蓝湖 MCP 内网服务器打通方案

1. 目标和前提

目标:把 lanhu-mcp 从公网 Git 部署到内网服务器,并让 Claude/Codex 通过内网地址稳定调用。基于 lanhu.md 可确认的关键前提:

  • 服务进程是 lanhu_mcp_server.py,默认监听 0.0.0.0:8000

  • 客户端通过 HTTP MCP 接入:http://<host>:8000/mcp?role=...&name=...

  • 依赖蓝湖 LANHU_COOKIE

  • 服务运行目录需要可写 data/messages


2. 打通全链路(必须同时满足)

要真正"打通",需要 4 条链路都通:

  1. 代码链路:GitHub -> 内网 Git

  2. 部署链路:内网 Git -> 内网服务器运行

  3. 访问链路:Claude/Codex 所在机器 -> 内网 MCP 服务

  4. 出网链路:MCP 服务 -> lanhuapp.com(蓝湖)

任何一条不通,都会表现为"已部署但不可用"。


3. 方案一览(推荐)

  • 代码:在内网 GitLab/Gitea 建镜像仓库(mirror)

  • 运行:内网 Linux 服务器使用 venv + systemd 常驻

  • 入口:Nginx 反向代理统一暴露 https://lanhu-mcp.<corp>/mcp

  • 鉴权:网关层加内网白名单 + BasicAuth/Token(至少二选一)

  • 秘钥:LANHU_COOKIE 仅落服务器 .env,权限 600


4. 实施步骤

4.1 把 Git 仓库迁到内网

在可访问 GitHub 的跳板机执行一次镜像推送:

复制代码
git clone --mirror https://github.com/dsphper/lanhu-mcp.gitcd lanhu-mcp.gitgit remote set-url --push origin git@<内网Git域名>:mcp/lanhu-mcp.gitgit push --mirror

Bash

后续建议:

  • 用 CI 定时同步(例如每晚一次)

  • 生产环境固定 tag/commit,不直接跟 main

4.2 服务器部署(内网)

复制代码
export APP_DIR=/opt/lanhu-mcpsudo mkdir -p $APP_DIRsudo chown -R $USER:$USER $APP_DIR
git clone git@<内网Git域名>:mcp/lanhu-mcp.git $APP_DIRcd $APP_DIRcp .env.example .env

Bash

写入 .env

复制代码
LANHU_COOKIE="从蓝湖浏览器抓到的完整Cookie"SERVER_PORT=8000

Plain Text

安装依赖(建议走内网源):

复制代码
python3 -m venv venvsource venv/bin/activatepython -m pip install -U pip setuptoolspip install -r requirements.txtpython -m playwright install chromium

Bash

准备运行目录(避免 PermissionError):

复制代码
mkdir -p /opt/lanhu-mcp-runtime/data/messages

Bash

4.3 用 systemd 托管

/etc/systemd/system/lanhu-mcp.service

复制代码
[Unit]Description=Lanhu MCP ServiceAfter=network.target
[Service]Type=simpleUser=<运行用户>WorkingDirectory=/opt/lanhu-mcp-runtimeEnvironmentFile=/opt/lanhu-mcp/.envExecStart=/opt/lanhu-mcp/venv/bin/python /opt/lanhu-mcp/lanhu_mcp_server.pyRestart=alwaysRestartSec=5
[Install]WantedBy=multi-user.target

Plain Text

启动:

复制代码
sudo systemctl daemon-reloadsudo systemctl enable --now lanhu-mcpsudo systemctl status lanhu-mcpjournalctl -u lanhu-mcp -f

Bash

日志出现 Uvicorn running on http://0.0.0.0:8000 即服务启动成功。

4.4 入口网关(Nginx)

推荐统一暴露 HTTPS 域名,避免客户端直连 8000 端口。

