自动更新DNS解析 到本机IP地址,支持 ipv4和ipv6 以 本地(内网)IP 和 公网IP。 代理模式,支持自动创建域名记录。
Build Details
- 兼容和跨平台:
- 域名支持:
- 多个域名支持
- 多级域名解析
- 自动创建新记录
- IP类型:
- 内网IP
- 公网IP
- ipv6支持
- 正则选取支持(@rufengsuixing)
- 网络代理:
- http代理支持
- 多代理自动切换
- 服务商支持:
- DNSPOD
- 阿里DNS
- DNS.COM(@loftor-git)
- DNSPOD国际版
- CloudFlare(@tongyifan)
- 其他:
- 可设置定时任务
- 本地文件缓存(减少服务器请求和查询)
根据需要选择一种方式: 二进制版,pip版,或者源码运行
-
- 安装ddns:
pip install ddns或easy_install ddns - 运行:
ddns
- 安装ddns:
-
- clone 或者下载此仓库并解压
- 运行./run.py (widnows 双击
run.bat或者运行python run.py)
-
首次运行
ddns会自动创建一个配置文件config.json -
申请 api
token,填写到对应的id和token字段: -
修改配置,
ipv4和ipv6字段,无则设为[](此时不会解析和更新对应IP),详细参照配置说明
config.json 配置文件
- 首次运行会自动生成一个模板配置文件
- 可以使用
-c使用指定的配置文件 (默认读取当前目录的 config.json) - 推荐使用vscode等支持JsonSchema的编辑器编辑配置文件
ddns -c path/to/config.json
# 或者源码运行
python run.py -c /path/to/config.json | key | type | required | default | description | tips |
|---|---|---|---|---|---|
| id | string | √ | 无 | api访问ID | cloudflare为邮箱 |
| token | string | √ | 无 | api授权token | 也叫secret key, 反馈粘贴时删除 |
| dns | string | No | "dnspod" |
dns服务商 | 阿里alidns,dns.com为 dnscom,DNSPOD国际版 dnspod_com |
| ipv4 | array | No | [] |
ipv4域名列表 | 为[]时,不会获取和更新IPv4地址 |
| ipv6 | array | No | [] |
ipv6域名列表 | 为[]时,不会获取和更新IPv6地址 |
| index4 | string|int | No | "default" |
ipv4获取方式 | 支持指定网卡,公网,正则(注意转义) 等 |
| index6 | string|int | No | "default" |
ipv6获取方式 | 支持指定网卡,公网,正则(注意转义) 等 |
| proxy | string | No | 无 | 多代理;分割 |
多代理逐个尝试直到成功,DIRECT为直连 |
| debug | bool | No | false |
是否开启调试 | 运行异常时,打开调试输出,方便诊断错误 |
| cache | bool | No | true |
是否缓存记录 | 正常情况打开避免频繁更新 |
- 数字(
0,1,2,3等): 第i个网卡ip - 正则表达(如
"192.*"): 提取ifconfig/ipconfig中与之匹配的首个IP地址,注意json转义(\要写成\\)"192.*"表示192开头的所有ip- 如果想匹配
10.00.xxxx应该写成"10\\.00\\..*"("\\"json转义成\)
- 字符串
"default"(或者无此项): 系统访问外网默认IP - 字符串
"public": 使用公网ip(使用公网API查询) false: 强制禁止更新ipv4或ipv6的DNS解析
{
"$schema": "https://ddns.newfuture.cc/schema.json",
"id": "12345",
"token": "mytokenkey",
"dns": "dnspod 或 dnspod_com 或 alidns 或 dnscom 或 cloudflare",
"ipv4": [
"ddns.newfuture.cc",
"ipv4.ddns.newfuture.cc"
],
"ipv6": [
"ddns.newfuture.cc",
"ipv6.ddns.newfuture.cc"
],
"index4": 0,
"index6": "public",
"proxy": "127.0.0.1:1080;DIRECT",
"debug": false
}可以通过脚本设置定时任务(默认每5分钟检查一次ip,自动更新)
- [推荐]以系统身份运行,右键"以管理员身份运行"
task.bat(或者在管理员命令行中运行) - 以当前用户身份运行定时任务,双击或者运行
task.bat(执行时会闪黑框)
运行 sudo ./task.sh
Windows Server [SSL: CERTIFICATE_VERIFY_FAILED]
Windows Server 默认安全策略会禁止任何未添加的信任ssl证书,可手动添加一下对应的证书 #56
使用系统自带的IE浏览器访问一次对应的API即可
- alidns打开: https://alidns.aliyuncs.com
- cloudflare打开: https://api.cloudflare.com
- dns.com打开: https://www.dns.com
- dnspod.cn打开: https://dnsapi.cn
- dnspod国际版: https://api.dnspod.com