Linux基础

1 帮助命令:

whatis make 查看某命令的简要说明
info make 查看某命令的详细说明
man make 查看某命令的具体参数和使用方法:man 3 printf、man 1 printf、

man man:
(1)用户可以操作的命令或者是可执行文件
(2)系统核心可调用的函数与工具等
(3)一些常用的函数与数据库
(4)设备文件的说明
(5)设置文件或者某些文件的格式
(6)游戏
(7)惯例与协议等。例如Linux标准文件系统、网络协议、ASCⅡ,码等说明内容
(8)系统管理员可用的管理条令
(9)与内核有关的文件

which make 查看某命令的位置
whereis make 查看某命令的搜索路径

2 文件及目录管理

mkdir newdir 创建目录:
rm -rf log.txt 删除文件或目录:
mv -r ./src ./dst 移动文件或目录:
cp -r ./src ./dst 复制文件或目录:
cd 切换目录:cd ~、cd ..
pwd 显示当前路径
ls 列出目录项:ls -lt、ll
find ./ -name “*.txt” 查找文件:find ./ -name “*.txt” -exec rm {} \;
wc -l 计算文件的Byte数、字数或是列数:统计行数find ./ | wc -l
cat log.txt 查看文件:cat -n log.txt
head -10 log.txt 查看头部文件:
tail -10 log.txt 查看尾部文件,显示最新内容:tail -f log.txt
diff log1.txt log2.txt 查看两文件差别:
chown -R mysql ./ 改变文件拥有者:
chgrp -R mysql ./ 改变文件所属组:
chmod 750 log.txt 改变文件读写执行属性:
ln -s lib.so.21 lib.so 创建软连接,连接无内容
ln a.out b.out 创建硬连接,重新创建新文件
cmd | cmd 管道,批处理命令
cmd; cmd 串联
cmd && cmd 前面成功,则执行后一条;否则不执行
cmd || cmd 前面失败,则执行后一条
> 重定向,标准错误重新定向到标准输出 2>&1,STDIN/STDOUT/STDERR对应0/1/2
  清空文件 :> a.txt
  追加方式添加文件 echo “a” >> a.txt

3 文本处理

find ./ -name “*.txt” [-o -name “*.sh]” 同时查找所有txt和pdf文件,-o为或
find ./ ! -name “*.txt” 查找所有非txt的文件
find ./ -maxdepth 1 -type f 指定搜索深度为1层,类型为文件的查找:文件f/目录d/链接l
find ./ -atime/-mtime/-ctime 7/-7/+7 被访问/内容被修改/元数据或权限改变、第7天/7天内/7天前
find ./ -size 2/-2/+2k/M/G 按照文件大小查找:等于2、小于2、大于2k或M或G
find ./ -perm 644 按照指定权限查找
find ./ -user weber 按照指定用户查找
find ./ -name “*.swp” -delete 查到到文件后删除
find ./ -name “*.txt” -exec ls -l {} \; 查找到文件后执行相应的命令:
  {} 代表find找到的文件名、\; 代表命令结束、{}和\;之间有空格
grep -nr “class” ./ 递归查找文件中的文本字符
sort file 对指定文件的文本进行排序
sort file | uniq [-c -d] 消除重复行:-c统计各行出现次数、-d找出重复行
cat text | tr ‘struct’ ‘class’ 将文本中的struct字符转换成class字符:
  -d 删除字符、-s 压缩重复字符
cut -f2,4 filename 按第2列和第4列截取文本
paste file1 file2 按列拼接文本
wc -l/w/c file 统计行数、单词数、字符数
sed流编辑器 以行为操作单位,先定位后操作,定位采用正则表达式,
 操作由p打印、a后插入、i前插入、s替代指定字符、d删除、c替代行;g全局,而非只操作单个;
 &表示正则选中的部分;正则表达式中加入反斜杠 \ 表示字符
sed -i “s/eagle/xxx/g” file 将每行中的所有eagle字符替换成xxx,-i表示写回文件
nl file| sed -n ‘5,7p’ nl将file标记处行号,-n仅显示操作后的结果,5到7行
awk数据流处理,区别:sed主要通过正则表达式操作,awk通过编程模式的逻辑操作
 基本模式:pattern { command }
 扩展模式:BEGIN{ statements } statements2 END{ statements } ,statements2 是基本模式内容
awk -F ‘:’ ‘{print NR, 2, 2 , 3}’ file 打印每第几行的第2和第3个字段,-F 指定分隔符
awk ‘NR==1,NR==4 {print}’ file 行号等于1和4的打印出来
echo -e “1\n 2\n 3\n 4\n” | awk ‘BEGIN{num = 0 print “begin”;} {sum += $1;} END {print “==”; print sum }’

NR:表示记录数量,在执行过程中对应当前行号
NF:表示字段数量,在执行过程总对应当前行的字段数
FILENAME:表示正在处理行的文件名
$0:这个变量包含执行过程中当前行的文本内容
$1:第一个字段的文本内容
$2:第二个字段的文本内容

