usermod
用于修改用户的基本信息
补充说明
usermod命令 用于修改用户的基本信息。usermod 命令不允许你改变正在线上的使用者帐号名称。当 usermod 命令用来改变user id,必须确认这名user没在电脑上执行任何程序。你需手动更改使用者的 crontab 档。也需手动更改使用者的 at 工作档。采用 NIS server 须在server上更动相关的NIS设定。
语法
1 | usermod(选项)(参数) |
显示每个进程的栈跟踪
pstack命令 可显示每个进程的栈跟踪。pstack 命令必须由相应进程的属主或 root 运行。可以使用 pstack 来确定进程挂起的位置。此命令允许使用的唯一选项是要检查的进程的 PID。
命令软件包下载地址:https://packages.debian.org/sid/pstack
pstree以树结构显示进程
1 | <!-- more --> |
work为工作用户,-p为显示进程识别码,ad_preprocess共启动了6个子线程,加上主线程共7个线程。
1 | ps -Lf 4551 |
进程共启动了7个线程
pstack显示每个进程的栈跟踪:
1 | pstack 4551 |
比 netstat 好用的socket统计信息,iproute2 包附带的另一个工具,允许你查询 socket 的有关统计信息。
ss命令 用来显示处于活动状态的套接字信息。ss命令可以用来获取socket统计信息,它可以显示和netstat类似的内容。但ss的优势在于它能够显示更多更详细的有关TCP和连接状态的信息,而且比netstat更快速更高效。
当服务器的socket连接数量变得非常大时,无论是使用netstat命令还是直接cat /proc/net/tcp
,执行速度都会很慢。可能你不会有切身的感受,但请相信我,当服务器维持的连接达到上万个的时候,使用netstat等于浪费 生命,而用ss才是节省时间。
天下武功唯快不破。ss快的秘诀在于,它利用到了TCP协议栈中tcp_diag。tcp_diag是一个用于分析统计的模块,可以获得Linux 内核中第一手的信息,这就确保了ss的快捷高效。当然,如果你的系统中没有tcp_diag,ss也可以正常运行,只是效率会变得稍慢。
1 | <!-- more --> |
1 | -h, --help 帮助信息 |
1 | ss -t -a # 显示TCP连接 |
将本地或者远程端口和一个数比较
1 | # ss dport OP PORT 远程端口和一个数比较; |
用TCP 状态过滤Sockets
1 | ss -4 state closing |
显示ICP连接
1 | [root@localhost ~]# ss -t -a |
显示 Sockets 摘要
1 | [root@localhost ~]# ss -s |
列出当前的established, closed, orphaned and waiting TCP sockets
列出所有打开的网络连接端口
1 | [root@localhost ~]# ss -l |
查看进程使用的socket
1 | [root@localhost ~]# ss -pl |
找出打开套接字/端口应用程序
1 | [root@localhost ~]# ss -pl | grep 3306 |
显示所有UDP Sockets
1 | [root@localhost ~]# ss -u -a |
1 | ss state all sport = :ssh |