1.查看服务器端口情况:lsof -i:端口号 (lsof -i 需要 root 用户的权限)
相关命令:
lsof -i:8080 –查看8080端口占用
lsof abc.txt –显示开启文件abc.txt的进程
lsof -c abc –显示abc进程现在打开的文件
lsof -c -p 1234 –列出进程号为1234的进程所打开的文件
lsof -g gid –显示归属gid的进程情况
lsof +d /usr/local/ –显示目录下被进程开启的文件
lsof +D /usr/local/ –同上,但是会搜索目录下的目录,时间较长
lsof -d 4 –显示使用fd为4的进程
lsof -i -U –显示所有打开的端口和UNIX domain文件
2.关闭某PID进程:kill -9 PID
3.显示 tcp,udp 的端口和进程等相关情况: netstat -tunlp | grep 端口号
-t (tcp) 仅显示tcp相关选项
-u (udp)仅显示udp相关选项
-n 拒绝显示别名,能显示数字的全部转化为数字
-l 仅列出在Listen(监听)的服务状态
-p 显示建立相关链接的程序名
示例:
netstat -ntlp –查看当前所有tcp端口
netstat -ntulp | grep 80 –查看所有80端口使用情况
netstat -ntulp | grep 3306 –查看所有3306端口使用情况
Linux ps aux指令詳解
linux上进程有5种状态:
1. 运行(正在运行或在运行队列中等待)
2. 中断(休眠中, 受阻, 在等待某个条件的形成或接受到信号)
3. 不可中断(收到信号不唤醒和不可运行, 进程必须等待直到有中断发生)
4. 僵死(进程已终止, 但进程描述符存在, 直到父进程调用wait4()系统调用后释放)
5. 停止(进程收到SIGSTOP, SIGSTP, SIGTIN, SIGTOU信号后停止运行运行)
1)ps a 显示现行终端机下的所有程序,包括其他用户的程序。
2)ps -A 显示所有程序。
3)ps c 列出程序时,显示每个程序真正的指令名称,而不包含路径,参数或常驻服务的标示。
4)ps -e 此参数的效果和指定”A”参数相同。
5)ps e 列出程序时,显示每个程序所使用的环境变量。
6)ps f 用ASCII字符显示树状结构,表达程序间的相互关系。
7)ps -H 显示树状结构,表示程序间的相互关系。
8)ps -N 显示所有的程序,除了执行ps指令终端机下的程序之外。
9)ps s 采用程序信号的格式显示程序状况。
10)ps S 列出程序时,包括已中断的子程序资料。
11)ps -t <终端机编号> 指定终端机编号,并列出属于该终端机的程序的状况。
12)ps u 以用户为主的格式来显示程序状况。
13)ps x 显示所有程序,不以终端机来区分。
14)ps -l 較長,較詳細的顯示該PID的信息
ps aux | grep jupou
查看jupou的进程
kill -s 9 PID
杀死指定的PID进程
相关信息的意义:
F 進程的標誌(flag),4表示用戶為超級用戶
S 進程的狀態(stat),各STAT的意義見下文
PID :進程的ID
C :CPU使用資源的百分比
PRI :priority(優先級)的縮寫,
NI :Nice值,
ADDR : 核心功能,指出該進程在內存的那一部分,如果是運行的進程,一般都是“-”
SZ :用掉的內存的大小
WCHAN :當前進程是否正在運行,若為“-”表示正在運行
TTY :登陸者的終端位置
TIME : 用掉的CPU的時間
CMD :所執行的指令
复制代码
# ps aux |more
USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
root 1 0.0 0.3 246728 6284 ? Ss 2023 12:49 /usr/lib/systemd/systemd –switched-root –system –deserialize 18
root 2 0.0 0.0 0 0 ? S 2023 0:02 [kthreadd]
root 3 0.0 0.0 0 0 ? I< 2023 0:00 [rcu_gp]
root 4 0.0 0.0 0 0 ? I< 2023 0:00 [rcu_par_gp]
root 6 0.0 0.0 0 0 ? I< 2023 0:00 [kworker/0:0H-events_highpri]
root 9 0.0 0.0 0 0 ? I< 2023 0:00 [mm_percpu_wq]
root 10 0.0 0.0 0 0 ? S 2023 2:00 [ksoftirqd/0]
root 11 0.0 0.0 0 0 ? I 2023 73:23 [rcu_sched]
root 12 0.0 0.0 0 0 ? S 2023 0:06 [migration/0]
root 13 0.0 0.0 0 0 ? S 2023 0:00 [watchdog/0]
root 14 0.0 0.0 0 0 ? S 2023 0:00 [cpuhp/0]
root 15 0.0 0.0 0 0 ? S 2023 0:00 [cpuhp/1]
root 16 0.0 0.0 0 0 ? S 2023 0:07 [watchdog/1]
root 17 0.0 0.0 0 0 ? S 2023 0:06 [migration/1]
root 18 0.0 0.0 0 0 ? S 2023 2:04 [ksoftirqd/1]
root 20 0.0 0.0 0 0 ? I< 2023 0:00 [kworker/1:0H-events_highpri]
root 23 0.0 0.0 0 0 ? S 2023 0:00 [kdevtmpfs]
root 24 0.0 0.0 0 0 ? I< 2023 0:00 [netns]
复制代码
上述各位解释:
USER :进程的属主;
PID :进程的ID;
PPID :父进程;
%CPU: 进程占用的CPU百分比;
%MEM :占用内存的百分比;
NI :进程的NICE值,数值大,表示较少占用CPU时间;
VSZ: 进程使用的虚拟內存量(KB);
RSS :该进程占用的固定內存量(KB)(驻留中页的数量);
TTY :该进程在那個終端上運行(登陸者的終端位置),若與終端無關,則顯示(?)。
若为pts/0等,则表示由网络连接主机进程
WCHAN :当前进程是否正在進行,若为-表示正在進行;
START :該進程被觸發启动时间;
TIME: 該进程實際使用CPU運行的时间;
COMMAND 命令的名称和参数;
STAT:狀態位常見的狀態字符
D :无法中断的休眠状态(通常 IO 的进程);
R :正在运行可中在队列中可过行的;
S :处于休眠状态;
T :停止或被追踪;
W :进入内存交换 (从内核2.6开始无效);
X :死掉的进程 (基本很少見);
Z :僵尸进程;
< :优先级高的进程
N : 优先级较低的进程
L :有些页被锁进内存;
s :进程的领导者(在它之下有子进程);
l :多进程的(使用 CLONE_THREAD, 类似 NPTL pthreads);
+ :位于后台的进程组;