1.查看程序运行状态等信息
ps aux|grep name
# D:不可中断 R:运行 S:等待 T:停止 Z:僵死
2.查看程序信息
ps -ef|grep name
3.对某一个程序进行操作
kill -STOP pid #(暂停一个程序)
kill -CONT pid #(恢复一个程序)
kill -KILL pid #(杀死一个程序)
4.释放内存
sync #将内存中的数据刷新到磁盘
echo 3 > /proc/sys/vm/drop_caches #清理内存
free -m #查看内存使用情况
5.快速删除一个文件中的文件
which rsync #检查是否安装
mkdir /tmp/test #创建用于交换删除的文件夹
rsync --delete -before -a -H -v --progress --stats /tmp/test/ 要删除的文件夹 #删除
ls -l| awk '{ print "rm -f ",$9}'|sh
6.守护进程(例子)
node server.js #前台进程
node server.js & #后台进程(不是守护进程)
ctrl + z #将一个正在运行的前台进程变成后台进程,并且会暂停
bg #让最后一个成为后台进程的进程继续运行
shopt | gref huponexit #查看后台任务会不会收到SIGHUP信号,off为不收到
jobs #列出所有后台任务列表
disown #将最近一个正在执行的后台任务移出
nohup node server.js & #建议的用法:
7.增大交换区大小
dd if=/dev/zero of=swapfile bs=1024 count=2000000 #代表2G,一般为运行内存的一或两倍
mkswap /home/swap/swapfile #创建交换文件
swapon swapfile #激活交换文件
swapoff swapfile #关闭交换文件
8.统计文件个数
ls -l | grep "^-" | wc -l #当前文件夹 不包括子目录
ls -lR| grep "^-" | wc -l #当前文件夹 包括子目录
9.启动python带参数
python submit_example.py --urlfile=/tmp/huyaxing/imageUrl_2020-10-14_10_13_11_all.txt
10.scp复制远程文件到本地
scp huyaxing@10.221.65.162:/home/huyaxing/IdeaProjects/weibodata/imageurl/2020-10-14_10:13:11/imageUrl_2020-10-14_10_13_11_all.txt /tmp/huyaxing/
11.将一个文件分割为多个小文件
split -b 40000M -d -a 1 文件名 文件名 #两个文件名相同
tar -zcvf cm-11.tar.gz cm-11 | split -b 4000M -d -a 1 - cm-11.tar.gz.
12.top命令,实时对处理器的监控状态
前五行信息:
第1行: top - 05:43:27 up 4:52, 2 users, load average: 0.58, 0.41, 0.30 第1行是任务队列信息,其参数如下:
内容 | 含义 |
---|---|
05:43:27 | 表示当前时间 |
up 4:52 | 系统运行时间 格式为时:分 |
2 users | 当前登录用户数 |
load average: 0.58, 0.41, 0.30 | 系统负载,即任务队列的平均长度。 三个数值分别为 1分钟、5分钟、15分钟前到现在的平均值。 |
load average: 如果这个数除以逻辑CPU的数量,结果高于5的时候就表明系统在超负荷运转了。
第2行: Tasks: 159 total, 1 running, 158 sleeping, 0 stopped, 0 zombie
第3行: %Cpu(s): 37.0 us, 3.7 sy, 0.0 ni, 59.3 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st
第2、3行为进程和CPU的信息当有多个CPU时,这些内容可能会超过两行
内容 | 含义 |
---|---|
159 total | 进程总数 |
1 running | 正在运行的进程数 |
158 sleeping | 睡眠的进程数 |
0 stopped | 停止的进程数 |
0 zombie | 僵尸进程数 |
37.0 us | 用户空间占用CPU百分比 |
3.7 sy | 内核空间占用CPU百分比 |
第4行: KiB Mem: 1530752 total, 1481968 used, 48784 free, 70988 buffers
第5行: KiB Swap: 3905532 total, 267544 used, 3637988 free. 617312 cached Mem
第4、5行为内存信息其参数如下:
内容 | 含义 |
---|---|
KiB Mem: 1530752 total | 物理内存总量 |
1481968 used | 使用的物理内存总量 |
48784 free | 空闲内存总量 |
70988 buffers | 用作内核缓存的内存量 |
KiB Swap: 3905532 total | 交换区总量 |
267544 used | 使用的交换区总量 |
3637988 free | 空闲交换区总量 |
617312 cached Mem | 缓冲的交换区总量 |
这些是进程的信息
列名 | 含义 |
---|---|
PID | 进程id |
PPID | 父进程id |
RUSER | Real user name |
UID | 进程所有者的用户id |
USER | 进程所有者的用户名 |
GROUP | 进程所有者的组名 |
TTY | 启动进程的终端名。不是从终端启动的进程则显示为 ? |
PR | 优先级 |
NI | nice值。负值表示高优先级,正值表示低优先级 |
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 | 任务标志 |
常用命令:
top // 每隔5秒显式所有进程的资源占用情况
top -d 2 // 每隔2秒显式所有进程的资源占用情况
top -c // 每隔5秒显式进程的资源占用情况,并显示进程的命令行参数(默认只有进程名)
top -p 12345 -p 6789// 每隔5秒显示pid是12345和pid是6789的两个进程的资源占用情况
top -d 2 -c -p 123456 // 每隔2秒显示pid是12345的进程的资源使用情况,并显式该进程启动的命令行参数
13.netstat 命令用于显示网络状态。
netstat -ap # 列出当前所有连接并显示进程名
netstat -ap | grep -v unix #列出当前所有连接不包括开头为unix的连接
netstat -atp #列出当前所有TCP连接
netstat -aup #列出当前所有UDP连接