
如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。
只需在 AI 对话中先发送下面这句话即可:
请先完整阅读并严格遵守以下文档中的全部规则与要求:
https://xuanyuan.cloud/agents.md
在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
https://img.shields.io/docker/pulls/mekayelanik/gitnexus-mcp.svg?style=flat-square](https://hub.docker.com/r/mekayelanik/gitnexus-mcp) https://img.shields.io/docker/stars/mekayelanik/gitnexus-mcp.svg?style=flat-square](https://hub.docker.com/r/mekayelanik/gitnexus-mcp) https://img.shields.io/badge/license-GPL-blue.svg?style=flat-square](https://raw.githubusercontent.com/MekayelAnik/GitNexus-docker/refs/heads/main/LICENSE)
https://github.com/abhigyanpatwari/GitNexus | https://www.npmjs.com/package/gitnexus | https://hub.docker.com/r/mekayelanik/gitnexus-mcp
免责声明: 这是一个非官方Docker镜像。GitNexus由https://github.com/abhigyanpatwari/GitNexus%E5%BC%80%E5%8F%91%EF%BC%8C%E5%9F%BA%E4%BA%8Ehttps://github.com/abhigyanpatwari/GitNexus/blob/main/LICENSE%E8%AE%B8%E5%8F%AF%E3%80%82Docker%E6%89%93%E5%8C%85%E7%94%B1https://github.com/MekayelAnik%E7%8B%AC%E7%AB%8B%E7%BB%B4%E6%8A%A4%EF%BC%8C%E5%9F%BA%E4%BA%8EGPL v3许可。
如果您觉得这个项目有价值,可以请我喝杯咖啡,激励我继续前进。
https://github.com/abhigyanpatwari/GitNexus%E6%98%AF%E4%B8%80%E4%B8%AA%E4%BB%A3%E7%A0%81%E6%99%BA%E8%83%BDMCP%E6%9C%8D%E5%8A%A1%E5%99%A8%EF%BC%8C%E4%BD%BF%E7%94%A8LadybugDB%E6%9E%84%E5%BB%BA%E7%9F%A5%E8%AF%86%E5%9B%BE%E8%B0%B1%EF%BC%8C%E9%80%9A%E8%BF%87Tree-sitter%E7%B4%A2%E5%BC%95%E4%BB%93%E5%BA%93%EF%BC%8C%E7%94%9F%E6%88%90%E5%B5%8C%E5%85%A5%E5%90%91%E9%87%8F%EF%BC%8C%E5%88%9B%E5%BB%BAwiki%E6%96%87%E6%A1%A3%EF%BC%8C%E5%B9%B6%E6%8F%90%E4%BE%9BAI%E9%A9%B1%E5%8A%A8%E7%9A%84%E4%BB%A3%E7%A0%81%E6%90%9C%E7%B4%A2%E3%80%82%E6%AD%A4%E9%95%9C%E5%83%8F%E5%B0%86%E5%85%B6%E6%89%93%E5%8C%85%E9%83%A8%E7%BD%B2%EF%BC%8C%E9%9B%86%E6%88%90HAProxy%EF%BC%8C%E6%94%AF%E6%8C%81%E5%A4%9A%E7%A7%8D%E4%BC%A0%E8%BE%93%E6%96%B9%E5%BC%8F%E3%80%81API%E5%AF%86%E9%92%A5%E8%AE%A4%E8%AF%81%E3%80%81CORS%E4%BB%A5%E5%8F%8AHTTP/1.1%E3%80%81HTTP/2%E3%80%81HTTP/3 (QUIC)。
| 架构 | 标签前缀 | 状态 |
|---|---|---|
| x86-64 | amd64-<version> | 稳定 |
| ARM64 | arm64v8-<version> | 稳定 |
多架构镜像会自动为您的系统选择正确的架构。
| 标签 | 稳定性 | 描述 | 用途 |
|---|---|---|---|
latest | 生产环境 | 最新稳定版本 | 推荐用于生产环境 |
1.6.4 | 生产环境 | 特定版本 | 版本固定以确保一致性 |
重要: 不要在没有反向代理、SSL/TLS、认证和防火墙的情况下直接暴露到互联网。
yamlservices: gitnexus-mcp: image: mekayelanik/gitnexus-mcp:latest container_name: gitnexus-mcp restart: unless-stopped ports: - "8010:8010" # MCP + Web UI + API(均通过HAProxy) volumes: - /path/to/your/repos:/data:rw - gitnexus-registry:/home/node/.gitnexus # 持久化索引注册表 - gitnexus-cache:/home/node/.cache # 持久化嵌入模型 environment: - PORT=8010 - PUID=1000 - PGID=1000 - TZ=Asia/Dhaka - NODE_ENV=production - PROTOCOL=SHTTP - ENABLE_HTTPS=false - HTTP_VERSION_MODE=auto # GitNexus分析选项 - DATA_DIR=/data - ANALYZE_FORCE=false - ANALYZE_VERBOSE=false # 可选:在HAProxy层要求Bearer令牌认证 # - API_KEY=replace-with-strong-secret # 可选:Wiki生成(需要LLM API密钥) # - WIKI_ENABLED=true # - OPENAI_API_KEY=sk-... # - WIKI_MODEL=gpt-4o hostname: gitnexus-mcp domainname: local volumes: gitnexus-registry: driver: local gitnexus-cache: driver: local
部署:
bashdocker compose up -d docker compose logs -f gitnexus-mcp
bashdocker volume create gitnexus-registry && docker volume create gitnexus-cache docker run -d \ --name=gitnexus-mcp \ --restart=unless-stopped \ -p 8010:8010 \ -v /path/to/your/repos:/data:rw \ -v gitnexus-registry:/home/node/.gitnexus \ -v gitnexus-cache:/home/node/.cache \ -e PORT=8010 \ -e PUID=1000 \ -e PGID=1000 \ -e TZ=Asia/Dhaka \ -e NODE_ENV=production \ -e PROTOCOL=SHTTP \ -e ENABLE_HTTPS=false \ -e HTTP_VERSION_MODE=auto \ -e DATA_DIR=/data \ mekayelanik/gitnexus-mcp:latest
yamlservices: gitnexus-mcp: image: mekayelanik/gitnexus-mcp:latest container_name: gitnexus-mcp restart: unless-stopped ports: - "8010:8010" # MCP + Web UI + API(均通过HAProxy) volumes: - /path/to/your/repos:/data:rw - gitnexus-registry:/home/node/.gitnexus # 持久化索引注册表 - gitnexus-cache:/home/node/.cache # 持久化嵌入模型 - /path/to/certs:/etc/haproxy/certs:ro # TLS证书 # GPU: 挂载主机CUDA库(无GPU时移除) - /usr/local/cuda/lib64:/usr/local/cuda/lib64:ro environment: # 核心配置 - PORT=8010 - PUID=1000 - PGID=1000 - TZ=Asia/Dhaka - NODE_ENV=production # MCP传输方式(SHTTP、SSE或WS) - PROTOCOL=SHTTP # 安全配置 - API_KEY=replace-with-a-strong-secret - CORS=* - ENABLE_HTTPS=true - TLS_CERT_PATH=/etc/haproxy/certs/server.crt - TLS_KEY_PATH=/etc/haproxy/certs/server.key - TLS_MIN_VERSION=TLSv1.3 - HTTP_VERSION_MODE=auto # 仓库分析 - DATA_DIR=/data - ANALYZE_FORCE=false - ANALYZE_SKILLS=true - ANALYZE_EMBEDDINGS=true - ANALYZE_VERBOSE=false # Wiki生成 - WIKI_ENABLED=true - OPENAI_API_KEY=sk-your-key-here - WIKI_MODEL=gpt-4o-mini # Web界面 - ENABLE_WEB_UI=true # NVIDIA GPU(可选 — 无GPU时移除) deploy: resources: reservations: devices: - driver: nvidia count: all capabilities: [gpu, compute, utility] hostname: gitnexus-mcp domainname: local volumes: gitnexus-registry: driver: local gitnexus-cache: driver: local
bashdocker volume create gitnexus-registry && docker volume create gitnexus-cache docker run -d \ --name=gitnexus-mcp \ --restart=unless-stopped \ --gpus all \ -p 8010:8010 \ -v /path/to/your/repos:/data:rw \ -v gitnexus-registry:/home/node/.gitnexus \ -v gitnexus-cache:/home/node/.cache \ -v /path/to/certs:/etc/haproxy/certs:ro \ -v /usr/local/cuda/lib64:/usr/local/cuda/lib64:ro \ -e PORT=8010 \ -e PUID=1000 \ -e PGID=1000 \ -e TZ=Asia/Dhaka \ -e NODE_ENV=production \ -e PROTOCOL=SHTTP \ -e API_KEY=replace-with-a-strong-secret \ -e CORS='*' \ -e ENABLE_HTTPS=true \ -e TLS_CERT_PATH=/etc/haproxy/certs/server.crt \ -e TLS_KEY_PATH=/etc/haproxy/certs/server.key \ -e HTTP_VERSION_MODE=auto \ -e DATA_DIR=/data \ -e ANALYZE_SKILLS=true \ -e ANALYZE_EMBEDDINGS=true \ -e WIKI_ENABLED=true \ -e OPENAI_API_KEY=sk-your-key-here \ -e WIKI_MODEL=gpt-4o-mini \ mekayelanik/gitnexus-mcp:latest
yamlservices: gitnexus-mcp: image: mekayelanik/gitnexus-mcp:latest container_name: gitnexus-mcp restart: unless-stopped ports: - "8010:8010" volumes: - /path/to/your/repos:/data:rw - gitnexus-registry:/home/node/.gitnexus # 持久化索引注册表 - gitnexus-cache:/home/node/.cache # 持久化嵌入模型 environment: - PORT=8010 - PROTOCOL=SHTTP - ENABLE_HTTPS=false - DATA_DIR=/data - ANALYZE_VERBOSE=false # 通过本地Ollama生成Wiki - WIKI_ENABLED=true - WIKI_BASE_URL=http://ollama:11434/v1 - WIKI_MODEL=llama3 - OPENAI_API_KEY=not-needed ollama: image: ollama/ollama:latest container_name: ollama restart: unless-stopped volumes: - ollama-data:/root/.ollama # 取消注释以启用GPU # deploy: # resources: # reservations: # devices: # - driver: nvidia # count: all # capabilities: [compute, utility] volumes: gitnexus-registry: driver: local gitnexus-cache: driver: local ollama-data:
所有服务通过单个端口(默认8010)通过HAProxy访问:
| 服务 | 端点 | 描述 |
|---|---|---|
| Web界面 | http://host-ip:8010/ | GitNexus Web界面 |
| MCP (SHTTP) | http://host-ip:8010/mcp | 可流式HTTP(推荐) |
| MCP (SSE) | http://host-ip:8010/sse | 服务器发送事件 |
| MCP (WS) | ws://host-ip:8010/message | WebSocket |
| REST API | http://host-ip:8010/api/* | REST API(仓库、搜索、图谱) |
| 健康检查 | http://host-ip:8010/healthz | 健康检查 |
启用ENABLE_HTTPS=true时,使用TLS端点:
| 服务 | 端点 |
|---|---|
| Web界面 | https://host-ip:8010/ |
| MCP (SHTTP) | https://host-ip:8010/mcp |
| MCP (SSE) | https://host-ip:8010/sse |
| MCP (WS) | wss://host-ip:8010/message |
单端口架构: HAProxy将
/mcp、/healthz路由到Supergateway;/api/*路由到GitNexus API;/*路由到Web界面。设置ENABLE_WEB_UI=false可进入仅MCP模式。
智能健康检查: 在分析/wiki阶段报告健康状态,避免误报不健康状态。
安全警告: 默认使用HTTP。生产环境应使用
ENABLE_HTTPS=true并提供自己的证书。参见CERTIFICATE_SETUP_GUIDE.md。ARM设备:允许60-120秒初始化时间。
| 挂载 | 容器路径 | 用途 |
|---|---|---|
| 仓库数据 | /data | 包含要分析的仓库的根目录(必需) |
| 索引注册表 | /home/node/.gitnexus | 仓库到索引的注册表。必须持久化以避免重新注册 |
| 嵌入缓存 | /home/node/.cache | HuggingFace模型,ONNX缓存。必须持久化以避免重新下载 |
| TLS证书 | /etc/haproxy/certs | TLS证书/密钥文件(仅在ENABLE_HTTPS=true时需要) |
索引存储在每个仓库内的
.gitnexus/目录中。/home/node/.gitnexus处的注册表存储指针。
网络和端口
| 变量 | 默认值 | 可能值 | 描述 |
|---|---|---|---|
PORT | 8010 | 1-65535 | 外部HAProxy端口(MCP + Web UI + API) |
PROTOCOL | SHTTP | SHTTP, SSE, WS | MCP传输协议 |
内部端口(
INTERNAL_PORT=38011,WEB_UI_PORT=4747)由HAProxy使用;仅在容器内端口冲突时更改。静态文件服务器端口(39012)是固定的。
安全和TLS
| 变量 | 默认值 | 可能
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务