ddns-go

jeessy/ddns-go

jeessy

这是一款简单易用的动态域名解析(DDNS)服务,支持阿里云、腾讯云、Dnspod、Cloudflare、回调功能及华为云等多个主流平台,可帮助用户便捷实现动态IP地址与域名的实时绑定,适用于个人服务器、家庭网络设备等多种场景,为用户提供稳定可靠的动态域名解析解决方案。

440 次收藏下载次数: 0状态:社区镜像维护者:jeessy仓库类型:镜像最近更新:20 天前
让 AI 帮你使用轩辕镜像?

如果你使用 DeepSeek元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。

只需在 AI 对话中先发送下面这句话即可:

请先完整阅读并严格遵守以下文档中的全部规则与要求:

https://xuanyuan.cloud/agents.md

在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。

查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AIDeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。

下载命令
点击查看

DDNS-GO

https://img.shields.io/github/release/jeessy2/ddns-go.svg?logo=github&style=flat-square !https://img.shields.io/github/downloads/jeessy2/ddns-go/total?logo=github](https://github.com/jeessy2/ddns-go/releases/latest) https://img.shields.io/github/go-mod/go-version/jeessy2/ddns-go](https://github.com/jeessy2/ddns-go/blob/master/go.mod) https://goreportcard.com/badge/github.com/jeessy2/ddns-go/v6](https://goreportcard.com/report/github.com/jeessy2/ddns-go/v6) https://img.shields.io/docker/image-size/jeessy/ddns-go](https://registry.hub.docker.com/r/jeessy/ddns-go) https://img.shields.io/docker/pulls/jeessy/ddns-go](https://registry.hub.docker.com/r/jeessy/ddns-go)

中文 | https://github.com/jeessy2/ddns-go/blob/master/README_EN.md

自动获得你的公网 IPv4 或 IPv6 地址,并解析到对应的域名服务。

  • DDNS-GO
    • 特性
    • 系统中使用
    • Docker中使用
    • 使用IPv6
    • Webhook
    • Callback
    • 界面
    • 开发&自行编译

特性

  • 支持Mac、Windows、Linux系统,支持ARM、x86、RISC-V架构
  • 支持的域名服务商 阿里云 阿里云 ESA 腾讯云 Dnspod Cloudflare 华为云 Callback 百度云 Porkbun GoDaddy Namecheap NameSilo Dynadot DNSLA 时代互联 Eranet Tnethk Gcore EdgeOne IBM NS1 Connect 雨云
  • 支持接口/网卡/https://github.com/jeessy2/ddns-go/wiki/%E9%80%9A%E8%BF%87%E5%91%BD%E4%BB%A4%E8%8E%B7%E5%8F%96IP%E5%8F%82%E8%80%83%E8%8E%B7%E5%8F%96IP
  • 支持以服务的方式运行
  • 默认间隔5分钟同步一次
  • 支持同时配置多个DNS服务商
  • 支持多个域名同时解析
  • 支持多级域名
  • 网页中配置,简单又方便,默认勾选禁止从公网访问
  • 网页中方便快速查看最近50条日志
  • 支持Webhook通知
  • 支持TTL
  • 支持部分DNS服务商https://github.com/jeessy2/ddns-go/wiki/%E4%BC%A0%E9%80%92%E8%87%AA%E5%AE%9A%E4%B9%89%E5%8F%82%E6%95%B0%EF%BC%8C%E5%AE%9E%E7%8E%B0%E5%9C%B0%E5%9F%9F%E8%A7%A3%E6%9E%90/%E5%A4%9AIP%E7%AD%89%E5%8A%9F%E8%83%BD

[!NOTE] 建议在启用公网访问时,使用 Nginx 等反向代理软件启用 HTTPS 访问,以保证安全性。https://github.com/jeessy2/ddns-go/wiki/FAQ

系统中使用

  • https://github.com/jeessy2/ddns-go/releases 下载并解压 ddns-go
  • 安装服务
    • Mac/Linux: sudo ./ddns-go -s install
    • Win(以管理员打开cmd): .\ddns-go.exe -s install
  • 配置
    • 打开浏览器并访问http://localhost:9876进行初始化配置
  • [可选] 服务卸载
    • Mac/Linux: sudo ./ddns-go -s uninstall
    • Win(以管理员打开cmd): .\ddns-go.exe -s uninstall
  • [可选] 支持安装带参数
    • -l 监听地址
    • -f 同步间隔时间(秒)
    • -cacheTimes 间隔N次与服务商比对
    • -c 自定义配置文件路径
    • -noweb 不启动web服务
    • -skipVerify 跳过证书验证
    • -dns 自定义 DNS 服务器
    • -resetPassword 重置密码
  • [可选] 参考示例
    • 10分钟同步一次, 并指定了配置文件地址
      bash
      ./ddns-go -s install -f 600 -c /Users/name/.ddns_go_config.yaml
      
    • 每 10 秒检查一次本地 IP 变化, 每 30 分钟对比一下 IP 变化, 实现 IP 变化即时触发更新且不会被服务商限流, 如果使用接口获取IP, 需要注意接口限流
      bash
      ./ddns-go -s install -f 10 -cacheTimes 180
      
    • 重置密码
      bash
      ./ddns-go -resetPassword 123456
      ./ddns-go -resetPassword 123456 -c /Users/name/.ddns_go_config.yaml
      

