BLOG

端口 网关 域名

2026/04/24 2 min read BLOG 编程学习之路 端口 网关 域名

这三个其实是一条链上的不同层级:端口(进程入口)→ 网关(流量调度)→ 域名(人类入口)。你现在做部署、AI 网关、池子分发,正好都用得到。我给你讲清楚“各自是什么 + 怎么连起来 + 常见坑”。


🧠 一句话总览

用户输入域名 → DNS解析 → 命中服务器IP
→ 网关(反向代理)接收请求
→ 按规则转发到某个端口(你的服务)
→ 服务处理并返回

🧱 一、端口(Port)——“程序的入口门牌号”

是什么

每个在运行的服务(进程)对外提供能力,都要监听一个端口

IP + 端口 = 一个具体服务

例子:

127.0.0.1:3001  → 你的 Next.js
127.0.0.1:5101  → 你的 Node 后端

你刚刚遇到的典型问题

EADDRINUSE :3000

👉 含义:

3000 已被其他程序占用(你那次是 Docker 里的 aiclient2api)

常用命令

lsof -i :3000     # 谁占用了端口
ss -lntp          # 当前监听端口

核心理解

端口是“服务的物理入口”
但用户不会直接记端口(太难用)

🌐 二、域名(Domain)——“人类可读入口”

是什么

example.com → IP地址

通过 DNS 系统解析。


过程

浏览器访问 example.com
→ DNS服务器返回 1.2.3.4
→ 浏览器请求 1.2.3.4:80 或 443

默认端口

http  → 80
https → 443

所以:

https://example.com
= https://example.com:443

为什么不用端口

http://example.com:3001

虽然可以,但:

❌ 不专业
❌ 不安全
❌ 不好记

🚦 三、网关(Gateway / 反向代理)——“调度中心”

是什么

网关的作用:

接收请求 → 决定转发给哪个服务

常见实现

  • Nginx

  • Traefik

  • 自己写的 AI Gateway(你现在在做的)


例子(非常关键)

你服务器有两个服务:

3001 → console-web(前端)
5101 → atramenti-console(后端)

网关可以这样配置:

example.com         → 3001
api.example.com     → 5101

工作方式

用户访问 https://example.com
→ 网关(80/443)
→ 转发到 localhost:3001

这叫

反向代理(Reverse Proxy)

🔗 四、三者怎么连起来(你现在的真实结构)

你现在的系统其实应该长这样:

用户

域名(example.com)

DNS解析

服务器IP

网关(Nginx / Gateway)

转发规则
 ├─ /        → 3001(Next.js)
 └─ /api     → 5101(Node服务)

🧠 五、和你当前项目的对应关系

你现在实际状态:

✔ 端口:3001 / 5101(已解决冲突)
✔ 服务:systemd 托管(已完成)
❌ 域名:还没接
❌ 网关:还没正式配置

👉 所以你现在:

能本地访问 ✔
还不能用域名访问 ❌

🔥 六、你接下来必然要做的两步


🥇 1. 配域名(DNS)

example.com → 你的服务器IP

🥈 2. 上网关(Nginx)

示例:

server {
    listen 80;
    server_name example.com;
 
    location / {
        proxy_pass http://127.0.0.1:3001;
    }
 
    location /api {
        proxy_pass http://127.0.0.1:5101;
    }
}

👉 完成后:

用户 → 域名 → 网关 → 端口 → 服务

⚠️ 七、常见坑(你后面一定会踩)


❗1. 端口冲突

两个服务抢 3000

👉 你已经踩过 ✔


❗2. 网关没转发

域名访问 502

👉 实际服务没启动 or 端口错


❗3. DNS 没生效

域名 ping 不通

👉 需要时间传播(几分钟到几小时)


❗4. 防火墙

端口开了但访问不到

👉 云服务器安全组没放行


🧠 八、最重要理解(核心一句)

端口 = 服务入口
网关 = 流量调度
域名 = 用户入口

🚀 如果你要更进一步(建议)

我可以帮你直接给一套:

✔ 域名 + Nginx + HTTPS(证书)
✔ 你的 3001 / 5101 全接进去
✔ 一步到公网访问

你只要说:

我要上线公网

我直接带你把你这套系统变成:

别人可以访问的真实网站