实现阿里云DDNS解析[通俗易懂]

实现阿里云DDNS解析[通俗易懂]我有三种设备,synologyopenwrtraspberryopenwrt1,首先,我在openwrt上实现,这有分为二种方法,其实也是一种方法,1,下载ddns-scripts_aliyun_1.0.0-1_all.ipk这个安装包,直接安装,在app-ddns里面就可以看到阿里去的服务商了,然后输入用户名,密码就可以了。2,使用自定义的脚本也行,raspberrysynology…

大家好,又见面了,我是你们的朋友全栈君。

我有三种设备,synology openwrt raspberry

openwrt

1,首先,我在openwrt上实现, 这有分为二种方法,其实也是一种方法, 1, 下载ddns-scripts_aliyun_1.0.0-1_all.ipk这个安装包,直接安装,在app-ddns里面就可以看到阿里去的服务商了, 然后输入用户名,密码就可以了。

2, 使用自定义的脚本也行, 

raspberry

先安装python库

pip3 install aliyunsdkcore

pip3 install aliyun-python-sdk-alidns

网上下载https://shumeipai.nxez.com/2020/01/10/raspberry-pi-ddns-for-external-network-access.html

ddns.py

修改自己的ID  KEY,主机名。

执行 python3 ddns.py &

synology

在群晖上可以使用2种方法,1, docker, 这个我没有试。  2是使用脚本,我个我试了,比较方便, 网上下载了一个aliyun.sh, 加到群晖的自定义任务里,10分钟运行一次,就可以了,非常简单方便易行。

主机记录:主机记录就是域名前缀,常见用法有:

  • www:解析后的域名为 www.1756260160.com

sh aliyun.sh <id> <secret> <主域名> <主机记录>

sh /var/services/homes/wandersky/aliddns/aliyun.sh L******************74 V0********************CMi **********.com www

脚本命令格式如上。

#!/bin/sh

set -e

if [ $1 ]; then
    ApiId=$1
fi

if [ $2 ]; then
    ApiKey=$2
fi

if [ $3 ]; then
    Domain=$3
fi

if [ -z “$ApiId” -o -z “$ApiKey” -o -z “$Domain” ]; then
    echo “参数缺失”
    exit 1
fi

if [ $4 ]; then
    SubDomain=$4
fi

if [ -z “$SubDomain” ]; then
    SubDomain=”@”
fi

Nonce=$(date -u “+%N”)    # 有bug?
Timestamp=$(date -u “+%Y-%m-%dT%H%%3A%M%%3A%SZ”)    # SB 阿里云, 什么鬼时间格式
Nonce=$Timestamp

urlencode() {

    local raw=”$1″;
    local len=”${#raw}”
    local encoded=””

    for i in `seq 1 $len`; do
        local j=$((i+1))
        local c=$(echo $raw | cut -c$i-$i)

        case $c in [a-zA-Z0-9.~_-]) ;;
            *)
            c=$(printf ‘%%%02X’ “‘$c”) ;;
        esac

        encoded=”$encoded$c”
    done

    echo $encoded
}

# $1 = query string
getSignature() {

    local encodedQuery=$(urlencode $1)
    local message=”GET&%2F&$encodedQuery”
    local sig=$(echo -n “$message” | openssl dgst -sha1 -hmac “$ApiKey&” -binary | openssl base64)
    echo $(urlencode $sig)
}

sendRequest() {

    local sig=$(getSignature $1)
    local result=$(wget -qO- –no-check-certificate –content-on-error “https://alidns.aliyuncs.com?$1&Signature=$sig”)
    echo $result
}

getRecordId() {

    echo “获取 $SubDomain.$Domain 的 IP…” >&2
    local queryString=”AccessKeyId=$ApiId&Action=DescribeSubDomainRecords&Format=JSON&SignatureMethod=HMAC-SHA1&SignatureNonce=$Nonce&SignatureVersion=1.0&SubDomain=$SubDomain.$Domain&Timestamp=$Timestamp&Type=A&Version=2015-01-09″
    local result=$(sendRequest “$queryString”)
    local code=$(echo $result | sed ‘s/.*,”Code”:”\([A-z]*\)”,.*/\1/’)
    local recordId=$(echo $result | sed ‘s/.*,”RecordId”:”\([0-9]*\)”,.*/\1/’)

    if [ “$code” = “$result” ] && [ ! “$recordId” = “$result” ]; then
        local ip=$(echo $result | sed ‘s/.*,”Value”:”\([0-9\.]*\)”,.*/\1/’)

        if [ “$ip” == “$NewIP” ]; then
            echo “IP 无变化, 退出脚本…” >&2
            echo “quit”
        else
            echo $recordId
        fi
    else
        echo “null”
    fi
}

# $1 = record ID, $2 = new IP
updateRecord() {

    local queryString=”AccessKeyId=$ApiId&Action=UpdateDomainRecord&DomainName=$Domain&Format=JSON&RR=$SubDomain&RecordId=$1&SignatureMethod=HMAC-SHA1&SignatureNonce=$Nonce&SignatureVersion=1.0&Timestamp=$Timestamp&Type=A&Value=$2&Version=2015-01-09″
    local result=$(sendRequest $queryString)
    local code=$(echo $result | sed ‘s/.*,”Code”:”\([A-z]*\)”,.*/\1/’)

    if [ “$code” = “$result” ]; then
        echo “$SubDomain.$Domain 已指向 $NewIP.” >&2
    else
        echo “更新失败.” >&2
        echo $result >&2
    fi
}

# $1 = new IP
addRecord() {

    local queryString=”AccessKeyId=$ApiId&Action=AddDomainRecord&DomainName=$Domain&Format=JSON&RR=$SubDomain&SignatureMethod=HMAC-SHA1&SignatureNonce=$Nonce&SignatureVersion=1.0&Timestamp=$Timestamp&Type=A&Value=$1&Version=2015-01-09″
    local result=$(sendRequest $queryString)
    local code=$(echo $result | sed ‘s/.*,”Code”:”\([A-z]*\)”,.*/\1/’)

    if [ “$code” = “$result” ]; then
        echo “$SubDomain.$Domain 已指向 $NewIP.” >&2
    else
        echo “添加失败.” >&2
        echo $result >&2
    fi
}

# Get new IP address
echo “获取当前 IP…”
NewIP=$(wget -qO- –no-check-certificate “http://members.3322.org/dyndns/getip”)
echo “当前 IP 为 $NewIP.”

# Get record ID of sub domain
recordId=$(getRecordId)

if [ ! “$recordId” = “quit” ]; then
    if [ “$recordId” = “null” ]; then
        echo “域名记录不存在, 添加 $SubDomain.$Domain 至 $NewIP…”
        addRecord $NewIP
    else
        echo “域名记录已存在, 更新 $SubDomain.$Domain 至 $NewIP…”
        updateRecord $recordId $NewIP
    fi
fi

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/134242.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • ubuntu进tty1_linux最小系统板

    ubuntu进tty1_linux最小系统板这个系统很迷你。完全符合变态操作控的习惯,如果你很喜欢洁净的系统,那么它就是你的玩具~可以试试自己的能力,是否能够在这系统里DIY一个属于你自己的LINUX。。。转载于:https://www.cnblogs.com/xiaoCon/archive/2013/03/31/2991221.html…

    2025年5月22日
    7
  • 灰色关联度分析(Grey Relation Analysis,GRA)原理详解[通俗易懂]

    灰色关联度分析(Grey Relation Analysis,GRA)原理详解[通俗易懂]释名灰色关联度分析(GreyRelationAnalysis,GRA),是一种多因素统计分析的方法。简单来讲,就是在一个灰色系统中,我们想要了解其中某个我们所关注的某个项目受其他的因素影响的相对强弱,再直白一点,就是说:我们假设以及知道某一个指标可能是与其他的某几个因素相关的,那么我们想知道这个指标与其他哪个因素相对来说更有关系,而哪个因素相对关系弱一点,依次类推,把这些因素排个序,得到一个…

    2022年7月17日
    16
  • Access denied for user ‘root‘@‘localhost‘问题的解决「建议收藏」

    Access denied for user ‘root‘@‘localhost‘问题的解决「建议收藏」问题场景在阿里云上部署了一台服务器,CentOS6.8系统环境,安装了MySql+Nginx+Git+vsftpd等软件,在本地Linux终端以非root账户SSH远程登录服务器,在将项目打包发布时遇到如题所示问题。代码中配置文件里的用户名不是“root”,密码正确,且该用户名和密码是配置在服务端数据库的用户表中的。但是在用浏览器调用跟数据库交互接口时出错:尝试解决网上搜了一堆文章,主要集中在(1…

    2025年7月7日
    2
  • Python – 实现矩阵转置

    Python – 实现矩阵转置有个朋友提出了一个问题:手头上现在有一个二维列表,比如[[1,2,3],[4,5,6],[7,8,9],[10,11,12]],现在要把该二维列表变成为[[1,4,7,10],[2,5,8,11],[3,6,9,12]]。其实不动脑筋的话,用二重循环很容易写出来:#!/usr/bin/envpython3#-*-coding:utf-8-…

    2022年5月5日
    40
  • hdu 4507 数位dp(求和,求平方和)[通俗易懂]

    hdu 4507 数位dp(求和,求平方和)

    2022年1月24日
    40
  • 数据结构算法常见面试考题及答案_数据结构和算法面试题

    数据结构算法常见面试考题及答案_数据结构和算法面试题(1)红黑树的了解(平衡树,二叉搜索树),使用场景把数据结构上几种树集中的讨论一下:1.AVLtree定义:最先发明的自平衡二叉查找树。在AVL树中任何节点的两个子树的高度最大差别为一,所以它也被称为高度平衡树。查找、插入和删除在平均和最坏情况下都是O(logn)。增加和删除可能需要通过一次或多次树旋转来重新平衡这个树。节点的平衡因子是它的左子树的高度减去它的右子树的高度(有时相反)。…

    2022年9月29日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号