Docker中使用

  • 挂载主机目录, 使用docker host模式。可把 /opt/ddns-go 替换为你主机任意目录, 配置文件为隐藏文件

    bash
    docker run -d --name ddns-go --restart=always --net=host -v /opt/ddns-go:/root jeessy/ddns-go
    
  • 打开浏览器并访问http://Docker主机IP:9876进行初始化配置

  • [可选] 使用 ghcr.io 镜像

    bash
    docker run -d --name ddns-go --restart=always --net=host -v /opt/ddns-go:/root ghcr.io/jeessy2/ddns-go
    
  • [可选] 支持启动带参数 -l监听地址 -f间隔时间(秒)

    bash
    docker run -d --name ddns-go --restart=always --net=host -v /opt/ddns-go:/root jeessy/ddns-go -l :9877 -f 600
    
  • [可选] 不使用docker host模式

    bash
    docker run -d --name ddns-go --restart=always -p 9876:9876 -v /opt/ddns-go:/root jeessy/ddns-go
    
  • [可选] 重置密码

    bash
    docker exec ddns-go ./ddns-go -resetPassword 123456
    docker restart ddns-go
    

使用IPv6

  • 前提:你的电脑或终端能正常获取IPv6,并能正常访问IPv6
  • Windows/Mac:推荐 系统中使用,Windows/Mac桌面版的docker不支持--net=host
  • 群晖:
    • 套件中心下载docker并打开
    • 注册表中搜索ddns-go并下载
    • 映像 -> 选择jeessy/ddns-go -> 启动 -> 高级设置 -> 网络中勾选使用与 Docker Host 相同的网络,高级设置中勾选启动自动重新启动
    • 在浏览器中打开http://群晖IP:9876,修改你的配置,成功
  • Linux的x86或arm架构,推荐使用Docker的--net=host模式。参考 Docker中使用
  • 虚拟机中使用有可能正常获取IPv6,但不能正常访问IPv6

