Skip to content

Latest commit

 

History

History
99 lines (83 loc) · 2.71 KB

README.md

File metadata and controls

99 lines (83 loc) · 2.71 KB

DDNS

自动更新DNS解析 到本机IP地址,支持 ipv4和ipv6 以 本地(内网)IP 和 公网IP。 代理模式,支持自动创建域名记录。

特性

  • 多个域名支持
  • 多级域名解析
  • 内网IP
  • 公网IP
  • ipv6支持
  • 代理模式(http代理)
  • 定时任务
  • 自动创建记录
  • 多系统(Widnows, Linux, MacOS)
  • DNSPOD
  • 阿里DNS
  • 兼容 python2 和 python3

TODO:

  • 文件缓存(减少服务器IP请求)
  • 同线路多记录支持
  • socks代理
  • 多代理自动切换
  • 简化混合配置

使用

  1. 复制 example.config.jsonconfig.json
  2. 申请api token(DNSPOD创建token,阿里云accesskey)
  3. 修改配置,ipv4ipv6字段,没有则设为[],详细参照配置说明
  4. 运行./run.py (widnows 双击run.bat或者运行python run.py)

配置

config.json

可以使用 -c使用指定的配置文件 (默认读取当前目录的 config.json)

python run.py -c /path/to/config.json 

配置说明

key type required default comment
id string Yes api授权id
token string Yes api授权token
dns string No dnspod dns服务商,阿里为alidns
ipv4 array No [] ipv4 域名列表
ipv6 array No [] ipv6 域名列表
index4 string/int No 'default' ipv4获取方式
index6 string/int No 'default' ipv6获取方式
proxy string No 设置请求代理
debug boolean No false 是否开启调试(输出调试信息)

index4和index6参数说明

  • default 系统访问外网默认IP
  • 数字(0,1,2,3等)第i个网卡ip
  • public使用公网ip(使用公网API查询)
  • nku NKU网关ip(只支持ipv4)

配置示例

{
	"id": "12345",
	"token": "mythokenkey",
	"dns": "dnspod 或者 alidns",
	"ipv4": [
		"dns.newfuture.xyz",
		"ipv4.dns.newfuture.xyz"
	],
	"ipv6": [
		"dns.newfuture.xyz",
		"ipv6.dns.newfuture.xyz"
	],
	"index4": "0",
	"index6": "public",
	"proxy": "127.0.0.1:1111",
	"debug": false
}

定时任务

可以通过脚本方便的设置定时任务(默认没5分钟检查一次ip变化,自动更新)

windows

需要已经安装python

  • 以当前用户身份运行定时任务,双击或者运行task.bat (执行时会闪黑框)
  • 以系统身份运行定时任务,右键"以管理员身份运行"task.bat(或者在管理员命令行中运行)

linux

运行 sudo ./task.sh