美文网首页运维linux
Linux TCP连接状态查看

Linux TCP连接状态查看

作者: SkTj | 来源:发表于2019-01-22 10:56 被阅读27次

    //查看哪些IP连接本机
    netstat -an|more
    //查看哪些IP连接80端口
    netstat -ant |grep -i "80"
    netstat -ant|grep -i "80"|wc -l
    //统计httpd协议的连接数
    ps -ef|grep httpd
    //统计已连接上的状态为established
    netstat -an|grep ESTABLISHED
    //查看哪个IP连接数最多
    netstat -na|grep ESTABLISHED|awk {print 5}|awk -F: {print1}|sort|uniq -c|sort -r +0n
    //统计各种连接状态
    netstat -n | awk '/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}'
    //各种状态详解
    TCP连接状态详解
    LISTEN: 侦听来自远方的TCP端口的连接请求
    SYN-SENT: 再发送连接请求后等待匹配的连接请求
    SYN-RECEIVED:再收到和发送一个连接请求后等待对方对连接请求的确认
    ESTABLISHED: 代表一个打开的连接
    FIN-WAIT-1: 等待远程TCP连接中断请求,或先前的连接中断请求的确认
    FIN-WAIT-2: 从远程TCP等待连接中断请求
    CLOSE-WAIT: 等待从本地用户发来的连接中断请求
    CLOSING: 等待远程TCP对连接中断的确认
    LAST-ACK: 等待原来的发向远程TCP的连接中断请求的确认
    TIME-WAIT: 等待足够的时间以确保远程TCP接收到连接中断请求的确认
    CLOSED: 没有任何连接状态

    //如果有大量TIME_WAIT,则需要调整系统内核参数
    vim /etc/sysctl.conf
    编辑文件,加入以下内容:
    net.ipv4.tcp_syncookies = 1
    net.ipv4.tcp_tw_reuse = 1
    net.ipv4.tcp_tw_recycle = 1
    net.ipv4.tcp_fin_timeout = 30
    然后执行 /sbin/sysctl -p 让参数生效。

    net.ipv4.tcp_syncookies = 1 表示开启SYN cookies。当出现SYN等待队列溢出时,启用cookies来处理,可防范少量SYN攻击,默认为0,表示关闭;
    net.ipv4.tcp_tw_reuse = 1 表示开启重用。允许将TIME-WAIT sockets重新用于新的TCP连接,默认为0,表示关闭;
    net.ipv4.tcp_tw_recycle = 1 表示开启TCP连接中TIME-WAIT sockets的快速回收,默认为0,表示关闭。
    net.ipv4.tcp_fin_timeout 修改系統默认的 TIMEOUT 时间

    查看APACHE的工作模式

    apachectl -l
    //计算httpd占用内存的平均数
    ps aux|grep -v grep|awk '/httpd/{sum+=$6;n++};END{print sum/n}'
    //apache性能调整
    <IfModule mpm_prefork_module>
    StartServers 5
    MinSpareServers 5
    MaxSpareServers 10
    ServerLimit 5500
    MaxClients 5000
    MaxRequestsPerChild 100
    </IfModule>
    maxclients * 内存平均数,最好不要超过总内存的80%
    当Apache被启动时,Apache会自动创建StartServers个进程,并且尽力将空闲进程数保持在MinSpareServers和MaxSpareServers之间。
    如果空闲进程小于MinSpareServers,Apache将会以大约每秒1个的速度新建进程。
    如果空闲进程小于MaxSpareServers,Apache将会删除多余的空闲进程,释放服务器资源。
    进程数的最大值由MaxClients控制,在Apache1.3中最大只能设置为256,但在Apache2.0中,可以通过在配置开头增加ServerLimit项目来突破256的限制,此时必须MaxClients ≤ ServerLimit ≤ 20000
    MaxRequestsPerChild用来控制每个进程在处理了多少次请求之后自动销毁,这个参数可以设置为0表示无限(即不销毁进程)。

    //DRBD
    DRBD(DistributedReplicatedBlockDevice)是一个基于块设备级别在远程服务器直接同步和镜像数据的软件,用软件实现的、无共享的、服务器之间镜像块设备内容的存储复制解决方案。它可以实现在网络中两台服务器之间基于块设备级别的实时镜像或同步复制(两台服务器都写入成功)/异步复制(本地服务器写入成功),相当于网络的RAID1,由于是基于块设备(磁盘,LVM逻辑卷),在文件系统的底层,所以数据复制要比cp命令更快。DRBD已经被MySQL官方写入文档手册作为推荐的高可用的方案之一

    相关文章

      网友评论

        本文标题:Linux TCP连接状态查看

        本文链接:https://www.haomeiwen.com/subject/tbqljqtx.html