
如果你使用 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 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
Webhook Gateway 是一个轻量级、高性能的webhook请求处理中间件,旨在简化跨服务间的webhook集成流程。该镜像提供统一的webhook接入点,支持请求验证、数据转换、规则路由等核心能力,解决多服务webhook管理中的安全验证复杂、格式不统一、转发规则分散等问题,降低跨服务事件通知的集成成本。
bashdocker run -d \ --name webhook-gateway \ -p 8080:8080 \ -e PORT=8080 \ -e VALIDATION_SECRET=your_webhook_secret \ -e TARGET_URL=https://your-backend-service.com/webhook \ webhook-gateway:latest
yamlversion: '3' services: webhook-gateway: image: webhook-gateway:latest container_name: webhook-gateway ports: - "8080:8080" environment: - PORT=8080 # 监听端口,默认8080 - LOG_LEVEL=info # 日志级别:debug/info/warn/error,默认info - VALIDATION_TYPE=hmac # 验证类型:hmac/token/none,默认none - VALIDATION_SECRET=your_hmac_secret # 验证密钥,当VALIDATION_TYPE为hmac/token时必填 - TARGET_BASE_URL=https://backend-service:3000 # 默认转发基础URL volumes: - ./routes.yaml:/app/routes.yaml # 路由规则配置文件(可选) restart: unless-stopped
| 环境变量名 | 描述 | 默认值 | 可选值 |
|---|---|---|---|
PORT | 网关监听端口 | 8080 | 1-65535 |
LOG_LEVEL | 日志输出级别 | info | debug, info, warn, error |
VALIDATION_TYPE | 请求验证方式 | none | hmac, token, none |
VALIDATION_SECRET | 验证密钥(HMAC密钥或Token值),VALIDATION_TYPE为hmac/token时必填 | - | 字符串 |
VALIDATION_HEADER | 验证信息所在请求头(如GitHub的X-Hub-Signature-256) | 自动匹配 | 自定义头名称 |
TARGET_BASE_URL | 默认转发目标服务基础URL,未匹配路由规则时使用 | - | HTTP/HTTPS URL |
RETRY_MAX | 请求转发失败后最大重试次数 | 3 | 0-10 |
RETRY_DELAY_MS | 重试间隔(毫秒) | 1000 | 100-5000 |
通过挂载路由配置文件(如routes.yaml)实现复杂路由逻辑,配置示例:
yamlroutes: - name: github-webhook # 路由名称 match: # 匹配规则 path: /github # 匹配请求路径 headers: X-GitHub-Event: push # 匹配请求头 validate: # 路由级验证配置(覆盖全局配置) type: hmac secret: github_webhook_secret header: X-Hub-Signature-256 transform: # 数据转换规则 type: json mapping: # 字段映射,将源字段映射到目标字段 event_type: $.action repo: $.repository.name sender: $.sender.login target: https://internal-github-handler:3000/events # 转发目标URL - name: slack-notification match: path: /slack validate: type: token secret: slack_bot_token header: Authorization target: https://slack-processor:4000/process
启动容器后,通过curl发送测试请求验证:
bashcurl -X POST http://localhost:8080/github \ -H "Content-Type: application/json" \ -H "X-GitHub-Event: push" \ -d '{"action":"published","repository":{"name":"my-app"},"sender":{"login":"user123"}}'
查看容器日志确认请求处理状态:
bashdocker logs -f webhook-gateway
routes.yaml)管理复杂规则,避免环境变量过多导致配置混乱您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务