refactor: 端口改为内部映射,通过 Nginx 反向代理访问

- docker-compose.test.yml: API 和 MongoDB 端口改为 expose(仅容器内部可见)
- webhook-server.js: 端口改为 19001,绑定 127.0.0.1(仅本机访问)
- 新增 deploy/nginx-test.conf Nginx 反向代理配置
  - API: miniapp-api-test.dxz99wyr.cn → miniapp-api_test:3001
  - Webhook: miniapp-api-test-webhook.dxz99wyr.cn/webhook → 127.0.0.1:19001
- 更新 setup.sh 和 README.md 文档
This commit is contained in:
Developer
2026-05-18 20:51:54 +08:00
parent e73149f91d
commit 1117bd0bd7
5 changed files with 57 additions and 13 deletions
+23 -5
View File
@@ -52,7 +52,7 @@ chmod +x deploy/setup.sh
在 Git 仓库设置中添加 Webhook: 在 Git 仓库设置中添加 Webhook:
- **Payload URL**: `http://your-server-ip:9001/webhook` - **Payload URL**: `https://miniapp-api-test-webhook.dxz99wyr.cn/webhook`
- **Content type**: `application/json` - **Content type**: `application/json`
- **Secret**: 你设置的 `WEBHOOK_SECRET` - **Secret**: 你设置的 `WEBHOOK_SECRET`
- **触发事件**: Push events (main 分支) - **触发事件**: Push events (main 分支)
@@ -60,23 +60,41 @@ chmod +x deploy/setup.sh
### 5. 开放防火墙端口 ### 5. 开放防火墙端口
```bash ```bash
# 开放 9001 端口(webhook)和 3001 端口(API) # 仅需开放 80/443 端口,所有服务通过 Nginx 反向代理
ufw allow 9001/tcp ufw allow 80/tcp
ufw allow 3001/tcp ufw allow 443/tcp
``` ```
### 6. 配置 Nginx 反向代理 (推荐) ### 6. 配置 Nginx 反向代理 (推荐)
```nginx ```nginx
# 复制到服务器的 Nginx 配置目录
# cp deploy/nginx-test.conf /opt/ALiYunManager/nginx/conf.d/miniapp-api-test.conf
# docker exec main-nginx nginx -t && docker exec main-nginx nginx -s reload
server { server {
listen 80; listen 80;
server_name miniapp-api-test.dxz99wyr.cn; server_name miniapp-api-test.dxz99wyr.cn;
location / { location / {
proxy_pass http://localhost:3001; proxy_pass http://miniapp-api_test:3001;
proxy_set_header Host $host; proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
}
server {
listen 80;
server_name miniapp-api-test-webhook.dxz99wyr.cn;
location /webhook {
proxy_pass http://127.0.0.1:19001/webhook;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
} }
} }
``` ```
+25
View File
@@ -0,0 +1,25 @@
server {
listen 80;
server_name miniapp-api-test.dxz99wyr.cn;
location / {
proxy_pass http://miniapp-api_test:3001;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
}
server {
listen 80;
server_name miniapp-api-test-webhook.dxz99wyr.cn;
location /webhook {
proxy_pass http://127.0.0.1:19001/webhook;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
}
+1 -1
View File
@@ -44,7 +44,7 @@ echo "=========================================="
echo " 配置完成!" echo " 配置完成!"
echo "==========================================" echo "=========================================="
echo "" echo ""
echo "Webhook 接收地址: http://$(curl -s ifconfig.me):9001/webhook" echo "Webhook 接收地址: https://miniapp-api-test-webhook.dxz99wyr.cn/webhook"
echo "API 测试地址: https://miniapp-api-test.dxz99wyr.cn" echo "API 测试地址: https://miniapp-api-test.dxz99wyr.cn"
echo "" echo ""
echo "查看 webhook 日志: journalctl -u miniapp-api_test-webhook -f" echo "查看 webhook 日志: journalctl -u miniapp-api_test-webhook -f"
+4 -3
View File
@@ -3,7 +3,7 @@ const { exec } = require('child_process');
const path = require('path'); const path = require('path');
const crypto = require('crypto'); const crypto = require('crypto');
const PORT = 9001; const PORT = 19001;
const DEPLOY_DIR = '/opt/miniapp-api_test'; const DEPLOY_DIR = '/opt/miniapp-api_test';
const COMPOSE_FILE = 'docker-compose.test.yml'; const COMPOSE_FILE = 'docker-compose.test.yml';
@@ -98,8 +98,9 @@ const server = http.createServer(async (req, res) => {
}); });
}); });
server.listen(PORT, '0.0.0.0', () => { server.listen(PORT, '127.0.0.1', () => {
console.log(`Webhook 服务器已启动, 监听端口 ${PORT}`); console.log(`Webhook 服务器已启动, 监听端口 ${PORT}`);
console.log(`部署目录: ${DEPLOY_DIR}`); console.log(`部署目录: ${DEPLOY_DIR}`);
console.log(`接收地址: http://your-server-ip:${PORT}/webhook`); console.log(`接收地址: http://127.0.0.1:${PORT}/webhook`);
console.log(`Nginx 代理地址: http://your-server-ip/webhook`);
}); });
+4 -4
View File
@@ -5,8 +5,8 @@ services:
dockerfile: Dockerfile dockerfile: Dockerfile
container_name: miniapp-api_test container_name: miniapp-api_test
restart: unless-stopped restart: unless-stopped
ports: expose:
- "3001:3001" - "3001"
environment: environment:
- PORT=3001 - PORT=3001
- NODE_ENV=production - NODE_ENV=production
@@ -38,8 +38,8 @@ services:
image: mongo:7.0 image: mongo:7.0
container_name: miniapp-api_test-mongo container_name: miniapp-api_test-mongo
restart: unless-stopped restart: unless-stopped
ports: expose:
- "27019:27017" - "27017"
volumes: volumes:
- mongo_data_test:/data/db - mongo_data_test:/data/db
environment: environment: