群晖设置DDNS (服务商Godaddy被墙 DDNS-GO无法解析 采用自定义脚本方式完成DDNS更新)

本文主要是介绍群晖设置DDNS (服务商Godaddy被墙 DDNS-GO无法解析 采用自定义脚本方式完成DDNS更新),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

起因&解决思路

事情的开始大概是这样的。。godaddy买了个域名,好好的用了半个月。。然后一直更新失败发现被狗东西墙了 

在提一嘴DDNS-GO 解析失败原因

DDNS-GO必须要先向godaddy请求自己的IP地址[这里被墙卡住了],然后比对,再决定是否上传新的地址[上传不会被卡]

所以解决方法是直接整个脚本,管你godaddy上记录的IP是什么,我也不用获取,直接上传获得的IP地址就完事了

测试过的解决方法

  • 在openwrt网关路由上使用透明网关的方式代理并且做DDNS,并且设置端口转发到后端群晖,失败
    • (代理强制使用IPV4,但我要用ipv6啊,直接获取不到IPV6地址)
  • 在openwrt网关路由上使用透明网关的方式代理,然后在后面的群晖上设置DDNS-GO的docker容器,成功
    • (但是总不能给家里所有设备都上一层代理吧,太耗代理的流量了,而且开开关关的也麻烦) 
  • 在群晖系统内设置代理服务器,使用旁路由,然后在后面的群晖上设置DDNS-GO的docker容器,失败
    • (似乎群晖设置的代理,只能群晖用?群晖里docker不走代理。群晖可以curl Google,里面的容器curl不通。折腾很久没折腾成)
  • 群晖系统内设置DDNS,不用ddns-go套件,心有余而力不足
    • (群晖系统内要自定义请求串,看godaddy的文档调半天调不通)
  • 直接去github上找了个godaddy的 DDNS 脚本,并且自行修改以完成ipv6的解析上传,成功(用不着设置啥代理服务器,最方便。为什么这个办法看上面的黄底红字)
    •  源脚本 

      https://github.com/gu1ll0me/godaddy-ddns/blob/master/godaddy.sh

完整脚本