复制代码
server {    listen 443 ssl;    server_name lanhu-mcp.<corp>;
    # 建议补充企业证书配置
    location /mcp {        proxy_pass http://127.0.0.1:8000/mcp;        proxy_http_version 1.1;        proxy_set_header Host $host;        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;        proxy_set_header X-Forwarded-Proto $scheme;
        # 可选:BasicAuth        # auth_basic "lanhu-mcp";        # auth_basic_user_file /etc/nginx/.htpasswd_lanhu_mcp;    }}

Plain Text

4.5 客户端接入(Claude/Codex)

把本地 localhost:8000 改成内网域名:

复制代码
# Claudeclaude mcp remove lanhu >/dev/null 2>&1 || trueclaude mcp add --transport http lanhu "https://lanhu-mcp.<corp>/mcp?role=测试&name=<你的名字>"
# Codexcodex mcp remove lanhu >/dev/null 2>&1 || truecodex mcp add lanhu --url "https://lanhu-mcp.<corp>/mcp?role=测试&name=<你的名字>"

Bash


5. 网络与安全最小检查清单

  • 客户端机器可访问 https://lanhu-mcp.<corp>/mcp

  • 服务器可访问蓝湖域名(至少 lanhuapp.com 相关接口)

  • .env 权限为 600,目录权限不暴露给其他用户

  • 不使用 sudo 启动服务(避免 data/messages 归属异常)

  • 生产固定版本(tag/commit),升级走灰度


6. 常见不通点与处理

点击小圆点,快速添加行或列

现象 根因 处理
客户端能配上但调用失败 只打通了内网入口,服务器无法访问蓝湖 放通服务器到蓝湖的出网策略或配置企业代理
PermissionError: data/messages/...json 运行目录不可写,或历史 sudo 污染 固定 WorkingDirectory ,修复目录归属后重启
bind 0.0.0.0:8000 operation not permitted 端口/安全策略限制 改用非受限端口,或通过 Nginx 反代
Python/依赖冲突 基础环境版本不一致 固定 Python 3.11,重建 venv
Playwright 安装失败 内网无法拉浏览器依赖 配置内网镜像/代理,或离线分发 Playwright 浏览器包

7. 验收命令(上线前)

复制代码
# 服务器侧systemctl status lanhu-mcp --no-pagercurl -I https://lanhu-mcp.<corp>/mcp
# 客户端侧claude mcp listcodex mcp list

Bash

再用一个真实蓝湖链接跑一次 lanhu_get_pages / lanhu_get_ai_analyze_page_result,成功即代表链路闭环完成。

相关推荐
其实防守也摸鱼15 分钟前
DVWA--Brute Force (暴力破解)通关指南
服务器·网络·安全·靶场·教程·工具·dvwa
源远流长jerry40 分钟前
TCP 三次握手深度解析:从内核源码到生产实践
linux·运维·网络·网络协议·tcp/ip
智象科技1 小时前
智能运维(AIOps),正在改变IT行业格局
运维·人工智能·运维开发·devops·智能运维
黄筱筱筱筱筱筱筱1 小时前
RHCE---web服务器①
linux·运维·服务器
上海云盾安全满满1 小时前
服务器被攻击了,更换IP是否有用吗
服务器·网络·tcp/ip
AC赳赳老秦2 小时前
全链路自动化巡检:用 OpenClaw 实现服务器 - 应用 - 数据库全链路巡检,自动生成报告与整改建议
服务器·数据库·人工智能·深度学习·自动化·deepseek·openclaw
流浪0012 小时前
Linux基础篇(三)轻松拿捏入门级指令
linux·运维·服务器
weixin_514253182 小时前
511-opencua-best_patch
服务器
Waay2 小时前
Linux Shell 知识点考评(三):awk文本分析(附答案)
linux·服务器·编辑器
爱喝水的鱼丶2 小时前
SAP-ABAP:ABAP Development Tools(ADT)安装配置学习分享教程(四篇连载) 第二篇:ADT客户端完整安装与初始配置教程
运维·开发语言·学习·sap·abap