Linux如何关闭80端口?

在Linux系统中,关闭80端口通常用于安全防护、服务迁移或端口冲突解决,80端口是HTTP服务的默认端口,可能被Apache、Nginx、Tomcat等Web服务占用,或被其他自定义程序监听,关闭端口需分步骤进行,包括确认占用情况、停止相关服务、配置防火墙规则等,以下是详细操作流程。

如何关闭linux 80端口

确认80端口占用情况

关闭端口前,需先明确80端口被哪个进程或服务占用,避免误操作影响正常业务,常用命令有netstatsslsof,具体如下:

使用netstat命令(传统工具)

netstat -tuln | grep 80
  • -t:显示TCP端口
  • -u:显示UDP端口
  • -l:仅显示监听端口
  • -n:以数字形式显示地址和端口,避免DNS解析
    若输出类似tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN,表示80端口被监听,需查看右侧PID/进程名(结合-p参数:netstat -tulnp | grep 80)。

使用ss命令(推荐,更高效)

ss -tuln | grep 80

ssnetstat的替代工具,在Linux新版本中默认安装,查询速度更快,参数与netstat基本一致。

使用lsof命令(显示详细进程信息)

lsof -i:80

该命令会列出占用80端口的进程ID(PID)、用户、命令等详细信息,
nginx 1234 root IPv4 0 0 0.0.0.0:80 0.0.0.0:* LISTEN,明确进程为nginx,PID为1234

停止占用80端口的服务

确认占用进程后,需根据服务类型停止服务,常见Web服务的停止命令如下:

如何关闭linux 80端口

停止Apache服务

# 停止当前运行的服务
systemctl stop httpd    # CentOS/RHEL系统
systemctl stop apache2   # Debian/Ubuntu系统
# 禁止服务开机自启(避免重启后自动监听80端口)
systemctl disable httpd
systemctl disable apache2

停止Nginx服务

systemctl stop nginx
systemctl disable nginx

停止Tomcat服务

Tomcat默认监听8080端口,若配置修改为80端口,需先定位Tomcat安装目录,关闭catalina.sh脚本:

# 假设Tomcat安装目录为/usr/local/tomcat
/usr/local/tomcat/bin/shutdown.sh

强制终止进程(若服务无法正常停止)

若服务停止命令无效,可通过PID强制终止进程(谨慎使用,可能导致数据丢失):

kill -9 <PID>  # kill -9 1234

配置防火墙规则关闭80端口

即使停止了服务,防火墙可能仍允许80端口入站连接,需进一步配置防火墙规则,不同Linux发行版使用的防火墙工具不同,需区分处理:

CentOS/RHEL(使用firewalld)

# 查看当前是否开放80端口
firewall-cmd --list-ports | grep 80
# 移除80端口规则(永久生效)
firewall-cmd --permanent --remove-port=80/tcp
# 重新加载防火墙使规则生效
firewall-cmd --reload

Debian/Ubuntu(使用ufw)

# 查看当前规则
ufw status | grep 80
# 拒绝80端口入站连接
ufw deny 80
# 重新加载防火墙
ufw reload

通用方法(iptables)

若系统使用iptables(如老旧版本或自定义配置):

如何关闭linux 80端口

# 删除允许80端口的规则(需匹配原有规则格式)
iptables -D INPUT -p tcp --dport 80 -j ACCEPT
# 保存规则(CentOS:service iptables save;Ubuntu:iptables-save > /etc/iptables/rules.v4)
service iptables save

验证80端口是否关闭

执行以下命令确认80端口已不再监听或被允许:

# 检查端口占用
netstat -tuln | grep 80
ss -tuln | grep 80
# 测试防火墙规则(从外部或本地访问80端口)
curl http://localhost:80  # 应返回“Connection refused”或超时

常用命令速查表

