轩辕镜像
轩辕镜像专业版
个人中心搜索镜像
交易
充值流量我的订单
工具
工单支持镜像收录Run 助手IP 归属地密码生成Npm 源Pip 源
帮助
常见问题我要吐槽
其他
关于我们网站地图

官方QQ群: 13763429

轩辕镜像
镜像详情
ncarlier/webhookd
官方博客使用教程热门镜像工单支持
本站面向开发者与科研用户,提供开源镜像的搜索和下载加速服务。
所有镜像均来源于原始开源仓库,本站不存储、不修改、不传播任何镜像内容。
轩辕镜像 - 国内开发者首选的专业 Docker 镜像下载加速服务平台 - 官方QQ群:13763429 👈点击免费获得技术支持。
本站面向开发者与科研用户,提供开源镜像的搜索和下载加速服务。所有镜像均来源于原始开源仓库,本站不存储、不修改、不传播任何镜像内容。

本站支持搜索的镜像仓库:Docker Hub、gcr.io、ghcr.io、quay.io、k8s.gcr.io、registry.gcr.io、elastic.co、mcr.microsoft.com

webhookd Docker 镜像下载 - 轩辕镜像

webhookd 镜像详细信息和使用指南

webhookd 镜像标签列表和版本信息

webhookd 镜像拉取命令和加速下载

webhookd 镜像使用说明和配置指南

Docker 镜像加速服务 - 轩辕镜像平台

国内开发者首选的 Docker 镜像加速平台

极速拉取 Docker 镜像服务

相关 Docker 镜像推荐

热门 Docker 镜像下载

webhookd
ncarlier/webhookd
自动构建

webhookd 镜像详细信息

webhookd 镜像标签列表

webhookd 镜像使用说明

webhookd 镜像拉取命令

Docker 镜像加速服务

轩辕镜像平台优势

镜像下载指南

相关 Docker 镜像推荐

一个非常简单的webhook服务器,用于启动shell脚本。
10 收藏0 次下载activencarlier镜像
🚀轩辕镜像专业版更稳定💎一键安装 Docker 配置镜像源
中文简介版本下载
🚀轩辕镜像专业版更稳定💎一键安装 Docker 配置镜像源

webhookd 镜像详细说明

webhookd 使用指南

webhookd 配置说明

webhookd 官方文档

webhookd

一个非常简单的webhook服务器,用于启动shell脚本。

!Logo

概述

webhookd是一个轻量级的webhook服务器,允许通过HTTP请求触发shell脚本执行。它设计简洁,配置灵活,支持多种参数传递方式、实时日志流、通知机制、认证与签名验证等功能,适用于自动化部署、CI/CD流程触发、简单任务调度等场景。

核心功能与特性

  • 简单易用:通过目录结构定义webhook,脚本即服务
  • 灵活配置:支持命令行参数或环境变量配置
  • 多参数传递:URL参数、HTTP头、请求体均可转换为脚本变量
  • 实时日志:支持Server-sent events (SSE) 和Chunked Transfer Coding实时流日志
  • 超时控制:全局和请求级别的超时配置
  • 通知机制:支持HTTP和Email通知,可过滤脚本输出
  • 安全保障:HTTP基本认证、请求签名验证(HTTP Signatures和Ed25519)、TLS加密
  • 多安装方式:支持Go安装、二进制下载、Docker部署、APT包管理

安装与部署

Docker部署

基本部署

$ docker run -d --name=webhookd \
  -v ${PWD}/scripts:/scripts \
  -p 8080:8080 \
  ncarlier/webhookd

高级功能镜像

官方镜像轻量适用于简单脚本,如需高级功能(如Docker CLI或Docker Compose交互),可使用ncarlier/webhookd:edge-distrib镜像:

$ docker run -d --name=webhookd \
  -v ${PWD}/scripts:/scripts \
  -v /var/run/docker.sock:/var/run/docker.sock \
  -p 8080:8080 \
  ncarlier/webhookd:edge-distrib

配置说明

