zoukankan      html  css  js  c++  java
  • Linux环境下Netstat与PS的使用

    Linux下用netstat查看网络状态、端口状态

    在linux一般使用netstat 来查看系统端口使用情况步。

          netstat命令是一个监控TCP/IP网络的非常有用的工具,它可以显示路由表、实际的网络连接以及每一个网络接口设备的
          netstat命令的功能是显示网络连接、路由表和网络接口信息,可以让用户得知目前都有哪些网络连接正在运作。

          该命令的一般格式为:
          netstat [选项]
          命令中各选项的含义如下:
          -a 显示所有socket,包括正在监听的。
          -c 每隔1秒就重新显示一遍,直到用户中断它。
          -i 显示所有网络接口的信息,格式同“ifconfig -e”。
          -n 以网络IP地址代替名称,显示出网络连接情形。
          -r 显示核心路由表,格式同“route -e”。
          -t 显示TCP协议的连接情况。
          -u 显示UDP协议的连接情况。
          -v 显示正在进行的工作。

    1. netstat -an | grep LISTEN
          0.0.0.0的就是每个IP都有的服务,写明哪个IP的就是绑定那个IP的服务。

    2. netstat -tln
          用来查看linux的端口使用情况

    3. /etc/init.d/vsftp start
          是用来启动ftp端口~!


    4. netstat
          查看已经连接的服务端口(ESTABLISHED)

    5. netstat -a
          查看所有的服务端口(LISTEN,ESTABLISHED)

    6. sudo netstat -ap
          查看所有的服务端口并显示对应的服务程序名

    7. nmap <扫描类型><扫描参数>
    例如:
           nmap localhost
    nmap -p 1024-65535 localhost
    nmap -PT 192.168.1.127-245
    当我们使用 netstat -apn 查看网络连接的时候,会发现很多类似下面的内容:
    Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
    tcp 0 52 218.104.81.152:7710 211.100.39.250:29488 ESTABLISHED 6111/1
    显示这台服务器开放了7710端口,那么这个端口属于哪个程序呢?我们可以使用 lsof -i :7710 命令来查询:
    COMMAND PID USER FD TYPE DEVICE SIZE NODE NAME
    sshd 1990 root 3u IPv4 4836 TCP *:7710 (LISTEN) 54com.cn

    这样,我们就知道了7710端口是属于sshd程序的。

    Linux下用内建的PS工具查看当前进程

     查看它的man手册可以看到,ps命令能够给出当前系统中进程的快照。它能捕获系统在某一事件的进程状态。如果你想不断更新查看的这个状态,可以使用top命令。

     ps命令支持三种使用的语法格式

           1.UNIX 风格,选项可以组合在一起,并且选项前必须有“-”连字符

           2.BSD 风格,选项可以组合在一起,但是选项前不能有“-”连字符

           3.GNU 风格的长选项,选项前有两个“-”连字符 

    我们能够混用这几种风格,但是可能会发生冲突。本文使用 UNIX 风格的ps命令。这里有在日常生活中使用较多的ps命令的例子。 

    ps工具标识进程的5种状态码: 

    1. D 不可中断 uninterruptible sleep (usually IO)   
    2. R 运行 runnable (on run queue)   
    3. S 中断 sleeping   
    4. T 停止 traced or stopped   
    5. Z 僵死 a defunct (”zombie”) process 
    1)ps a 显示现行终端机下的所有程序,包括其他用户的程序。   
    2)ps -A 显示所有程序。   
    3)ps c 列出程序时,显示每个程序真正的指令名称,而不包含路径,参数或常驻服务的标示。   
    4)ps -e 此参数的效果和指定"A"参数相同。  例如:  ps -e|grep sshd  
    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   
    显示所有程序,不以终端机来区分。   
    最常用的方法是ps -aux,然后再利用一个管道符号导向到grep去查找特定的进程,然后再对特定的进程进行操作。 
    

    10个重要的ps命令实战

    1. 不加参数执行ps命令 

    这是一个基本的 ps 使用。在控制台中执行这个命令并查看结果。 

    不加选项执行ps命令

     不加选项执行ps命令 

    结果默认会显示4列信息。 

    • PID: 运行着的命令(CMD)的进程编号
    • TTY: 命令所运行的位置(终端)
    • TIME: 运行着的该命令所占用的CPU处理时间
    • CMD: 该进程所运行的命令 

    这些信息在显示时未排序。 

    2. 显示所有当前进程 

    使用 -a 参数。-a 代表 all。同时加上x参数会显示没有控制终端的进程。 

    1. $ ps -ax 

    这个命令的结果或许会很长。为了便于查看,可以结合less命令和管道来使用。 

    1. $ ps -ax | less 

    ps all 信息

    ps all 信息 

    3. 根据用户过滤进程 

    在需要查看特定用户进程的情况下,我们可以使用 -u 参数。比如我们要查看用户'pungki'的进程,可以通过下面的命令: 

    1. $ ps -u pungki

    通过用户过滤

    通过用户过滤 

    4. 通过cpu和内存使用来过滤进程 

    也许你希望把结果按照 CPU 或者内存用量来筛选,这样你就找到哪个进程占用了你的资源。要做到这一点,我们可以使用 aux 参数,来显示全面的信息: 

    1. $ ps -aux | less

    显示全面信息

    显示全面信息 

    当结果很长时,我们可以使用管道和less命令来筛选。 

    默认的结果集是未排好序的。可以通过 --sort命令来排序。 

    根据 CPU 使用来升序排序 

    1. $ ps -aux --sort -pcpu | less 

    根据cpu使用排序

     根据cpu使用排序

     根据 内存使用 来升序排序 

    1. $ ps -aux --sort -pmem | less 

    根据内存使用来排序

     根据内存使用来排序 

    我们也可以将它们合并到一个命令,并通过管道显示前10个结果: 

    1. $ ps -aux --sort -pcpu,+pmem | head -n 10 

    5. 通过进程名和PID过滤 

    使用 -C 参数,后面跟你要找的进程的名字。比如想显示一个名为getty的进程的信息,就可以使用下面的命令: 

    1. $ ps -C getty 

    通过进程名和PID过滤

    通过进程名和PID过滤 

    如果想要看到更多的细节,我们可以使用-f参数来查看格式化的信息列表: 

    1. $ ps -f -C getty 

    通过进程名和PID过滤

    通过进程名和PID过滤 

    6. 根据线程来过滤进程 

    如果我们想知道特定进程的线程,可以使用-L 参数,后面加上特定的PID。 

    1. $ ps -L 1213 

    根据线程来过滤进程

    根据线程来过滤进程 

    7. 树形显示进程 

    有时候我们希望以树形结构显示进程,可以使用 -axjf 参数。 

    1. $ps -axjf 

    树形显示进程

    树形显示进程 

    或者可以使用另一个命令。 

    1. $ pstree

    树形显示进程

     树形显示进程

     8. 显示安全信息

     如果想要查看现在有谁登入了你的服务器。可以使用ps命令加上相关参数: 

    1. $ ps -eo pid,user,args 

    参数 -e 显示所有进程信息,-o 参数控制输出。Pid,User 和 Args参数显示PID,运行应用的用户和该应用。 

    显示安全信息

    显示安全信息 

    能够与-e 参数 一起使用的关键字是args, cmd, comm, command, fname, ucmd, ucomm, lstart, bsdstart 和 start。 

    9. 格式化输出root用户(真实的或有效的UID)创建的进程 

    系统管理员想要查看由root用户运行的进程和这个进程的其他相关信息时,可以通过下面的命令: 

    1. $ ps -U root -u root u 

    -U 参数按真实用户ID(RUID)筛选进程,它会从用户列表中选择真实用户名或 ID。真实用户即实际创建该进程的用户。 

    -u 参数用来筛选有效用户ID(EUID)。 

    最后的u参数用来决定以针对用户的格式输出,由User, PID, %CPU, %MEM, VSZ, RSS, TTY, STAT, START, TIME 和 COMMAND这几列组成。 

    这里有上面的命令的输出结果: 

    show real and effective User ID

    show real and effective User ID 

    10. 使用PS实时监控进程状态 

    ps 命令会显示你系统当前的进程状态,但是这个结果是静态的。 

    当有一种情况,我们需要像上面第四点中提到的通过CPU和内存的使用率来筛选进程,并且我们希望结果能够每秒刷新一次。为此,我们可以将ps命令和watch命令结合起来。 

    1. $ watch -n 1 ps -aux --sort -pmem, -pcpu’  

    组合 ps 和 watch

     组合 ps 和 watch 

    如果输出太长,我们也可以限制它,比如前20条,我们可以使用head命令来做到。 

    1. $ watch -n 1 ps -aux --sort -pmem, -pcpu | head 20’ 

    组合 ps 和 watch

     组合 ps 和 watch 

    这里的动态查看并不像top或者htop命令一样。但是使用ps的好处是你能够定义显示的字段,你能够选择你想查看的字段。 

    举个例子,如果你只需要看名为'pungki'用户的信息,你可以使用下面的命令: 

    1. $ watch -n 1 ps -aux -U pungki u --sort -pmem, -pcpu | head 20’  

    组合 ps 和 watch

     组合 ps 和 watch 

    结论 

    你也许每天都会使用ps命令来监控你的Linux系统。但是事实上,你可以通过ps命令的参数来生成各种你需要的报表。 

    ps命令的另一个优势是ps是各种 Linux系统都默认安装的,因此你只要用就行了。 

    不要忘了通过 man ps来查看更多的参数。(LCTT 译注:由于 ps 命令古老而重要,所以它在不同的 UNIX、BSD、Linux 等系统中的参数不尽相同,因此如果你用的不是 Linux 系统,请查阅你的文档了解具体可用的参数。)

  • 相关阅读:
    PHP正则表达式
    PHP日期时间处理
    好文摘录
    Unix时间戳与C# DateTime时间类型互换
    dedecms表结构分析
    css默认值汇总
    jQuery offset,position,offsetParent,scrollLeft,scrollTop html控件定位 css position
    html中label宽度设置、非替换元素和替换元素
    css position, display, float 内联元素、块级元素
    CSS技巧(一):清除浮动
  • 原文地址:https://www.cnblogs.com/peteremperor/p/8666934.html
Copyright © 2011-2022 走看看