注:我测试发现如果用请求api方式虽然可以获取IP地址,但是用这个地址访问不了我的主机,所以改用ifconfig方式获取网卡网址。我把api方式有关命令全部注释了

       

        使用时,无论ipv6还是ipv4,基本上只要更改最上面几个变量,还有中间PublicIP=`ifconfig -a | gr........(地址获取匹配规则)即可

        完成后将其加入crontab计划任务,每10分钟更新一次

#!/bin/bashKey=这里输入api key
Secret=这里输入api Secret
Domain=你的域名
Type=AAAA #ipv4=A ipv6=AAAA
Name=@  # Record name, as seen in the DNS setup page, default @.
TTL=600#这个是缓存IP 用于与目前比对决定是否更新
# Writable path to last known Public IP record cached. Best to place in tmpfs.
CachedIP=/tmp/current_ip#外部api方式检测IP地址。改用ifconfig方式获取,整段注释
#我测试发现可以获取地址但是用这个地址访问不了我的主机,所以改用ifconfig方式获取网址
#CheckURL=http://api.ipify.org.                 #检测ipv4地址
#CheckURL=https://6.ipw.cn/                     #检测ipv6地址
#CheckURL=https://v6.ident.me                   #检测ipv6地址
#CheckURL=https://speed.neu6.edu.cn/getIP.php   #检测ipv6地址
#PublicIP=$(${Curl} -kLs ${CheckURL})#ifconfig方式获取网卡eth0接口IP地址
PublicIP=`ifconfig -a | grep -A 5 eth0 | grep Glo | grep 64 | awk '{print $3}' | awk -F / '{print $1}'` #自己根据自己要获取的网卡和ip自行修改,每个人都不一样。我这里对于我的地址最大化匹配
echo "ifconfig获得IP为 $PublicIP"#检测IP地址合法性
#由于源脚本针对IPV4进行匹配,IPV6会直接进入else显示failed,所以整段注释
#if [ $? -eq 0 ] && [[ "${PublicIP}" =~ [0-9]{1,3}\.[0-9]{1,3} ]];then
#  echo "${PublicIP}!"
#else
#  echo "Failed ${PublicIP}"#exit 1
#fi#curl请求体
Curl=$(/usr/bin/which curl 2>/dev/null)
Touch=$(/usr/bin/which touch 2>/dev/null)
[ "${Curl}" = "" ] &&
echo "Error: Unable to find 'curl CLI'." && exit 1
[ -z "${Key}" ] || [ -z "${Secret}" ] &&
echo "Error: Requires API 'Key/Secret' value." && exit 1
[ -z "${Domain}" ] &&
echo "Error: Requires 'Domain' value." && exit 1
[ -z "${Type}" ] && Type=A
[ -z "${Name}" ] && Name=@
[ -z "${TTL}" ] && TTL=600
[ "${TTL}" -lt 600 ] && TTL=600
${Touch} ${CachedIP} 2>/dev/null
[ $? -ne 0 ] && echo "Error: Can't write to ${CachedIP}." && exit 1
#[ -z "${CheckURL}" ] && CheckURL=http://api.ipify.org #不使用api接口获取ip地址,改为ifconfig获取,注释掉
#echo -n "Checking current 'Public IP' from '${CheckURL}'..." #不使用api接口获取ip地址,改为ifconfig获取,注释掉#CachedIP与PublicIP比对决定是否更新
#使用上方的key,secret,publicIP等参数更新DDNS
#并判断更新是否成功
if [ "$(cat ${CachedIP} 2>/dev/null)" != "${PublicIP}" ];thenecho -n "Checking '${Domain}' IP records from 'GoDaddy'..."Check=$(${Curl} -kLsH"Authorization: sso-key ${Key}:${Secret}" \-H"Content-type: application/json" \https://api.godaddy.com/v1/domains/${Domain}/records/${Type}/${Name} \2>/dev/null|jq -r '.[0].data')if [ $? -eq 0 ] && [ "${Check}" = "${PublicIP}" ];thenecho -n ${Check}>${CachedIP}echo -e "unchanged!\nCurrent 'Public IP' matches 'GoDaddy' records. No update required!"elseecho -en "changed!\nUpdating '${Domain}' ${Check} -> ${PublicIP}..."Update=$(${Curl} -kLsXPUT -H"Authorization: sso-key ${Key}:${Secret}" \-H"Content-type: application/json" \https://api.godaddy.com/v1/domains/${Domain}/records/${Type}/${Name} \-d "[{\"data\":\"${PublicIP}\",\"ttl\":${TTL}}]" 2>/dev/null)if [ $? -eq 0 ] && [ "${Update}" = "" ];thenecho -n ${PublicIP}>${CachedIP}echo "Success!"eval ${SuccessExec}elseecho "Fail! ${Update}"eval ${FailedExec}exit 1fifi
elseecho "Current 'Public IP' matches 'Cached IP' recorded. No update required!"
fi
exit $?

完成后DDNS更新后进行检测

访问

https://api.godaddy.com/v1/domains/你的域名/records/AAAA/@#AAAA为IPV6

这就成功了捏 

嗯,建议以后买域名先看中国大内网能不能访问。虽然这次是解决了,但是真的太折腾了、、、

这篇关于群晖设置DDNS (服务商Godaddy被墙 DDNS-GO无法解析 采用自定义脚本方式完成DDNS更新)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/320527

相关文章

使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)

《使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)》在现代软件开发中,处理JSON数据是一项非常常见的任务,无论是从API接口获取数据,还是将数据存储为JSON格式,解析... 目录1. 背景介绍1.1 jsON简介1.2 实际案例2. 准备工作2.1 环境搭建2.1.1 添加

Jsoncpp的安装与使用方式

《Jsoncpp的安装与使用方式》JsonCpp是一个用于解析和生成JSON数据的C++库,它支持解析JSON文件或字符串到C++对象,以及将C++对象序列化回JSON格式,安装JsonCpp可以通过... 目录安装jsoncppJsoncpp的使用Value类构造函数检测保存的数据类型提取数据对json数

Redis事务与数据持久化方式

《Redis事务与数据持久化方式》该文档主要介绍了Redis事务和持久化机制,事务通过将多个命令打包执行,而持久化则通过快照(RDB)和追加式文件(AOF)两种方式将内存数据保存到磁盘,以防止数据丢失... 目录一、Redis 事务1.1 事务本质1.2 数据库事务与redis事务1.2.1 数据库事务1.

Linux磁盘分区、格式化和挂载方式

《Linux磁盘分区、格式化和挂载方式》本文详细介绍了Linux系统中磁盘分区、格式化和挂载的基本操作步骤和命令,包括MBR和GPT分区表的区别、fdisk和gdisk命令的使用、常见的文件系统格式以... 目录一、磁盘分区表分类二、fdisk命令创建分区1、交互式的命令2、分区主分区3、创建扩展分区,然后

element-ui下拉输入框+resetFields无法回显的问题解决

《element-ui下拉输入框+resetFields无法回显的问题解决》本文主要介绍了在使用ElementUI的下拉输入框时,点击重置按钮后输入框无法回显数据的问题,具有一定的参考价值,感兴趣的... 目录描述原因问题重现解决方案方法一方法二总结描述第一次进入页面,不做任何操作,点击重置按钮,再进行下

Linux中chmod权限设置方式

《Linux中chmod权限设置方式》本文介绍了Linux系统中文件和目录权限的设置方法,包括chmod、chown和chgrp命令的使用,以及权限模式和符号模式的详细说明,通过这些命令,用户可以灵活... 目录设置基本权限命令:chmod1、权限介绍2、chmod命令常见用法和示例3、文件权限详解4、ch

Java中的密码加密方式

《Java中的密码加密方式》文章介绍了Java中使用MD5算法对密码进行加密的方法,以及如何通过加盐和多重加密来提高密码的安全性,MD5是一种不可逆的哈希算法,适合用于存储密码,因为其输出的摘要长度固... 目录Java的密码加密方式密码加密一般的应用方式是总结Java的密码加密方式密码加密【这里采用的

Java中ArrayList的8种浅拷贝方式示例代码

《Java中ArrayList的8种浅拷贝方式示例代码》:本文主要介绍Java中ArrayList的8种浅拷贝方式的相关资料,讲解了Java中ArrayList的浅拷贝概念,并详细分享了八种实现浅... 目录引言什么是浅拷贝?ArrayList 浅拷贝的重要性方法一:使用构造函数方法二:使用 addAll(

Mycat搭建分库分表方式

《Mycat搭建分库分表方式》文章介绍了如何使用分库分表架构来解决单表数据量过大带来的性能和存储容量限制的问题,通过在一对主从复制节点上配置数据源,并使用分片算法将数据分配到不同的数据库表中,可以有效... 目录分库分表解决的问题分库分表架构添加数据验证结果 总结分库分表解决的问题单表数据量过大带来的性能

Linux使用nohup命令在后台运行脚本

《Linux使用nohup命令在后台运行脚本》在Linux或类Unix系统中,后台运行脚本是一项非常实用的技能,尤其适用于需要长时间运行的任务或服务,本文我们来看看如何使用nohup命令在后台... 目录nohup 命令简介基本用法输出重定向& 符号的作用后台进程的特点注意事项实际应用场景长时间运行的任务服