操作类别 命令(示例) 说明
查看端口占用 ss -tuln | grep 80 查询80端口监听状态
查看进程详情 lsof -i:80 显示占用80端口的进程信息
停止Apache systemctl stop httpd 停止Apache服务
停止Nginx systemctl stop nginx 停止Nginx服务
移除firewalld规则 firewall-cmd --permanent --remove-port=80/tcp 永久移除80端口规则
拒绝ufw规则 ufw deny 80 拒绝80端口入站连接

相关问答FAQs

Q1: 关闭80端口后,如何确认服务是否完全停止?
A1: 可通过以下方式综合确认:

  1. 使用systemctl status <服务名>(如systemctl status nginx)查看服务状态,应显示“inactive (dead)”;
  2. 执行ps aux | grep <服务名>(如ps aux | grep nginx),确认无相关进程运行;
  3. 通过netstat -tuln | grep 80再次检查,确保80端口无监听状态。

Q2: 为什么停止服务后,80端口仍显示被占用?
A2: 可能原因包括:

  1. 服务未完全停止:部分服务可能存在子进程或守护进程未退出,可尝试kill -9强制终止,或检查服务配置文件中的端口绑定是否彻底;
  2. 其他程序占用:可能有非Web服务(如Python、Java程序)监听80端口,需通过lsof -i:80确认并停止相关进程;
  3. 防火墙规则未更新:若防火墙仍允许80端口入站,需按本文第三部分重新配置防火墙规则,确保规则已生效(如执行firewall-cmd --reload)。

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/37072.html

(0)
酷番叔酷番叔
上一篇 2025年10月6日 16:16
下一篇 2025年10月6日 16:26

相关推荐

  • Linux上传文件最快方法是什么?

    远程服务器文件上传方法SCP(Secure Copy)适用场景:命令行操作、中小文件传输、需加密传输步骤: # 从本地上传文件到远程服务器 scp /本地/文件路径 用户名@服务器IP:/远程/目录/ # 示例:将本地的 report.pdf 上传到远程 /home/user/docs/ scp ~/repor……

    2025年8月6日
    8700
  • Linux中如何通过命令修改文件名?

    在Linux系统中,修改文件名是日常操作中常见的需求,无论是单个文件的重命名、批量文件名的格式调整,还是基于特定规则的文件名替换,都可以通过命令行工具高效完成,本文将详细介绍Linux环境下修改文件名的核心命令、使用方法及实用技巧,帮助用户灵活应对各种文件名管理场景,基础重命名命令:mvmv(move)是Lin……

    2025年9月24日
    6300
  • Linux系统如何在局域网内详细实现文件共享?方法有哪些?

    在Linux系统中,共享文件是常见的网络需求,无论是企业环境中的跨平台协作,还是家庭网络内的文件互通,都需要高效的共享方案,Linux提供了多种文件共享协议和服务,支持不同场景下的文件传输与访问需求,本文将详细介绍主流的Linux文件共享方法,包括Samba(与Windows共享)、NFS(Linux/Unix……

    2025年9月21日
    7400
  • Linux权限配置不当,服务器会被黑?

    理解Linux权限基础权限三元组r(读):查看文件/目录内容w(写):修改或删除x(执行):运行程序或进入目录通过 ls -l 查看权限(如 -rwxr–r– 表示所有者有读写执行,同组和其他用户仅有读权限),权限对象用户(User):文件所有者组(Group):共享权限的用户集合其他(Others):系统……

    2025年7月17日
    10300
  • 如何查看Linux机器CPU使用情况、实时占用率及进程详情?

    在Linux系统中,CPU作为核心硬件资源,其信息对于系统性能监控、应用优化、故障排查至关重要,掌握查看CPU信息的多种方法,能帮助管理员或开发者快速了解硬件配置、运行状态及性能瓶颈,本文将详细介绍Linux环境下查看CPU信息的常用命令及其使用技巧,使用lscpu命令友好显示CPU架构信息lscpu是Linu……

    2025年10月2日
    7900

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信