如何故意占用linux系统某个端口

如何故意占用linux系统某个端口,第1张

linux系统下,查看端口占用情况的命令:lsof -i

1 [root@www ~]# lsof -i

2

3 COMMAND PID USER FD TYPE DEVICE SIZE NODE NAME

4 nginx 2333 root 6u IPv4 6242 TCP *:http (LISTEN)

5 nginx 2334 www 6u IPv4 6242 TCP *:http (LISTEN)

6 sshd 2349 root 3u IPv6 6283 TCP *:ndmp (LISTEN)

7 sshd 2349 root 4u IPv6 6286 TCP *:ssh (LISTEN)

这里返回了Linux当前所有打开端口的占用情况。第一段是进程,最后一列是侦听的协议、侦听的IP与端口号、状态。如果端口号是已知的常用服务(如80、21等),则会直接显示协议名称,如http、ftp、ssh等。

查看某一端口的占用情况: lsof -i:端口号

1 [root@www ~]# lsof -i:21

2

3 COMMAND PID USER FD TYPE DEVICE SIZE NODE NAME

4 pure-ftpd 2651 root 4u IPv4 7047 TCP *:ftp (LISTEN)

5 pure-ftpd 2651 root 5u IPv6 7048 TCP *:ftp (LISTEN)

这里显示出21号端口正在被pure-ftpd使用,状态是listen。

结束占用端口的进程:killall 进程名

虽然我们不建议用这种本末倒置的方法来解决冲突问题,但某些情况下还是可以直接结束掉占用进程的(比如重启Apache时进程没有完全退出,导致重启失败)

1 [root@www ~]# killall pure-ftpd

这样,所有的pure-ftpd进程都会被结束掉。

在Linux系统中22号端口是ssh服务使用的端口,如果想看看22号ssh端口上是哪种ssh应用,可以在终端输入命令:netstat -tlnp

这个命令表示列出系统里面监听网络的TCP连接和相应的进程PID。

参数说明:

-t:表示列出TCP连接

-l:表示列出正在网络监听的服务

-n:表示以端口号来显示

-p:表示列出进程PID

然后看看Local Address这一列下面,端口号是22的那一行,再看它的Program name那一列,就是ssh应用的名称。

80被占用一般是在调整Apache服务时,前一个进程没有被杀死会报这个错,或者之前跑着80端口的服务,最好问清楚80端口跑的哪个服务如果是进程没有杀掉重新杀一次即可,如果跑着其他服务则改个端口就行了。关注更多Linux技术《Linux就该这么学》网上免费版可以去看看


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/yw/7321072.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-04
下一篇2023-04-04

发表评论

登录后才能评论

评论列表(0条)

    保存