找到占用80的端口应用并关闭掉

宿主机上 0.0.0.0:80 这个端口已经被别的进程/容器占用了,所以 Docker 里的 aivirtualcourt-nginx-1 没法把容器的 80 端口映射到宿主机 80。

报错关键句:

• failed to bind port 0.0.0.0:80/tcp

• bind: address already in use

也就是:端口 80 已经在用。

你现在输出里有哪些"误导点"

你执行了:

ps -ef | grep 80

这并不能找到"谁占用了 80 端口",它只是找到了 进程命令行里包含字符串 80 的进程。所以你看到的 root 80 [kintegrityd] 只是 PID=80,不是端口 80。

另外你 kill -9 2024 是在杀 PID=2024,但 ps 输出里 2024 出现在 2024 ? 这一列是"年份/启动时间",不是 PID,所以当然会提示 No such process。

正确的排查方式(立刻能定位谁占了 80)

在宿主机上执行以下任意一个(推荐第一个):

  1. 最推荐:ss

ss -ltnp | grep ':80 '

  1. 或者 lsof

lsof -iTCP:80 -sTCP:LISTEN -Pn

  1. 或者 netstat(若有)

netstat -lntp | grep ':80 '

你会看到类似:

• LISTEN 0 4096 0.0.0.0:80 ... users:(("nginx",pid=xxxx,fd=...))

• docker-proxy pid=xxxx

• apache2 / caddy / traefik / openresty

或某个容器在占用

最可能的占用者(结合你当前 docker ps)

你机器上长期运行了一个 n8n 容器(映射 5678),它本身不占 80。

但常见情况是:

  1. 宿主机 nginx/apache 已经在跑(你也 which nginx 看到了系统装了 nginx)

  2. 或者 之前有另一个容器已经映射了 80(比如老的 nginx/traefik/caddy)

  3. 或者云厂商安全组件/面板服务占了 80(阿里云环境里也常见)

解决办法(两条路,选其一)

A. 让 Docker 的 nginx 不用宿主机 80(最省事,推荐)

在 docker-compose.yml 里把 nginx 的端口从 80:80 改成别的,比如:

ports:

  • "8080:80"

然后:

docker compose up -d

以后访问就是 http://<你的服务器IP>:8080

如果你还需要 HTTPS,也可以映射 8443:443。

B. 释放宿主机的 80 端口(如果你必须用 80)

先用上面 ss/lsof 找到占用者。

常见占用者对应处理:

  1. 是宿主机 nginx

systemctl status nginx

systemctl stop nginx

systemctl disable nginx # 如果你不想它开机自启

  1. 是某个容器占了 80

docker ps --format 'table {{.Names}}\t{{.Ports}}' | grep ':80->'

找到后:

docker stop <container_name>

  1. 是 apache

systemctl stop apache2

你现在可以直接照抄做的最短路径

  1. 先定位占用者:

ss -ltnp | grep ':80 '

复制代码
2.	如果你不执着必须 80:直接改 compose 映射到 8080(最快)。
3.	如果必须 80:按 ss 输出找到进程/容器,停掉它,再 docker compose up -d。
相关推荐
AI攻城狮14 小时前
OpenFang 给我的一个提醒:AI Agent 真正难的不是自主,而是治理
人工智能·云原生·aigc
Java陈序员17 小时前
轻量强大!一款现代化的 Kubernetes 集群管理与监控工具!
云原生·容器·kubernetes
AI攻城狮3 天前
OpenClaw 里 TAVILY_API_KEY 明明写在 ~/.bashrc,为什么还是失效?一次完整排查与修复
人工智能·云原生·aigc
阿里云云原生3 天前
零配置部署顶级模型!函数计算一键解锁 Qwen3.5
云原生
AI攻城狮4 天前
Kimi Bot + OpenClaw 完整配置指南:5 步实现本地 AI Agent 集成
人工智能·云原生·aigc
AI攻城狮4 天前
RAG Chunking 为什么这么难?5 大挑战 + 最佳实践指南
人工智能·云原生·aigc
哈里谢顿6 天前
Kubernetes Operator核心概念、实现原理和实战开发
云原生
阿里云云原生6 天前
你的 OpenClaw 真的在受控运行吗?
云原生
阿里云云原生6 天前
5 分钟零代码改造,让 Go 应用自动获得全链路可观测能力
云原生·go
Shanyoufusu126 天前
RKE2 单节点集群安装 Rancher+ 私有镜像仓库搭建 完整教程
云原生