利用CloudFlare设置Dynamic DNS(DDNS)获取动态IP

更新提示

2018/07/05:增加一个Python脚本,支持Python2和Python3。Shell脚本和Python脚本均支持Cloudflare的v4 API,使用其中一个即可。

2018/07/04:第一版教程的脚本比较旧,用的API不再被CloudFlare支持。新教程改用Benkulbertis的shell脚本,设置也更为简单。此脚本需要系统支持grep的-P参数,部分系统可能无法使用,会报错grep: the -P option is not supported。目前在CentOS 7、Ubuntu 16.04测试通过,已知可能不支持的系统有OS X、Debian、FreeBSD。

2018/05/13:第一版教程使用了Larrybolt的shell脚本

简介

如果买了动态IP的VPS或服务器,IP会经常改变。这时,就可以通过DDNS来获取动态IP。部分商家可能不提供DDNS,需要自己搭建。假设你已经有了一个域名zhaozhuji.net,想要设置域名ddns.zhaozhu.net获取最新的动态IP。

获取API

如果域名没有使用CloudFlare的DNS解析服务,首先要在CloudFlare按提示添加域名zhaozhuji.net,把域名的DNS服务器改为CloudFlare,增加对应域名的A记录ddns.zhaozhuji.net。TTL可设为2分钟或自动。注意,DDNS使用的域名不要开启CloudFlare的CDN,只用CF的DNS解析功能,也就是status一列对应域名的图标要是灰色的。

添加好域名解析后,前往https://www.cloudflare.com/a/profile获取Global API,把API一长串字符复制保存下来。注意,这串API不要泄露给其他人。

Shell脚本

获取脚本

得到API后,在VPS中下载脚本到/usr/local/bin目录,把脚本命名为cf-ddns.sh,并修改脚本的权限:

curl https://gist.githubusercontent.com/benkulbertis/fff10759c2391b6618dd/raw > /usr/local/bin/cf-ddns.sh && chmod +x /usr/local/bin/cf-ddns.sh

一般系统都会带有curl,但如果出错,就需要先安装curl,具体安装方法可以谷歌或百度一下。

配置

打开脚本进行配置:

vi  /usr/local/bin/cf-ddns.sh

找到以下内容并修改:

auth_email="user@example.com"
auth_key="c2547eb745079dac9320b638f5e225cf483cc5cfdda41" # found in cloudflare account settings
zone_name="example.com"
record_name="www.example.com"

其中,在auth_email中填入CloudFlare账号的邮箱,在auth_key输入前面获取的API,zone_name填入域名zhaozhuji.net,record_name填入DDNS的域名ddns.zhaozhuji.net。

修改完后,保存退出。输入bash /usr/local/bin/cf-ddns.sh运行脚本,如果提示IP changed to: X.X.X.X,表明配置成功。

crontab定时运行

脚本配置成功后,需要让它定时运行。这里设置每10分钟运行一次cf-ddns.sh脚本。

输入crontab -e,然后会弹出vi编辑界面,在里面添加一行:

*/10 * * * *  /usr/local/bin/cf-ddns.sh >/dev/null 2>&1

保存并退出。输入service crond status,可以看到contab的运行状态。如果contab服务没有打开,建议参考http://man.linuxde.net/crontab教程,它涵盖了crontab服务状态的启动、重启、查看、简单配置等内容。另外也可以看看http://linuxtools-rst.readthedocs.io/zh_CN/latest/tool/crontab.htmlhttp://www.runoob.com/linux/linux-comm-crontab.html

日志文件

脚本获取IP更改CloudFlare的DNS记录后,会在目录中生成ip.txt、cloudflare.ids和cloudflare.log三个文件。ip.txt记录的是本机的IP。脚本自动获取到IP后,会先与ip.txt中的IP进行比较,当不一致时(检测到IP发生变化),才会更新CloudFlare的DNS记录,并且把新IP写入ip.txt文件中。如果IP没变化,运行脚本会提示IP has not changed。如果要强制运行脚本更新DNS记录,可以rm /usr/local/bin/ip.txt删除掉ip.txt。