webhookd可通过命令行参数或环境变量配置,执行webhookd -h查看所有参数及对应环境变量。所有配置变量详见etc/default/webhookd.env文件。

核心配置项:

  • WHD_SCRIPTS/-script:脚本目录路径(默认./scripts)
  • WHD_HOOK_TIMEOUT:全局webhook超时时间(秒,默认10)
  • WHD_HOOK_LOG_DIR:日志存储目录
  • WHD_NOTIFICATION_URI:通知目标URI(HTTP或Email)
  • WHD_PASSWD_FILE:htpasswd认证文件路径
  • WHD_TRUST_STORE_FILE:签名验证公钥文件(PEM格式)
  • WHD_TLS:启用TLS(true/false)
  • WHD_TLS_DOMAIN:ACME域名(启用ACME时)

使用方法

目录结构

webhook通过脚本目录结构定义,默认位于./scripts(可通过WHD_SCRIPTS修改)。目录结构示例:

/scripts
├── /github
│   ├── build.sh
│   └── deploy.sh
├── push.js
└── echo.sh

注:支持任何可执行文件(需添加shebang头),如.sh、.js等。

Webhook URL

URL路径对应脚本路径,可省略脚本扩展名(默认查找.sh文件)。示例:

  • 脚本/scripts/github/build.sh对应URL:http://localhost:8080/github/build
  • 脚本/scripts/echo.sh对应URL:http://localhost:8080/echo

响应流类型

  • SSE(Server-sent events):使用GET方法且Accept: text/event-stream头
  • Chunked Transfer:其他情况(如POST方法或默认GET)

参数传递

