利用Dnspod的API和shell脚本搭建自己的动态域名服务

凛酱 638 0

利用Dnspod的API和shell脚本搭建自己的动态域名服务


使用方法

本脚本分为两个版本,一个是获取自己外网ip的版本dnspod_ddns.sh,一个是直接获取自己网卡设备上的ip的版本dnspod_ddns_line.sh(对于多拨或者路由器网关用户适用)。

获取API的ID和Token

API的ID和Token可以在后台获取:
>创建一个 Token,依次点击 用户中心 -> 安全设置 -> API Token:

>点击创建一个 Token,输入 Token 名称即可,名称仅用来标记 Token,方便用户管理 Token ,不参与鉴权。
>点击 “确定” 之后,Token 创建成功,会弹出如下提示框:

利用Dnspod的API和shell脚本搭建自己的动态域名服务

创建密钥,获取token

 

参数说明

>在脚本开头#CONF START到#CONF END之间为用户所需填写的参数:

参数填写说明
| API_ID | 在个人中心后台的安全设置里面获取ID

| API_Token |在个人中心后台的安全设置里面获取Token
| domain| 你所注册的主域名,例如```baidu.com```,```qq.com```,```china.edu.cn```,```example.com```
| host|主机记录名,例如```www.baidu.com```的主机记录名是```www```,```image.www.weibo.com```的主机记录是```image.www```,```home.example.com```的主机记录名是```home```
| CHECKURL|用于检查自己的外网IP是什么的网址,注释掉该参数会跳过本地DNS检查比对,直接执行(验证域名记录是否存在以及记录是否重复后)更新;建议的备选CHECKURL:```http://ip.03k.org``` ```http://ip.3322.org``` ```http://myip.ipip.net``` ```http://checkip.dns.he.net/``` ```https://api-ipv4.ip.sb/ip```
OUT|指定使用某个网卡设备进行联网通信(默认被注释掉)。注意,一些系统的负载均衡功能可能会导致该参数无效。推荐使用```ip a```命令或者```ifconfig```命令查看网卡设备名称。

利用Dnspod的API和shell脚本搭建自己的动态域名服务

 

推荐的部署方法

把如上所述的参数填好即可。
本脚本没有自带循环,因为linux平台几乎都有Crontab(计划任务),利用计划任务可以实现开机启动、循环执行脚本、并设定循环频率而无需常驻后台。

在群晖系统中设置一个计划任务即可,每五分钟执行一次。利用Dnspod的API和shell脚本搭建自己的动态域名服务

利用Dnspod的API和shell脚本搭建自己的动态域名服务

命令参考

假设脚本已经填写好参数并加了可执行权限(```chmod +x ./dnspod_ddns.sh```),并位于```/root/dnspod_ddns.sh```:
新建计划任务输入```crontab -e```
按a进入编辑模式,输入
```*/1 * * * * /root/dnspod_ddns.sh &> /dev/null```
意思是每隔一分钟执行/root/dnspod_ddns.sh并屏蔽输出日志。当然,如果你需要记录日志可以直接重定向至保存路径。
然后按Esc,输入:wq回车保存退出即可。
更多关于Crontab的使用方法此处不再详述。
另外对于一些带有Web管理界面嵌入式系统(比如openwrt),有图形化的计划任务菜单管理,可以直接把脚本粘贴进去。

群晖系统这种可以直接登陆FTP粘贴进去。

工作过程

1、用CHECKURL检查自己的外网ip和本地解析记录是否相同,相同则退出;
2、使用API获取域名在Dnspod平台的ip记录,如果CHECKURL(line.sh则是直接获取网卡ip)获取IP结果和“本地DNS解析记录或者API记录”相同则退出;获取记录异常也会退出并返回错误信息(例如域名不存在No Record);
3、执行DNS更新,并返回执行结果。

注意事项

本脚本**不会**自动创建子域名,请务必先到后台添加一个随意的子域名A记录,否则会提示No Record
如果你看到**API usage is limited**的报错,是由于调用API频率过高账号被冻结(一小时后解封)

 

脚本下载     github地址

参考链接:撸了个dnspod动态DNS的shell脚本 | 零散坑知识分享 (03k.org)

 

发表评论 取消回复
表情 图片 链接 代码

分享