参考

命令释义
shutdown -h now关机
shutdown -r now重启
uname -a查看系统内核信息
cat /proc/version查看系统内核版本
env查看当前用户的环境变量
cat /proc/cpuinfo查看系统内存信息
cat /proc/cpuinfo | grep name | cut -f2 -d: | uniq -c查看有几个逻辑CPU及型号
cat /proc/cpuinfo | grep physical | uniq -c查看有几颗CPU,每颗分别是几核
getconf LONG_BIT查看当前CPU运行在32bit
cat /proc/cpuinfo | grep flags | grep ‘ lm ’ | wc -l结果大于0,说明支持64bit
ln -s /usr/local/jdk1.8 jdk建立软连接
rpm -qa | grep 软件名查看是否通过rpm安装了该软件
ssh-keygen -t rsa -C your_email@example.com创建sshkey
alias ll=’ls -alF’在各个用户的.bash_profile中添加重命名配置
sudo ntpdate -u ntp.api.bz同步服务器时间
nohup xxx &后台运行,并且有nohup.out输出
nohup xxx > /dev/null &后台运行, 不输出任何日志
nohup xxx >out.log 2>&1 &后台运行, 并将错误信息做标准输出到日志中
pkill -kill -t [TTY]命令来完成强制活动用户退出.其中TTY表示终端名称
which <命令>查看命令路径
ulimit -n查看进程所有打开最大fd数
vim /etc/resolv.conf配置dns
nslookup google.com查看域名路由表
last -n 5最近登录信息列表
ifconfig em1 192.168.5.177 netmask 255.255.255.0设置固定ip
ps eww -p XXXXX(进程号)查看进程内加载的环境变量
ps auwxf查看进程树找到服务器进程
cd /proc/xxx(进程号)查看进程启动路径
useradd 用户名 && passwd 用户名添加用户
vim /etc/sudoers配置sudo权限
ps aux | grep xxx | grep -v grep | awk ‘{print $2}’ | xargs kill -9强制关闭进程名包含xxx的所有进程
:%s/x/y/gnormal模式下 g表示全局, x表示查找的内容, y表示替换后的内容
mount查看磁盘挂载情况
df查看磁盘分区信息
du -H -h查看目录及子目录大小
du -sh *查看当前目录下各个文件, 文件夹占了多少空间, 不会递归
wc -l filename查看文件里有多少行
wc -w filename看文件里有多少个word
wc -L filename文件里最长的那一行是多少个字
wc -c统计字节数
tar czvf xxx.tar压缩目录
zip -r xxx.zip压缩目录
tar zxvf xxx.tar
tar zxvf xxx.tar -C /xxx/yyy/解压到指定文件夹
unzip xxx.zip
chown eagleye.eagleye xxx.log变更文件所属用户, 用户组
cp xxx.log复制
cp -f xxx.log复制并强制覆盖同名文件
cp -r xxx(源文件夹) yyy(目标文件夹)复制文件夹
scp -P ssh端口 username@10.10.10.101:/home/username/xxx /home/xxx远程复制
mkdir -p /xxx/yyy/zzz级联创建目录
mkdir -p src/{test,main}/{java,resources}批量创建文件夹, 会在test,main下都创建java, resources文件夹
diff -u 1.txt 2.txt比较两个文件
tail -f xxx.log | pv -bt如果做性能测试, 可以每执行一次, 往日志里面输出 “.” , 这样日志中的字节数就是实际的性能测试运行的次数, 还可以看见实时速率.
cat -v xxx.sh查看特殊字符
sed -i ‘s/^M//g’ env.sh 去除文件的特殊字符, 比如^M: 需要这样输入: ctrl+v+enter去除特殊字符
cat file.sh > file.sh_bak可以转换为该系统下的文件格式
cat > file1.sh先将file.sh中文件内容复制下来然后运行, 然后粘贴内容, 最后ctrl + d 保存退出
:set fileencodings=utf-8 ,然后 w (存盘)一下即可转化为 utf8 格式,
:set fileformat=unix
在vim中通过如下设置文件编码和文件格式
find . -name “*.sh” | xargs dos2unix在mac下使用dos2unix进行文件格式化
awk ‘{print $0}’ xxx.log | tee test.log重定向的同时输出到屏幕
grep -v xxx反向匹配, 查找不包含xxx的内容
grep -v ‘^/pre>排除所有空行
grep -n “^$” 111.txt返回结果 2,则说明第二行是空行
awk -F ‘:’ ‘{if ($5 ~ /user/) print $0}’ /etc/passwd以’:’ 为分隔符,如果第五域有user则输出该行
awk -v RS=’character’ ‘END {print –NR}’ xxx.txt统计单个文件中某个字符(串)(中文无效)出现的次数
find /home/eagleye -name ‘*.mysql’ -print在目录下找后缀是.mysql的文件
find /doc -name ‘*bak’ -exec rm {} ;会从 /doc 目录开始往下找,找到凡是文件名结尾为 bak的文件,把它删除掉。-exec 选项是执行的意思,rm 是删除命令,{ } 表示文件名,“;”是规定的命令结尾
lsof -i:port查看什么进程使用了该端口
/sbin/ifconfig -a | grep inet | grep -v 127.0.0.1 | grep -v inet6 | awk ‘{print $2}’ | tr -d “addr:”获取本机ip地址
service iptables status查看iptables状态
iptables -I INPUT -s ***.***.***.*** -j DROP要封停一个ip
iptables -D INPUT -s ***.***.***.*** -j DROP要解封一个IP
/etc/init.d/iptables status | start | stop | restart防火墙查看状态、开启、关闭、重启
nc 192.168.0.11 8000 < data.txt给某一个endpoint发送TCP请求,就将data的内容发送到对端
tcpdump -i em1 tcp port 12301 -s 1500 -w abc.pcapdump出本机12301端口的tcp包
traceroute -I www.163.comtraceroute默认使用udp方式, 如果是-I则改成icmp方式
netstat -n | awk ‘/^tcp/ {n=split($(NF-1),array,”:”);if(n<=2)++S[array[(1)]];else++S[array[(4)]];++s[$NF];++N} END {for(a in S){printf(“%-20s %s\n”, a, S[a]);++I}printf(“%-20s %s\n”,”TOTAL_IP”,I);for(a in s) printf(“%-20s %s\n”,a, s[a]);printf(“%-20s %s\n”,”TOTAL_LINK”,N);}’输出每个ip的连接数,以及总的各个状态的连接数
top监控linux性能命令
dmesg查看系统日志
iostat -xz 1磁盘IO情况监控
free -m内存使用情况

top

列名含义
PID进程id
PPID父进程id
RUSERReal user name
UID进程所有者的用户id
USER进程所有者的用户名
GROUP进程所有者的组名
TTY启动进程的终端名。不是从终端启动的进程则显示为 ?
PR优先级
NInice值。负值表示高优先级,正值表示低优先级
P最后使用的CPU,仅在多CPU环境下有意义
%CPU上次更新到现在的CPU时间占用百分比
TIME进程使用的CPU时间总计,单位秒
TIME+进程使用的CPU时间总计,单位1/100秒
%MEM进程使用的物理内存百分比
VIRT进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES
SWAP进程使用的虚拟内存中,被换出的大小,单位kb。
RES进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA
CODE可执行代码占用的物理内存大小,单位kb
DATA可执行代码以外的部分(数据段+栈)占用的物理内存大小,单位kb
SHR共享内存大小,单位kb
nFLT页面错误次数
nDRT最后一次写入到现在,被修改过的页面数。
S进程状态。D=不可中断的睡眠状态,R=运行,S=睡眠,T=跟踪/停止,Z=僵尸进程
COMMAND命令名/命令行
WCHAN若该进程在睡眠,则显示睡眠中的系统函数名
Flags任务标志,参考 sched.h