Webhook

  • 支持webhook, 域名更新成功或不成功时, 会回调填写的URL

  • 支持的变量

    变量名说明
    #{ipv4Addr}新的IPv4地址
    #{ipv4Result}IPv4地址更新结果: 未改变 失败 成功
    #{ipv4Domains}IPv4的域名,多个以,分割
    #{ipv6Addr}新的IPv6地址
    #{ipv6Result}IPv6地址更新结果: 未改变 失败 成功
    #{ipv6Domains}IPv6的域名,多个以,分割
    #{timestamp}当前 UTC+0 时间戳(秒)
  • 如 RequestBody 为空则为 GET 请求,否则为 POST 请求

  • Server酱
    https://sctapi.ftqq.com/[SendKey].send?title=你的公网IP变了&desp=主人IPv4变了#{ipv4Addr},域名更新结果:#{ipv4Result}
    
  • Bark
    https://api.day.app/[YOUR_KEY]/主人IPv4变了#{ipv4Addr},域名更新结果:#{ipv4Result}
    
  • 钉钉
    • 钉钉电脑端 -> 群设置 -> 智能群助手 -> 添加机器人 -> 自定义
    • 只勾选 自定义关键词, 输入的关键字必须包含在RequestBody的content中, 如:你的公网IP变了
    • URL中输入钉钉给你的 Webhook地址
    • RequestBody中输入
      json
      {
          "msgtype": "markdown",
          "markdown": {
              "title": "你的公网IP变了",
              "text": "#### 你的公网IP变了 \n - IPv4地址:#{ipv4Addr} \n - 域名更新结果:#{ipv4Result} \n"
          }
      }
      
  • 飞书
    • 飞书电脑端 -> 群设置 -> 添加机器人 -> 自定义机器人
    • 安全设置只勾选 自定义关键词, 输入的关键字必须包含在RequestBody的content中, 如:你的公网IP变了
    • URL中输入飞书给你的 Webhook地址
    • RequestBody中输入
      json
      {
          "msg_type": "post",
          "content": {
              "post": {
                  "zh_cn": {
                      "title": "你的公网IP变了",
                      "content": [
                          [
                              {
                                  "tag": "text",
                                  "text": "IPv4地址:#{ipv4Addr}"
                              }
                          ],
                          [
                              {
                                  "tag": "text",
                                  "text": "域名更新结果:#{ipv4Result}"
                              }
                          ]
                      ]
                  }
              }
          }
      }
      
  • ***

    https://github.com/WingLim/ddns-***-bot

  • plusplus 推送加
    • 获取token
    • URL中输入 https://www.pushplus.plus/send
    • RequestBody中输入
      json
      {
          "token": "your token",
          "title": "你的公网IP变了",
          "content": "你的公网IP变了 \n - IPv4地址:#{ipv4Addr} \n - 域名更新结果:#{ipv4Result} \n"
      }
      
  • ***
    • ***任意客户端 -> 伺服器 -> 频道设置 -> 整合 -> 查看Webhook -> 新Webhook -> 复制Webhook网址
    • URL中输入***复制的 Webhook网址
    • RequestBody中输入
      json
      {
          "content": "域名 #{ipv4Domains} 动态解析 #{ipv4Result}.",
          "embeds": [
              {
                  "description": "#{ipv4Domains} 的动态解析 #{ipv4Result}, IP: #{ipv4Addr}",
                  "color": 15258703,
                  "author": {
                      "name": "DDNS"
                  },
                  "footer": {
                      "text": "DDNS #{ipv4Result}"
                  }
              }
          ]
      }
      
  • 微信
    • 通过 https://www.npmjs.com/package/@tencent-weixin/openclaw-weixin 推送消息到微信
    • 需要先通过协议获取 $your_bot_token 和 $your_user_id,可参考 https://github.com/hao-ji-xing/openclaw-weixin/blob/main/weixin-bot-api.md
    • URL 中输入 https://ilinkai.weixin.qq.com/ilink/bot/sendmessage
    • RequestBody 中输入
      json
      {
          "msg": {
              "from_user_id": "",
              "to_user_id": "$your_user_id@im.wechat",
              "client_id": "ddns-#{timestamp}",
              "message_type": 2,
              "message_state": 2,
              "item_list": [
                  {
                      "type": 1,
                      "text_item": {
                          "text": "📡 IPv4: #{ipv4Result}\n   新地址: #{ipv4Addr}\n   已绑定域名: #{ipv4Domains}\n\n📡 IPv6: #{ipv6Result}\n   新地址: #{ipv6Addr}\n   已绑定域名: #{ipv6Domains}"
                      }
                  }
              ]
          },
          "base_info": {
              "channel_version": "2.1.7"
          }
      }
      
    • Headers 中输入
      Content-Type: application/json
      AuthorizationType: ilink_bot_token
      Authorization: Bearer $your_bot_token
      iLink-App-Id: bot
      iLink-App-ClientVersion: 131335
      
  • https://github.com/jeessy2/ddns-go/issues/327

Callback

  • 通过自定义回调可支持更多的第三方DNS服务商

  • 配置的域名有几行, 就会回调几次

  • 支持的变量

    变量名说明
    #{ip}新的IPv4/IPv6地址
    #{domain}当前域名
    #{recordType}记录类型 AAAAA
    #{ttl}TTL
  • 如 RequestBody 为空则为 GET 请求,否则为 POST 请求

  • https://github.com/jeessy2/ddns-go/wiki/Callback%E9%85%8D%E7%BD%AE%E5%8F%82%E8%80%83

界面

!https://raw.githubusercontent.com/jeessy2/ddns-go/master/ddns-web.png

开发&自行编译

  • 如果喜欢从源代码编译自己的版本,可以使用本项目提供的 Makefile 构建
  • 使用 make build 生成本地编译后的 ddns-go 可执行文件
  • 使用 make build_docker_image 自行编译 Docker 镜像

镜像拉取方式

您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面

轩辕镜像加速拉取命令点我查看更多 ddns-go 镜像标签

docker pull docker.xuanyuan.run/jeessy/ddns-go:<标签>

DockerHub 原生拉取命令

docker pull jeessy/ddns-go:<标签>

用户好评

来自真实用户的反馈,见证轩辕镜像的优质服务

用户头像

oldzhang

运维工程师

Linux服务器

5

"Docker访问体验非常流畅,大镜像也能快速完成下载。"

专业版 · 高速稳定拉取镜像
50GB 仅 ¥7/年
高速镜像下载在线技术支持99.95% SLA 保障付费会员免广告