脚本参数来源及转换规则:

  1. URL请求参数:转换为脚本变量(如?foo=bar → foo=bar)
  2. HTTP头:转换为snakecase变量(如Content-Type → content_type)
  3. 请求体:
    • application/x-www-form-urlencoded:键值对转换为变量
    • text/*或application/json:作为脚本第一个参数传递

额外内置变量:

  • hook_id:自动递增的hook ID
  • hook_name:hook名称
  • hook_method:HTTP请求方法
  • x_forwarded_for:客户端IP
  • x_webauth_user:认证用户名(若启用认证)

超时配置

  • 全局超时:通过WHD_HOOK_TIMEOUT环境变量设置(秒)
  • 请求级超时:通过X-Hook-Timeout HTTP头覆盖(秒)

示例:

curl -H "X-Hook-Timeout: 5" http://localhost:8080/echo?foo=bar

日志管理

  • 实时日志:webhook调用时实时流式输出
  • 历史日志:通过X-Hook-ID头获取的ID访问http://localhost:8080/<NAME>/<ID>查看历史日志

通知机制

脚本执行后可发送通知,仅输出中以特定前缀(默认notify:)开头的行将被发送。通过WHD_NOTIFICATION_URI配置通知目标。

HTTP通知

配置URI:[***](prefix可选,默认notify:)

POST payload格式:

{
  "id": "42",
  "name": "echo",
  "text": "notify: Hello World\n",
  "error": "错误信息(如有)"
}

支持Mattermost、Slack、***等webhook端点。

Email通知

配置URI:mailto:***?smtp=smtp.example.com:587&username=user&password=pass&from=***

支持参数:smtp(SMTP服务器)、username/password(认证信息)、conn(连接类型:tls/tls-insecure/plain)、from(发件人)、subject(主题)。

认证配置

通过htpasswd文件启用HTTP基本认证:

  1. 创建htpasswd文件:
htpasswd -B -c .htpasswd api
  1. 配置认证文件路径:
export WHD_PASSWD_FILE=/path/to/.htpasswd
  1. 使用认证访问:
curl -u api:password -XPOST "http://localhost:8080/echo?msg=hello"

签名验证

支持HTTP Signatures和Ed25519签名验证,需配置公钥文件(PEM格式):

export WHD_TRUST_STORE_FILE=/path/to/pubkey.pem

HTTP Signatures示例:

curl -X POST \
  -H 'Date: Wed, 21 Oct 2015 07:28:00 GMT' \
  -H 'Signature: keyId="my-key",algorithm="rsa-sha256",headers="(request-target) date",signature="base64-signature"' \
  "http://localhost:8080/echo?msg=hello"

Ed25519签名示例:

curl -X POST \
  -H 'X-Signature-Timestamp: 1620000000' \
  -H 'X-Signature-Ed25519: base64-signature' \
  "http://localhost:8080/echo?msg=hello"

TLS配置

启用TLS加密:

  1. 自定义证书:
docker run -d --name=webhookd \
  -v ${PWD}/scripts:/scripts \
  -v ${PWD}/certs:/certs \
  -p 443:443 \
  -e WHD_TLS=true \
  -e WHD_TLS_CERT_FILE=/certs/server.pem \
  -e WHD_TLS_KEY_FILE=/certs/server.key \
  ncarlier/webhookd
  1. ACME自动证书(需域名):
docker run -d --name=webhookd \
  -v ${PWD}/scripts:/scripts \
  -v ${PWD}/acme:/acme \
  -p 80:80 -p 443:443 \
  -e WHD_TLS=true \
  -e WHD_TLS_DOMAIN=hook.example.com \
  ncarlier/webhookd

许可证

MIT许可证,详见LICENSE。

查看更多 webhookd 相关镜像 →

常见问题

轩辕镜像免费版与专业版有什么区别?

免费版仅支持 Docker Hub 加速,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。

轩辕镜像免费版与专业版有分别支持哪些镜像?

免费版仅支持 docker.io;专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等。

流量耗尽错误提示

当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。

410 错误问题

通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。

manifest unknown 错误

先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。

镜像拉取成功后,如何去掉轩辕镜像域名前缀?

使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。

查看全部问题→

轩辕镜像下载加速使用手册

探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式

🔐

登录方式进行 Docker 镜像下载加速教程

通过 Docker 登录方式配置轩辕镜像加速服务,包含7个详细步骤

🐧

Linux Docker 镜像下载加速教程

在 Linux 系统上配置轩辕镜像源,支持主流发行版

🖥️

Windows/Mac Docker 镜像下载加速教程

在 Docker Desktop 中配置轩辕镜像加速,适用于桌面系统

📦

Docker Compose 镜像下载加速教程

在 Docker Compose 中使用轩辕镜像加速,支持容器编排

📋

K8s containerd 镜像下载加速教程

在 k8s 中配置 containerd 使用轩辕镜像加速

🔧

宝塔面板 Docker 镜像下载加速教程

在宝塔面板中配置轩辕镜像加速,提升服务器管理效率

💾

群晖 NAS Docker 镜像下载加速教程

在 Synology 群晖NAS系统中配置轩辕镜像加速

🐂

飞牛fnOS Docker 镜像下载加速教程

在飞牛fnOS系统中配置轩辕镜像加速

📱

极空间 NAS Docker 镜像下载加速教程

在极空间NAS中配置轩辕镜像加速

⚡

爱快路由 ikuai Docker 镜像下载加速教程

在爱快ikuai系统中配置轩辕镜像加速

🔗

绿联 NAS Docker 镜像下载加速教程

在绿联NAS系统中配置轩辕镜像加速

🌐

威联通 NAS Docker 镜像下载加速教程

在威联通NAS系统中配置轩辕镜像加速

📦

Podman Docker 镜像下载加速教程

在 Podman 中配置轩辕镜像加速,支持多系统

📚

ghcr、Quay、nvcr、k8s、gcr 等仓库下载镜像加速教程

配置轩辕镜像加速9大主流镜像仓库,包含详细配置步骤

🚀

专属域名方式进行 Docker 镜像下载加速教程

无需登录即可使用轩辕镜像加速服务,更加便捷高效

需要其他帮助?请查看我们的 常见问题 或 官方QQ群: 13763429

商务:17300950906
|©2024-2025 源码跳动
商务合作电话:17300950906|Copyright © 2024-2025 杭州源码跳动科技有限公司. All rights reserved.