Simple and easy to use DDNS. Support Aliyun, Tencent Cloud, Dnspod, Cloudflare, Callback, Huawei Cloud, Baidu Cloud, Porkbun, GoDaddy, Namecheap, NameSilo...
Go to file
2023-01-12 20:13:18 +08:00
.github build(deps): bump goreleaser/goreleaser-action from 3 to 4 (#456) 2022-12-16 09:57:25 +08:00
.vscode new 2020-08-26 23:56:01 +08:00
config refactor: update dependency and use build-in function (#402) 2022-10-09 15:40:23 +08:00
dns fix: godaddy doesn't work well (#484) 2023-01-12 19:37:11 +08:00
static refactor: replace jquery with vanilla js (#475) 2022-12-23 23:11:37 +08:00
util fix: godaddy doesn't work well (#484) 2023-01-12 19:37:11 +08:00
web feat: get ipv6, use net interfaces by default (#486) 2023-01-12 20:13:18 +08:00
.editorconfig 增加 Makefile 优化编译脚本,并添加相应的说明 (#19) 2020-12-25 10:50:01 +08:00
.gitignore 增加 Makefile 优化编译脚本,并添加相应的说明 (#19) 2020-12-25 10:50:01 +08:00
.goreleaser.yml feat: support goos freebsd (#450) 2022-12-08 17:48:00 +08:00
ddns-web.png docs: new screenshot 2022-12-23 20:11:46 +08:00
Dockerfile feat: golang1.19 (#377) 2022-09-14 20:35:49 +08:00
favicon.ico feat: using golang1.16 embed (#40) 2021-02-23 18:15:45 +08:00
go.mod build(deps): bump github.com/kardianos/service from 1.2.1 to 1.2.2 (#404) 2022-10-11 23:43:30 +08:00
go.sum build(deps): bump github.com/kardianos/service from 1.2.1 to 1.2.2 (#404) 2022-10-11 23:43:30 +08:00
LICENSE Add LICENSE 2020-08-31 17:06:54 +08:00
main.go feat: Skip verify (#481) 2023-01-06 20:56:55 +08:00
Makefile build: add -trimpath flag to build args (#247) 2022-04-26 18:26:47 +08:00
README.md docs: usage in docker 2023-01-06 21:11:46 +08:00

ddns-go

GitHub release

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

特性

  • 支持Mac、Windows、Linux系统支持ARM、x86架构
  • 支持的域名服务商 Alidns(阿里云) Dnspod(腾讯云) Cloudflare 华为云 Callback 百度云 porkbun GoDaddy Google Domains
  • 支持接口/网卡获取IP
  • 支持以服务的方式运行
  • 默认间隔5分钟同步一次
  • 支持多个域名同时解析,公司必备
  • 支持多级域名
  • 网页中配置,简单又方便,可设置 登录用户名和密码 / 禁止从公网访问
  • 网页中方便快速查看最近50条日志不需要跑docker中查看
  • 支持webhook通知
  • 支持TTL
  • 支持部分dns服务商传递自定义参数实现地域解析等功能

系统中使用

  • 下载并解压https://github.com/jeessy2/ddns-go/releases
  • 双击运行, 如没有找到配置, 程序自动打开http://127.0.0.1:9876
  • [可选] 安装服务
    • Mac/Linux: sudo ./ddns-go -s install
    • Win(以管理员打开cmd): .\ddns-go.exe -s install
    • 安装服务也支持 -l监听地址 -f同步间隔时间(秒) -c自定义配置文件路径 -noweb不启动web服务 -skipVerify跳过证书验证
  • [可选] 服务卸载
    • Mac/Linux: sudo ./ddns-go -s uninstall
    • Win(以管理员打开cmd): .\ddns-go.exe -s uninstall
  • [可选] 支持启动带参数 -l监听地址 -f同步间隔时间(秒) -c自定义配置文件路径 -noweb不启动web服务 -skipVerify跳过证书验证。如:./ddns-go -l :9877 -f 600 -c /Users/name/ddns-go.yaml

Docker中使用

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

    docker run -d --name ddns-go --restart=always --net=host -v /opt/ddns-go:/root jeessy/ddns-go
    
  • 在浏览器中打开http://主机IP:9876,修改你的配置,成功

  • [可选] 支持启动带参数 -l监听地址 -f间隔时间(秒)

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

    docker run -d --name ddns-go --restart=always -p 9876:9876 -v /opt/ddns-go:/root jeessy/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的域名多个以,分割
  • RequestBody为空GET请求不为空POST请求

  • Server酱: https://sctapi.ftqq.com/[SendKey].send?title=主人IPv4变了#{ipv4Addr},域名更新结果:#{ipv4Result}

  • Bark: https://api.day.app/[YOUR_KEY]/主人IPv4变了#{ipv4Addr},域名更新结果:#{ipv4Result}

  • 钉钉:

    • 钉钉电脑端 -> 群设置 -> 智能群助手 -> 添加机器人 -> 自定义
    • 只勾选 自定义关键词, 输入的关键字必须包含在RequestBody的content中, 如:你的公网IP变了
    • URL中输入钉钉给你的 Webhook地址
    • RequestBody中输入 {"msgtype": "markdown","markdown": {"title":"你的公网IP变了","text": "#### 你的公网IP变了 \n - IPV4地址#{ipv4Addr} \n - 域名更新结果:#{ipv4Result} \n"}}
  • 飞书:

    • 飞书电脑端 -> 群设置 -> 添加机器人 -> 自定义机器人
    • 安全设置只勾选 自定义关键词, 输入的关键字必须包含在RequestBody的content中, 如:你的公网IP变了
    • URL中输入飞书给你的 Webhook地址
    • RequestBody中输入 {"msg_type": "post","content": {"post": {"zh_cn": {"title": "你的公网IP变了","content": [[{"tag": "text","text": "IPV4地址#{ipv4Addr}"}] , [{"tag": "text","text": "域名更新结果:#{ipv4Result}"}]]}}}}
  • Telegram: ddns-telegram-bot

  • plusplus 推送加:

    • 获取token
    • URL中输入 https://www.pushplus.plus/send
    • RequestBody中输入 {"token":"your token","title":"你的公网IP变了","content":"你的公网IP变了 \n - IPV4地址#{ipv4Addr} \n - 域名更新结果:#{ipv4Result} \n"}
  • Discord:

    • Discord任意客户端 -> 伺服器 -> 频道设置 -> 整合 -> 查看Webhook -> 新Webhook -> 复制Webhook网址
    • URL中输入Discord复制的 Webhook网址
    • RequestBody中输入 {"content":"域名 #{ipv4Domains} 动态解析 #{ipv4Result}.","embeds":[{"description":"#{ipv4Domains} 的动态解析 #{ipv4Result}, IP: #{ipv4Addr}","color":15258703,"author":{"name":"DDNS"},"footer":{"text":"DDNS #{ipv4Result}"}}]}

Callback

  • 通过自定义回调可支持更多的第三方DNS服务商
  • 配置的域名有几行, 就会回调几次
  • 支持的变量
    变量名 说明
    #{ip} 新的IPv4/IPv6地址
    #{domain} 当前域名
    #{recordType} 记录类型 AAAAA
    #{ttl} ttl
  • RequestBody为空GET请求不为空POST请求

界面

screenshots

开发&自行编译

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