使用netstat命名排查网络问题的参考指引

2018-07-10 09:40 收藏:未收藏 设置分组 权限:公开 阅读(451) 赞(0) 踩(0) [空白] DTIO

1、查看 TIME_WAIT 情况
TIME_WAIT 是一种连接超时,之前遇到一个坑,有一台服务器莫名其妙的应用不能访问了,当时团队经验不足,各种排查都搞不定。最后被迫重启服务器修正。后来遇到类似的问题,发现有TIME_WAIT过多的情况,怀疑上次遇到的问题就是TIME_WAIT过多,占用资源导致。

用netstat命名查看time_wait个数:

- [新窗口查看]

netstat -ano   | find "TIME_WAIT" /C

netstat查看time_wait情况

netstat查看time_wait情况 90 180 270 


如上图所示,可以看到有2个time_wait超时,然后用命令

- [新窗口查看]

netstat -ano   | find "TIME_WAIT"

可以看到:
10.23.10.102:1521
10.23.10.101:5500
这两个超时。
根据服务器的应用分析,一个是数据库访问的超时,一个是数据接收程序(端口5500)的超时。

2、利用netstat查看远程登录服务器的情况和ip
如下指令:

- [新窗口查看]

netstat -ano   | find "3389"

应用netstat_find_3389查看远程登录的情况

应用netstat_find_3389查看远程登录的情况 90 180 270 

可以看到是:
10.28.146.122的IP远程访问的服务器

3、利用netstat查看应用软件使用的端口
如下指令:
假定我想知道VTS.exe(服务器上一个定时socket接收数据的程序)占用了哪个端口。
步骤:
(1)用tasklist查看该程序及进程ID
(2)用netstat查看该进程ID对应的端口
如:netstat -ano | find "318904" 
(备注:318904是tasklist查看到的vts.exe对应的进程Id)

如下图:

查看到vts对应的进程ID是318904

查看到vts对应的进程ID是318904 90 180 270 


用netstat的find命名查看到占用的端口是5500

用netstat的find命名查看到占用的端口是5500 90 180 270 


 





关联阅读

---- 本项目(经验交流) ----

上一条:编写一个BAT脚本协助运维人员遇到问题时候调测数据库是否有效连接成功的操作攻略

下一条:设置邮箱发送服务|邮箱开始SMTP服务和腾讯云解封25端口的经验总结

---- 全站 ----

上一条:Oracle|shared_pool_size

下一条:Druid介绍及配置说明(在线PPT文档)


导航当前分类项目权限