4 磁盘管理

df -h 查看磁盘利用率:df -h -k/m
du -sh 查看文件或目录的磁盘使用空间
du -sh `ls` | sort 查看所有子目录排序后的大小
tar -zcvf log.tar.gz ./log 打包并gzip压缩
tar -zxvf log.tar.gz ./ 解包并gzip解压
tar -jcvf demo.tar.bz2 ./demo 打包并bzip压缩
tar -jxvf demo.tar.bz2 ./ 解包并bzip解压

5 进程管理

ps -aux | grep mysql 查询正在运行的进程快照:ps -ef
top 实时查询进程:输入P/M/i以CPU/Memory排序、不显示闲置进程
lsof -i:8080 查询8080端口的进程
lsof -u username / -c init / -p PID 查看用户/进程/进程号所打开的文件
kill -9 PID 强制杀死指定PID进程
pkill firefox 杀死指定名称的进程
pmap PID 输出进程内存信息,用于分析线程堆栈

6 性能监控

sar -u 1 2 查看CPU使用情况,每秒1次总共2次:sar -q 1 2
sar -r 1 2 查看内存使用情况
sar -W 1 2 查看页面交换情况
free -h 查看内存使用量
df -h 查看磁盘使用情况
watch -d -n 1 “free -h” 持续监控应用的数据变化,-d高亮差异,-n每隔1秒

7 网络工具

netstat -antp 查看所有tcp端口
netstat -anup 查看所有udp端口
route -n 查看路由状态
ping IP 发送ping包到指定IP
traceroute IP 探测前往IP的路由路径
host url 寻找域名对于的IP,方向DNS:host 31.13.68.1
wget url 直接下载文件
ssh username@ip ssh远程登入
sftp username@ip 文件传输,登入后操作如下:
  get / put filename 从远程主机上 下载 / 上传 文件
  ls、cd 列出或切换远程主机路径
  lls、lcd 列出或切换本地主机路径
scp -r ./src username@ip:/home/xxx/dst 将本机文件复制到远程主机
scp -r username@ip:/home/xxx/src ./dst 将远程文件复制到本地主机

8 用户管理工具
新建用户

sudo useradd -m username 为用户创建账号和用户目录
  groupadd mysql
  useradd -r -g mysql -s /bin/false mysql
sudo passwd username 为用户创建密码
sudo userdel -r username 删除用户和用户目录
su username 切换用户

将用户添加到组

groups 查看本用户所属哪些用户组,默认属于本用户名的组,groupadd groupname
sudo usermod -G groupname username 将用户添加到组
  -g 变更用户根组并从原有的组中除去
more /etc/passwd、/etc/group 查看用户、用户组

更改文件的读写权限、所属用户、所属用户组

chmod a/u/g/o+r/w/x file 更改文件读写权限:chmod 750 file
chown -R username file 更改文件所属用户
chgrp -R username file 更改文件所属用户组

环境变量

/etc/profile、/etc/bashrc 是系统全局环境变量设定
\~/.profile、~/.bashrc 是用户目录下的私有环境变量设定

\~/.profile与~/.bashrc的区别:都具有个性化定制功能,设定专有路径、环境变量等,但
 ~/.profile只能登入的时候执行一次
 ~/.bashrc每次shell script的执行都会使用它一次

当登入系统获得一个shell进程时,其读取环境设置脚本分为三步:
(1)读入全局环境变量设置文件/etc/profile,然后根据其内容读取额外的文档,如/etc/profile
(2)依次读取登录用户目录下~/.bash_profile、~/.bash_login、~/.profile
(3)最后读取~/.bashrc

9 系统管理及IPC资源管理

cat /proc/version 查看操作系统版本:uname -a、arch
cat /proc/cpuinfo | grep “model name” | wc -l 查看CPU型号
cat /proc/cpuinfo | grep “physical id” | wc -l 查看CPU个数
cat /proc/cpuinfo | grep processor | wc -l 查看CPU核数
cat /proc/meminfo 查看内存信息
date 显示时间:设置date -s 2014-09-15 17:05:00、写入CMOS:sudo clock -w
tzselect 设置时区
ipcs [-m / -q / -s] 查看进程间通信IPC的资源:全部、共享内存、队列、信号量
  ipcs -l 查看系统IPC参数,可在/etc/sysctl.conf修改后,sysctl -p生效

ipcrm 命令来清除IPC资源:
  ipcrm -M shmkey 移除用shmkey创建的共享内存段
  ipcrm -m shmid 移除用shmid标识的共享内存段
  ipcrm -Q msgkey 移除用msqkey创建的消息队列
  ipcrm -q msqid 移除用msqid标识的消息队列
  ipcrm -S semkey 移除用semkey创建的信号
  ipcrm -s semid 移除用semid标识的信号

ulimit -a 显示当前所有系统资源limit信息:设置ulimit -c unlimited

ref:
https://linuxtools-rst.readthedocs.io/zh_CN/latest/base/index.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值