如果运行忽然出问题,可以试试rm /usr/local/bin/cloudflare.ids把cloudflare.ids文件和ip.txt文件删除掉,再重新运行脚本。

Python脚本

获取脚本

curl https://raw.githubusercontent.com/AmirAzodi/cloudflare_ddns/master/cf-ddns.py > /usr/local/bin/cf-ddns.py && curl https://raw.githubusercontent.com/AmirAzodi/cloudflare_ddns/master/cf-ddns.conf > /usr/local/bin/cf-ddns.conf && chmod +x /usr/local/bin/cf-ddns.py

配置

打开配置文件:

vi /usr/local/bin/cf-ddns.conf

按提示修改以下内容:

{
 "domains": [
  {
   "hosts": [
    {
     "id": "",
     "ipv4": "",
     "ipv6": "",
     "name": "ddns",   #以ddns.zhaozhuji.net为例,此处填入ddns
     "types": ["A"]
    }
   ],
   "id": "",
   "name": "zhaozhuji.net"  #以ddns.zhaozhuji.net为例,此处填入zhaozhuji.net
  }
 ],
 "user": {
  "api_key": "CLOUDFLARE_API_KEY_HERE",  #填入API
  "email": "CLOUDFLARE_EMAIL_HERE"  #填入CloudFlare邮箱
 }
}

保存并退出,输入python /usr/local/bin/cf-ddns.py运行脚本,如果提示内容有update successful,表明运行成功。

crontab定时运行

跟第一个脚本类似,输入crontab -e,然后会弹出vi编辑界面,在里面添加一行:

*/10 * * * *  /usr/local/bin/cf-ddns.py >/dev/null 2>&1

更多脚本

如果以上都不能使用,可以尝试换其他的,不过这些本人没尝试过:

https://gist.github.com/bensonfx/487a7fece19916f3e66a31ce782e76d2

https://github.com/MachineITSvcs/Cloudflare-DDNS-Update

https://github.com/gstuartj/cf-ddns.sh

