在linux一般使用netstat 来查看系统端口使用情况步。
netstat命令是一个监控TCP/IP网络的非常有用的工具,它可以显示路由表、实际的网络连接以及每一个网络接口设备的 netstat命令的功能是显示网络连接、路由表和网络接口信息,可以让用户得知目前都有哪些网络连接正在运作。 该命令的一般格式为: netstat [选项] 命令中各选项的含义如下: -a 显示所有socket,包括正在监听的。 -c 每隔1秒就重新显示一遍,直到用户中断它。 -i 显示所有网络接口的信息,格式同“ifconfig -e”。 -n 以网络IP地址代替名称,显示出网络连接情形。 -r 显示核心路由表,格式同“route -e”。 -t 显示TCP协议的连接情况。 -u 显示UDP协议的连接情况。 -v 显示正在进行的工作。1. netstat -an | grep LISTEN 0.0.0.0的就是每个IP都有的服务,写明哪个IP的就是绑定那个IP的服务。2. netstat -tln 用来查看linux的端口使用情况3. /etc/init.d/vsftp start 是用来启动ftp端口~! 4. netstat 查看已经连接的服务端口(ESTABLISHED)5. netstat -a 查看所有的服务端口(LISTEN,ESTABLISHED)6. netstat -ap 查看所有的服务端口并显示对应的服务程序名 例如:netstat -nltp
7、通过lsof命令查看端口
执行 lsof-i:20880
命令可以查看端口的相关使用情况:来自:https://mp.weixin.qq.com/s/cwqAMPku-LwXAGM3Cqztig
-
*:20880(LISTEN)
说明了 Dubbo 正在监听本地的 20880 端口,处理发送到本地 20880 端口的请求 -
后两条信息说明请求的发送情况,验证了 TCP 是一个双向的通信过程,由于我是在同一个机器开启了两个 Dubbo 应用,所以你能够看到是本地的 53078 端口与 20880 端口在通信。我们并没有手动设置 53078 这个客户端端口,他是随机的,但也阐释了一个道理:即使是发送请求的一方,也需要占用一个端口。
-
稍微说一下 FD 这个参数,他代表了文件句柄,每新增一条连接都会占用新的文件句柄,如果你在使用 TCP 通信的过程中出现了
open too many files
的异常,那就应该检查一下,你是不是创建了太多的连接,而没有关闭。细心的读者也会联想到长连接的另一个好处,那就是会占用较少的文件句柄。