• 工作中常用Linux命令--服务器运维


    工作中常用Linux命令--服务器运维

    lsof
    查看端口使用情况 lsof -i:8080
    更多lsof命令使用说明:http://www.cnblogs.com/peida/archive/2013/02/26/2932972.html

    ss
    通过ss -s 显示Socket摘要
    [root@dev-001 ~]# ss -s
    Total: 2467 (kernel 2801)
    TCP: 10323 (estab 2178, closed 7880, orphaned 251, synrecv 0, timewait 7876/0), ports 1554

    Transport Total IP IPv6
    * 2801 - -
    RAW 0 0 0
    UDP 0 0 0
    TCP 2443 2047 396
    INET 2443 2047 396
    FRAG 0 0 0
    更多ss命令使用说明:http://www.cnblogs.com/peida/archive/2013/03/11/2953420.html


    ps
    列出目前所有的正在内存当中的程序
    ps aux
    ps aux | grep tomcat
    显示所有进程信息,连同命令行
    ps -ef
    ps -ef | grep tomcat

    ps aux 是用BSD的格式来显示 java这个进程
    显示的项目有:USER , PID , %CPU , %MEM , VSZ , RSS , TTY , STAT , START , TIME , COMMAND
    ps -ef 是用标准的格式显示java这个进程
    显示的项目有:UID , PID , PPID , C , STIME , TTY , TIME , CMD

    ps -eo vsz,rss,comm | grep java

    更多ps命令使用说明:http://www.cnblogs.com/peida/archive/2012/12/19/2824418.html

    iostat
    iostat工具将对系统的磁盘操作活动进行监视
    查看TPS和吞吐量信息 iostat -d -k 1 1
    查看cpu状态 iostat -c 1 3
    更多iostat命令使用说明:http://www.cnblogs.com/peida/archive/2012/12/28/2837345.html


    netstat
    显示网卡列表 netstat -i

    查看机器的当前连接状态
    netstat -anp

    查看端口使用情况
    netstat -tlnp |grep 8080
    netstat -ano | grep 8080

    查询tomcat连接数
    netstat -na | grep ESTAB | grep 8080 | wc -l

    查看当前time_wait的数量
    netstat -an | grep TIME_WAIT | wc -l

    把状态全都取出来后使用uniq -c统计后再进行排序
    netstat -nat |awk '{print $6}'|sort|uniq -c|sort -rn

    统计机器中网络连接各个状态个数
    netstat -n | awk '/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}'
    它会显示例如下面的信息:
    TIME_WAIT 814
    CLOSE_WAIT 1
    FIN_WAIT1 1
    ESTABLISHED 634
    SYN_RECV 2
    LAST_ACK 1
    常用的三个状态是:ESTABLISHED 表示正在通信,TIME_WAIT 表示主动关闭,CLOSE_WAIT 表示被动关闭。
    参考:http://blog.csdn.net/shootyou/article/details/6622226

    更多 netstat命令使用说明:http://www.cnblogs.com/peida/archive/2013/03/08/2949194.html

    top
    top -c
    top -p 31843
    先输入top,然后再按shift+h 显示线程消耗资源

    top mem consumer: sudo ps -aux | sort -k4nr | head -5 or top, then press M

    更多top命令使用说明:http://www.cnblogs.com/peida/archive/2012/12/24/2831353.html

    vmstat
    vmstat 5 5 监控虚拟内存使用情况 vmstat 5 5(表示在5秒时间内进行5次采样)
    更多vmstat命令使用说明http://www.cnblogs.com/peida/archive/2012/12/25/2833108.html

    free
    显示Linux系统中空闲的、已用的物理内存及swap内存,及被内核使用的buffer
    free -m
    free -g
    更多参数说明:http://www.cnblogs.com/peida/archive/2012/12/25/2831814.html

    iotop

    用来监视磁盘I/O使用状况的工具

    http://man.linuxde.net/iotop

    atop

    http://www.cnblogs.com/bangerlee/archive/2011/12/23/2294090.html

    针对Nginx access.log统计命令
    1、查看当天有多少个IP访问:
    awk '{print $1}' access.log|sort|uniq|wc -l

    查看当天访问次数最多的10个IP
    awk '{print $1}' access.log |sort |uniq -c|sort -nr|head

    2、查看某一个页面被访问的次数:
    grep "/index.php" access.log | wc -l

    3、查看每一个IP访问了多少个页面:
    awk '{++S[$1]} END {for (a in S) print a,S[a]}' access.log

    4、将每个IP访问的页面数进行从小到大排序:
    awk '{++S[$1]} END {for (a in S) print S[a],a}' access.log | sort -n

    5、查看某一个IP访问了哪些页面:
    grep ^111.111.111.111 access.log| awk '{print $1,$7}'

    6、查看2014年6月21日14时这一个小时内有多少IP访问:

    awk '{print $4,$1}' access.log | grep 21/Jun/2014:14 | awk '{print $2}'| sort | uniq | wc -l

     查看当天访问次数最多的时间段
    awk '{print $4}' access.log | grep "21/Jun/2014" |cut -c 14-18|sort|uniq -c|sort -nr|head


    其他命令
    ls -lh 以M,G单位查看文件

    通过kill命令杀掉进程
    kill -s 9 pid
    或kill -9 pid


    watch -n 2 -d free 实时监控内存使用情况
    df -h 查看磁盘使用情况(文件系统的使用情况)
    pstree -p root | grep java pstree以树结构显示进程

    JVM:
    Tomcat debug: -agentlib:jdwp=transport=dt_socket,address=8088,server=y,suspend=n
    JProfiler: -agentpath:/opt/jprofiler7/bin/linux-x64/libjprofilerti.so=port=8080,nowait
    JConsole: -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.port=3306 -Dcom.sun.management.jmxremote
    Print default parameters: java -XX:+PrintFlagsFinal -version
    jmap -histo <pid>
    jmap -heap <pid>
    jmap -permstat <pid>
    jmap -dump:format=b,file=/xxx.hprof <pid>
    jhat -baseline 1.hprof 2.hprof
    jstack -l <pid>
    jstat -gc <pid>
    jstat -gccapacity <pid>
    jstat -compiler <pid>
    jstat -class <pid>
    另外,有一些JVM问题定位的工具使用,可参考 http://www.raychase.net/1519

    jstack 42036 查找线程的信息
    jstack -J-d64 42036
    jmap -heap 31843 打印heap的概要信息,GC使用的算法,heap的配置及wise heap的使用情况.
    jmap -histo 4939 打印每个class的实例数目,内存占用,类全名信息. VM的内部类名字开头会加上前缀”*”. 如果live子参数加上后,只统计活的对象数量.

    更多参考资料:

    专题:Linux监控工具的展览馆 http://os.51cto.com/art/201005/200741.htm

    理解Linux系统负荷 http://www.ruanyifeng.com/blog/2011/07/linux_load_average_explained.html

    利用shell脚本来监控linux系统的负载与CPU占用情况 http://huangrs.blog.51cto.com/2677571/788379/

    Linux下容易被忽视的那些命令用法 http://blog.csdn.net/xhjcehust/article/details/77253127

  • 相关阅读:
    《家庭财务总管》升级了(1.0.0.1)
    谁拥有接口?
    VScode调试C++工程
    NVIDIA显卡原生管理查询功能nvidiasmi的部分使用功能
    python版本的两款NVIDIA显卡管理查询工具
    pytorch之网络参数统计 torchstat & torchsummary
    电脑、笔记本、手机维修经验分享网站,专业领域网站
    Python使用pynvml查看GPU信息
    【转载】 Ubuntu下使用VSCode的launch.json及tasks.json编写
    笔记本挑电源适配器吗,是不是电压相同情况下保证功率大于等于原装适配器就可以保证笔记本正常运行???
  • 原文地址:https://www.cnblogs.com/huligong1234/p/4220132.html
Copyright © 2020-2023  润新知