/aliyun-ddns

阿里云动态域名解析(DDNS)

Primary LanguagePython

动态域名解析(DDNS)

介绍

本应用是基于阿里云SDK进行开发的,可以动态更新阿里云域名的DNS解析,运行环境是 Python 3

利用腾讯位置提供的 API 进行公网 IP 的获取,可以查看如何获取腾讯位置的 API 密钥

由于腾讯位置的 API 免费配额为每日 10000 次,请合理使用

快速开始

程序从环境变量中获取配置,运行前先设置环境变量

环境变量 说明
ALI_ACCESS_KEY_ID 阿里云 ACCESS_KEY_ID(必填)
ALI_ACCESS_KEY_SECRET 阿里云 ACCESS_KEY_SECRET(必填)
ALI_REGION_ID 阿里云区域 ID(默认:cn-hangzhou)
DNS_TYPE 解析类型(默认:A)
DNS_DOMAIN 域名(必填)
DNS_SUB_DOMAIN 二级域名(默认:@)
TENCENT_LBS_KEY 腾讯位置应用 KEY
TENCENT_LBS_SK 腾讯位置应用签名加密 SK

环境字段说明

DNS_TYPE 支持的解析类型:

点击查看官方详细说明

  • A:将域名指向一个IPV4地址
  • CNAME:将域名指向另外一个域名
  • AAAA:将域名指向一个IPV6地址

DNS_SUB_DOMAIN 域名前缀,常见用法有:

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

  • @:直接解析主域名 aliyun.com。

  • *:泛解析,匹配其他所有域名 *.aliyun.com。

  • mail:将域名解析为mail.aliyun.com,通常用于解析邮箱服务器。

  • 二级域名:如:abc.aliyun.com,填写abc。

  • 手机网站:如:m.aliyun.com,填写m。

  • 显性URL:不支持泛解析(泛解析:将所有子域名解析到同一地址)

运行

当设置好环境变量后,使用以下命令安装依赖

pip install -r requeirments.txt

安装依赖后,直接运行 main.py

python main.py

以 Docker 运行

如果你本地没有 python 环境,可以直接使用 docker 来运行本程序

先拉取镜像:

docker pull greycodee/aliyun-ddns

然后运行:

docker run -d -e ALI_ACCESS_KEY_ID="阿里云AK" \
              -e ALI_ACCESS_KEY_SECRET="阿里云AKS" \
              -e DNS_DOMAIN="你的域名" \
              -e DNS_SUB_DOMAIN="二级域名名称" \
              -e TENCENT_LBS_KEY="腾讯位置应用KEY" \
              -e TENCENT_LBS_SK="腾讯位置应用签名SK" \
              greycodee/aliyun-ddns

如果你想看日志的话,可以使用 -v 命令把 docker 容器里的 /root/logs 日志目录挂载出来,这里面存放着程序的运行日志

Dockerfile

在本目录中的 Dockerfile 文件中,更改文件里的环境变量参数为你的数据,具体参数字段含义见上文介绍。 更改完参数后,可以在当前目录使用 docker build 构建命令来构建你自己来镜像

docker build -t 设置镜像标签  .

构建完成后就可以使用命令来运行你刚才构建的镜像了

docker run -d 设置的镜像标签