© 版权声明
THE END
喜欢就支持以下吧
点赞0
分享
评论 共18条
    • 赵煮机
    • Safy0

      大佬,是否最后要加上这一行啊chkconfig crond on

      8月22日 10:13回复
      • crontab命令相关的东西懒得写了,所以直接挂了个教程网址 😆

        8月23日 21:01@Safy回复
    • 赵煮机
    • Safy0

      而且我遇到一个奇葩的问题,刚开始的时候可以用,后来发现突然用不了啦,发现 在/user/local/bin文件夹 里面 的cloudflare.ids 那几个文件都不会自动生成在/user/local/bin里面,而是生成在root目录,把sh脚本 里面的 这几个文件改成绝对路径/usr/local/bin后 正常了。。。好郁闷。

      8月22日 10:16回复
      • 我也试过忽然用不了的情况,把/usr/local/bin/里面产生的几个文件删除掉重新运行就可以了。个人感觉Python的那个脚本更稳些。

        8月23日 21:05@Safy回复
    • 赵煮机
    • miaoice0

      [root@Nathosts-201895604 ~]# python /usr/local/bin/cf-ddns.py
      Traceback (most recent call last):
      File "/usr/local/bin/cf-ddns.py", line 29, in
      with open(config_file_name, 'r') as config_file:
      IOError: [Errno 2] No such file or directory: 'cf-ddns.conf'
      大佬这是出现什么问题了,还有shell脚本只有第一次才能用,ip才会改变,第二次使用就不会改变no change ,然后删除ip.txt提示没这个文件!

      9月7日 10:57回复
      • 赵煮机
        灰太狼0

        我用的python那个脚本,第二次执行的也会出现这样,检查了一下,是路径问题,编辑脚本文件第27行,写全路径就可以了,config_file_name = '/usr/local/bin/cf-ddns.conf'

        9月17日 13:18@miaoice回复
    • 赵煮机
    • maxcat0

      可以把HTTPS的根证书加上,安全

      11月10日 23:25回复
    • 赵煮机
    • cf-origin0

      root@ip-172-26-9-148:~# bash /usr/local/bin/cf-ddns.sh
      API UPDATE FAILED. DUMPING RESULTS:
      {"success":false,"errors":[{"code":7003,"message":"Could not route to \/zones\/dns_records, perhaps your object identifier is invalid?"},{"code":7000,"message":"No route for that URI"}],"messages":[],"result":null}
      不知什么原因

      12月22日 17:07回复
    • 赵煮机
    • Colin0

      很迷 手动执行可以 放crontab 就不能了

      1月12日 07:08回复
    • 赵煮机
    • baiyou0

      运行 python /usr/local/bin/cf-ddns.py提示* problem with the config file怎么回事呢?

      2月17日 14:00回复
    • 赵煮机
    • taoge0

      # bash /usr/local/bin/cf-ddns.sh
      API UPDATE FAILED. DUMPING RESULTS:
      {"success":false,"errors":[{"code":1020,"message":"Invalid DNS record identifier"}],"messages":[],"result":null}
      IP变动后。没有更新。执行命令后提示上面出错,我只能进入程序目录,把IP.TXT删除后,再执行更新命令,就正常了
      这是不是要配合别外一个,执行更新的时候需要把旧的IP.txt 删除?
      [root@Nathosts-2019214508 ~]# rm ip.txt
      rm: remove regular file ‘ip.txt’? y
      [root@Nathosts-2019214508 ~]# bash /usr/local/bin/cf-ddns.sh
      API UPDATE FAILED. DUMPING RESULTS:
      {"success":false,"errors":[{"code":1020,"message":"Invalid DNS record identifier"}],"messages":[],"result":null}
      [root@Nathosts-2019214508 ~]# cd /usr/local/bin/
      [root@Nathosts-2019214508 bin]# ls
      cf-ddns.sh cloudflare.ids cloudflare.log ip.txt
      [root@Nathosts-2019214508 bin]# rm ip.txt
      rm: remove regular file ‘ip.txt’? y
      [root@Nathosts-2019214508 bin]# bash /usr/local/bin/cf-ddns.sh
      IP changed to: 14.*.*.*
      [root@Nathosts-2019214508 bin]#

      2月23日 21:52回复
    • 赵煮机
    • taoge0

      看来每10分钟的计划任务应该是选 RM /usr/local/bin/IP.TXT 最后才 bash /usr/local/bin/cf-ddns.sh 。这样IP换后才不会又出错,今晚又是换IP。10分钟任务没起作用

      2月25日 01:04回复
    • 赵煮机
    • taoge0

      赵煮机,每10分钟执行cf-ddns.sh前先把IP.txt删除了,这个crontab -e 要怎么写?

      2月25日 01:10回复
    • 赵煮机
    • Kenzie0

      日志显示已更换,但实际未做更改,这个是为啥呢?
      [Sun Mar 3 22:30:02 CST 2019] - IP changed to: 58.177.***.***
      [Sun Mar 3 22:40:01 CST 2019] - Check Initiated
      [Sun Mar 3 22:50:01 CST 2019] - Check Initiated
      [Sun Mar 3 23:00:01 CST 2019] - Check Initiated

      3月4日 12:27回复
      • 赵煮机
        Kenzie0

        结贴,因为在添加域名之前运行过一次,所以导致他更新到另外一个域名去了,解决办法删除cloudflare.ids,重新运行

        3月4日 12:47@Kenzie回复
    • 赵煮机
    • Pink0

      提問:換了IP之後腳本自動把CDN給關了…該怎麼解決?

      7月5日 16:50回复
    • 赵煮机
    • Microsoft0

      您好,请问可以转载嘛,肯定要注明出处

      7月11日 10:59回复
    • 赵煮机
    • chenmo0

      我想一次多更新几个二级域名呢,要怎么修改?

      9月25日 14:15回复