教程:如何在Linux上统计TCP连接时长
作为一名Linux系统管理员,网络连接是我们经常需要关注的一个数据和指标。在处理网络故障、优化网络性能等方面,了解TCP连接时长的情况是非常有帮助的。本篇文章将介绍如何在Linux上统计TCP连接时长,让你快速掌握各种TCP连接的情况。
1. 准备工作
在开始统计TCP连接时长之前,我们需要确保系统中已经安装了必要工具。这些工具主要包括:
– netstat:用于显示网络连接、路由表等信息。
– awk:用于数据处理和分析。
– sort:用于排序。
– uniq:用于去重。
大多数基于Linux的操作系统都默认安装了这些工具。你可以通过执行以下命令来验证这些工具是否可用:
“`
$ which netstat awk sort uniq
“`
如果这些命令有任何输出,则说明这些工具已经安装并且可用。
2. 统计TCP连接时长
2.1 使用netstat命令统计时长
最简单的方法是使用netstat命令显示当前的TCP连接,并使用awk命令提取连接时长。具体命令如下:
“`
$ netstat -npt | awk ‘/^tcp/ {print $4,$7}’ | awk -F: ‘{print $1,$2}’ | awk ‘{print $1,$2,$3,$4,$5,int($6/60)”:”int($6%60)}’
“`
这个命令会输出一个连接列表,其中包含本地IP地址、本地端口、远程IP地址、远程端口和连接时长。连接时长以分钟:秒的形式呈现。
2.2 使用脚本自动统计时长
如果需要定期获取TCP连接时长的情况,可以编写一个脚本来自动完成这个任务。以下是一个简单的bash脚本,可以在Linux上自动统计TCP连接时长:
“`
#!/bin/bash
# 获取当前日期和时间
now=$(date +”%Y-%m-%d_%H:%M:%S”)
# 定义输出文件
output_file=”/tmp/tcp_conn_$now.txt”
# 使用netstat命令查询TCP连接,提取连接时长
netstat -npt | awk ‘/^tcp/ {print $4,$7}’ | awk -F: ‘{print $1,$2}’ | awk ‘{print $1,$2,$3,$4,$5,int($6/60)”:”int($6%60)}’ > $output_file
echo “TCP连接时长统计结果已经保存到: $output_file”
“`
该脚本会将TCP连接时长记录在/tmp/tcp_conn_日期时间.txt中。
3. 统计连接数
如果需要统计TCP连接数,我们可以使用以下命令来查看当前的TCP连接数:
“`
$ netstat -nat | awk ‘$1~/^tcp/ {print $NF}’ | sort | uniq -c | sort -rn
“`
该命令将输出所有的TCP状态和连接数。你可以使用uniq指令来去重并计数,再利用sort命令的-rn选项按照连接数从大到小排序。
4.
通过以上介绍,我们已经了解到如何在Linux上统计TCP连接时长和连接数。这些信息对于管理网络的系统管理员来说是非常有用的。希望这篇文章可以帮助你轻松地获取TCP连接的时长以及其他网络连接的信息。
成都网站建设公司-创新互联,建站经验丰富以策略为先导10多年以来专注数字化网站建设,提供企业网站建设,高端网站设计,响应式网站制作,设计师量身打造品牌风格,热线:028-86922220查看TCP/IP连接的状态命令如下:
tcp 协议 是互联网中最常用的协议 , 开发人员基本上天天和它打交道,对它进行深入了解。 可以帮助我们排查定位bug和进行程序优化。下面我将就TCP几个点做深入的探讨
客户端:收到 ack 后 分配连接资源。 发送数据
服务器 : 收到 syn 后立即 分配连接资源
客户端:收到ACK, 立即分配资源
服务器:收到ACK, 立即分配资源
既然三次握手也液银颤不是100%可靠, 那四次,五次,六次。。。呢? 其实都一样,不管多少次都有丢包问题。
client 只发送一个 SYN, server 分配一个tcb, 放入syn队列中。 这时候连接叫
半连接
状态;如果server 收不到 client 的ACK, 会不停重试 发送 ACK-SYN 给client 。重试间隔 为 2 的 N 次方 叠加(2^0 , 2^1, 2^2 ….);直至超时才释放syn队列中的这个 TCB;
在半连接状态下, 一方面会占用队列配额资源,另一方面占用内存资源。我们应该让半连接状态存在时间尽可能的小
当client 向一个未打开的端口发起连接请求时,会收到一个RST回复包
当listen 的 backlog 和 somaxconn 都设置了得时候, 取两者min值
Recv-Q 是accept 队列当前个数, Send-Q 设置更大值
这种SYN洪水攻击是一种常见攻击方式,就是利用半连接队列特性,占满syn 队列的 资源,导致 client无法连接上。
解决方案:
为什么不像握手那样合并成三次挥手? 因为和刚开始连接情况,连接是大家都从0开始, 关闭时有历史包袱的。server(被动关闭方) 收到 client(主动关闭方) 的关闭请求FIN包。 这时候可能还有未发送完的数据,不能丢弃。 所以需要分开。事实可能是这样
当然,在没有待发数据,并且允许 Delay ACK 情况下, FIN-ACK合并还是非常常见的事情,这是三次挥手是可以的。
同上
CLOSE_WAIT 是被动关闭方才有的状态
。
被动关闭方 到 期间的状态为 CLOSE_WAIT, 这个状态仍然能发闹败送数据。 我们叫做
半关闭
, 下面用个例子来分析:
这个是我实际生产环境碰到的一个问题,长连接会话场景,server端收到client的rpc call 请求1,处理发现请求包有问题,就强制关闭结束这次会话, 但是 因为client 发送 第二次请求之前,并没有去调用recv,所以并不知道 这个连接被server关闭, 继续发送 请求2 , 此时是半连接,能够成功发送到对端机器,但是recv结果后,搏兆遇到连接已经关闭错误。
如果 client 和 server 恰好同时发起关闭连接。这种情况下,两边都是主动连接,都会进入 TIME_WAIT状态
1、
被动关闭方在LAST_ACK状态(已经发送FIN),等待主动关闭方的ACK应答,但是 ACK丢掉, 主动方并不知道,以为成功关闭。因为没有TIME_WAIT等待时间,可以立即创建新的连接, 新的连接发送SYN到前面那个未关闭的被动方,被动方认为是收到错误指令,会发送RST。导致创建连接失败。
2、
主动关闭方断开连接,如果没有TIME_WAIT等待时间,可以马上建立一个新的连接,但是前一个已经断开连接的,延迟到达的数据包。 被新建的连接接收,如果刚好seq 和 ack字段 都正确, seq在滑动窗口范围内(只能说机率非常小,但是还是有可能会发生),会被当成正确数据包接收,导致数据串包。 如果不在window范围内,则没有影响( 发送一个确认报文(ack 字段为期望ack的序列号,seq为当前发送序列号),状态变保持原样)
TIME_WAIT 问题比较比较常见,特别是CGI机器,并发量高,大量连接后段服务的tcp短连接。因此也衍生出了多种手段解决。虽然每种方法解决不是那么完美,但是带来的好处一般多于坏处。还是在日常工作中会使用。
1、改短TIME_WAIT 等待时间
这个是之一个想到的解决办法,既然等待时间太长,就改成时间短,快速回收端口。但是实际情况往往不乐观,对于并发的机器,你改多短才能保证回收速度呢,有时候几秒钟就几万个连接。太短的话,就会有前面两种问题小概率发生。
2、禁止Socket lingering
这种情况下关闭连接,会直接抛弃缓冲区中待发送的数据,会发送一个RST给对端,相当于直接抛弃TIME_WAIT, 进入CLOSE状态。同样因为取消了 TIME_WAIT 状态,会有前面两种问题小概率发生。
3、tcp_tw_reuse
net.ipv4.tcp_tw_reuse选项是 从 TIME_WAIT 状态的队列中,选取条件:1、remote 的 ip 和端口相同, 2、选取一个时间戳小于当前时间戳; 用来解决端口不足的尴尬。
现在端口可以复用了,看看如何面对前面TIME_WAIT 那两种问题。 我们仔细回顾用一下前面两种问题。
都是在新建连接中收到老连接的包导致的问题
, 那么如果我能在新连接中识别出此包为非法包,是不是就可以丢掉这些无用包,解决问题呢。
需要实现这些功能,需要扩展一下tcp 包头。 增加 时间戳字段。 发送者 在每次发送的时候。 在tcp包头里面带上发送时候的时间戳。 当接收者接收的时候,在ACK应答中除了TCP包头中带自己此时发送的时间戳,并且把收到的时间戳附加在后面。也就是说ACK包中有两个时间戳字段。结构如下:
那我们接下来一个个分析tcp_tw_reuse是如何解决TIME_WAIT的两个问题的
4、tcp_tw_recycle
tcp_tw_recycle 也是借助 timestamp机制。顾名思义, tcp_tw_reuse 是复用 端口,并不会减少 TIME-WAIT 数量。你去查询机器上TIME-WAIT 数量,还是 几千几万个,这点对有强迫症的同学感觉很不舒服。tcp_tw_recycle 是 提前 回收 TIME-WAIT资源。会减少 机器上 TIME-WAIT 数量。
linux 统计TCP连接时长的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于linux 统计TCP连接时长,「教程」如何在Linux上统计TCP连接时长,Linux – CentOS 7 – 查看TCP/IP连接状态,畅谈linux下TCP(上)的信息别忘了在本站进行查找喔。
成都网站建设选创新互联(☎:028-86922220),专业从事成都网站制作设计,高端小程序APP定制开发,成都网络营销推广等一站式服务。
当前文章:「教程」如何在Linux上统计TCP连接时长(linux统计TCP连接时长)
当前URL:http://www.csdahua.cn/qtweb/news23/447923.html
成都网站优化推广公司_创新互联,为您提供网站设计、标签优化、品牌网站建设、动态网站、做网站、电子商务
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网