DDNS 支持通过环境变量进行配置,环境变量的优先级为:命令行参数 > 配置文件 > 环境变量
所有环境变量都以 DDNS_
为前缀,后跟参数名(推荐全大写),点号(.
)替换为下划线(_
)。
export DDNS_xxx=”xxx” 命令作用于当前主机 docker run -e DDNS_xxx=”xxx” 命令作用于容器内
配置参数 | 环境变量名称 | 示例 |
---|---|---|
id |
DDNS_ID 或 ddns_id |
DDNS_ID=12345 |
token |
DDNS_TOKEN 或 ddns_token |
DDNS_TOKEN=mytokenkey |
log.level |
DDNS_LOG_LEVEL 或 ddns_log_level |
DDNS_LOG_LEVEL=DEBUG |
log.file |
DDNS_LOG_FILE 或 ddns_log_file |
DDNS_LOG_FILE=/var/log/ddns.log |
以下是DDNS支持的所有环境变量参数列表:
环境变量 | 类型 | 默认值 | 描述 |
---|---|---|---|
DDNS_ID |
字符串 | 无 | API访问ID或用户标识 |
DDNS_TOKEN |
字符串 | 无 | API授权令牌或密钥 |
DDNS_DNS |
字符串 | dnspod |
DNS服务提供商 |
DDNS_IPV4 |
数组/字符串 | 无 | IPv4域名列表 |
DDNS_IPV6 |
数组/字符串 | 无 | IPv6域名列表 |
DDNS_INDEX4 |
数组/字符串/数字 | default |
IPv4地址获取方式 |
DDNS_INDEX6 |
数组/字符串/数字 | default |
IPv6地址获取方式 |
DDNS_TTL |
整数 | 无 | DNS解析TTL时间(秒) |
DDNS_PROXY |
数组/字符串 | 无 | HTTP代理设置 |
DDNS_CACHE |
布尔值/字符串 | true |
缓存设置 |
DDNS_LOG_LEVEL |
字符串 | INFO |
日志级别 |
DDNS_LOG_FILE |
字符串 | 无 | 日志文件路径 |
DDNS_LOG_FORMAT |
字符串 | %(asctime)s %(levelname)s [%(module)s]: %(message)s |
日志格式字符串 |
DDNS_LOG_DATEFMT |
字符串 | %Y-%m-%dT%H:%M:%S |
日期时间格式字符串 |
环境变量 | 可能的值 | 示例 |
---|---|---|
DDNS_DNS |
dnspod, alidns, cloudflare, dnscom, dnspod_com, he, huaweidns, callback | export DDNS_DNS="cloudflare" |
DDNS_IPV4 |
JSON数组, 逗号分隔的字符串 | export DDNS_IPV4='["example.com", "www.example.com"]' |
DDNS_IPV6 |
JSON数组, 逗号分隔的字符串 | export DDNS_IPV6="example.com,ipv6.example.com" |
DDNS_INDEX4 |
数字、default、public、url:、regex:、cmd:、shell: | export DDNS_INDEX4='["public", "regex:192\\.168\\..*"]' |
DDNS_INDEX6 |
数字、default、public、url:、regex:、cmd:、shell: | export DDNS_INDEX6="public" |
DDNS_PROXY |
IP:端口, DIRECT, 分号分隔的列表 | export DDNS_PROXY="127.0.0.1:1080;DIRECT" |
DDNS_CACHE |
true/false, 文件路径 | export DDNS_CACHE="/path/to/cache.json" |
DDNS_LOG_LEVEL |
DEBUG, INFO, WARNING, ERROR, CRITICAL | export DDNS_LOG_LEVEL="DEBUG" |
DDNS_LOG_FORMAT |
格式字符串 | export DDNS_LOG_FORMAT="%(asctime)s: %(message)s" |
DDNS_LOG_DATEFMT |
日期格式字符串 | export DDNS_LOG_DATEFMT="%Y-%m-%d %H:%M:%S" |
示例:
export DDNS_ID="12345"
# DNSPod 为用户 ID
# 阿里云为 Access Key ID
# CloudFlare 为邮箱地址(使用 Token 时可留空)
# HE.net 可留空
# 华为云为 Access Key ID (AK)
示例:
export DDNS_TOKEN="your_api_token_here"
# 部分平台称为 Secret Key
# 注意:请妥善保管,不要泄露
dnspod
alidns
, cloudflare
, dnscom
, dnspod
, dnspod_com
, he
, huaweidns
, callback
示例:
export DDNS_DNS="alidns" # 阿里云 DNS
export DDNS_DNS="cloudflare" # CloudFlare
export DDNS_DNS="dnspod" # DNSPod 国内版
export DDNS_DNS="dnspod_com" # DNSPod 国际版
export DDNS_DNS="he" # HE.net
export DDNS_DNS="huaweidns" # 华为云 DNS
export DDNS_DNS="callback" # 自定义回调
[]
示例:
# JSON 数组格式(推荐)
export DDNS_IPV4='["example.com", "sub.example.com"]'
# 单个域名
export DDNS_IPV4="example.com"
# 禁用 IPv4 更新
export DDNS_IPV4="[]"
[]
示例:
# 单个域名
export DDNS_IPV6="ipv6.example.com"
# JSON 数组格式(推荐)
export DDNS_IPV6='["ipv6.example.com", "v6.example.com"]'
# python 列表格式
export DDNS_IPV6="['ipv6.example.com', 'v6.example.com']"
# 禁用 IPv6 更新
export DDNS_IPV6="[]"
default
示例:
# 默认方式(系统默认外网 IP)
export DDNS_INDEX4="default"
# 公网 IP
export DDNS_INDEX4="public"
# 指定网卡(第 0 个网卡)
export DDNS_INDEX4="0"
# 自定义 URL 获取
export DDNS_INDEX4="url:http://ip.sb"
# 正则匹配(注意转义)
export DDNS_INDEX4="regex:192\\.168\\..*"
# 执行命令
export DDNS_INDEX4="cmd:curl -s http://ipv4.icanhazip.com"
# Shell 命令
export DDNS_INDEX4="shell:ip route get 8.8.8.8 | awk '{print \$7}'"
# 多种方式组合(JSON 数组)
export DDNS_INDEX4='["public", "regex:172\\..*"]'
# 禁用 IPv4 获取
export DDNS_INDEX4="false"
default
示例:
# 公网 IPv6
export DDNS_INDEX6="public"
# 正则匹配 IPv6
export DDNS_INDEX6="regex:2001:.*"
# 自定义 URL
export DDNS_INDEX6="url:http://ipv6.icanhazip.com"
# 禁用 IPv6 获取
export DDNS_INDEX6="false"
null
(使用 DNS 默认值)示例:
export DDNS_TTL="600" # 10 分钟
export DDNS_TTL="3600" # 1 小时
export DDNS_TTL="86400" # 24 小时
示例:
# 单个代理
export DDNS_PROXY="http://127.0.0.1:1080"
# 多个代理(JSON 数组格式)
export DDNS_PROXY='["http://proxy1:8080", "http://proxy2:8080", "DIRECT"]'
# 分号分隔格式
export DDNS_PROXY="http://proxy1:8080;http://proxy2:8080;DIRECT"
# DIRECT 表示直连
export DDNS_PROXY="DIRECT"
true
示例:
# 启用缓存(默认路径)
export DDNS_CACHE="true"
# 禁用缓存
export DDNS_CACHE="false"
# 自定义缓存文件路径
export DDNS_CACHE="/path/to/ddns.cache"
INFO
CRITICAL
, FATAL
, ERROR
, WARN
, WARNING
, INFO
, DEBUG
, NOTSET
示例:
export DDNS_LOG_LEVEL="DEBUG" # 调试模式
export DDNS_LOG_LEVEL="INFO" # 信息模式
export DDNS_LOG_LEVEL="ERROR" # 仅错误
示例:
export DDNS_LOG_FILE="/var/log/ddns.log"
export DDNS_LOG_FILE="./ddns.log"
%(asctime)s %(levelname)s [%(module)s]: %(message)s
示例:
# 默认格式(含模块名)
export DDNS_LOG_FORMAT="%(asctime)s %(levelname)s [%(module)s]: %(message)s"
# 包含文件名和行号(debug模式下默认格式)
export DDNS_LOG_FORMAT="%(asctime)s %(levelname)s [%(filename)s:%(lineno)d]: %(message)s"
# 简单格式
export DDNS_LOG_FORMAT="%(levelname)s: %(message)s"
%Y-%m-%dT%H:%M:%S
示例:
# ISO 格式(默认)
export DDNS_LOG_DATEFMT="%Y-%m-%dT%H:%M:%S"
# 简短格式
export DDNS_LOG_DATEFMT="%m-%d %H:%M:%S"
# 标准格式
export DDNS_LOG_DATEFMT="%Y-%m-%d %H:%M:%S"
#!/bin/bash
# DNSPod 配置示例
export DDNS_DNS="dnspod"
export DDNS_ID="12345"
export DDNS_TOKEN="your_token_here"
export DDNS_IPV4='["example.com", "www.example.com"]'
export DDNS_IPV6='["ipv6.example.com"]'
export DDNS_TTL="600"
# 运行 DDNS
ddns
docker run -d \
-e DDNS_DNS=dnspod \
-e DDNS_ID=12345 \
-e DDNS_TOKEN=your_token_here \
-e DDNS_IPV4=example.com \
-e DDNS_IPV6='["ipv6.example.com","example.com"]' \
-e DDNS_INDEX4=["public", 0] \
-e DDNS_INDEX6=public \
-e DDNS_TTL=600 \
-e DDNS_LOG_LEVEL=INFO \
-e DDNS_LOG_FORMAT="%(asctime)s %(levelname)s [%(module)s]: %(message)s" \
-e DDNS_LOG_DATEFMT="%Y-%m-%dT%H:%M:%S" \
--network host \
newfuture/ddns
#!/bin/bash
# 阿里云 DNS 高级配置
export DDNS_DNS="alidns"
export DDNS_ID="your_access_key_id"
export DDNS_TOKEN="your_access_key_secret"
# 多域名配置
export DDNS_IPV4='["ddns.example.com", "home.example.com", "server.example.com"]'
export DDNS_IPV6='["ipv6.example.com"]'
# 多种 IP 获取方式
export DDNS_INDEX4='["public", "regex:192\\.168\\.1\\..*", "cmd:curl -s ipv4.icanhazip.com"]'
export DDNS_INDEX6="public"
# 代理和缓存配置
export DDNS_PROXY='["http://proxy.example.com:8080", "DIRECT"]'
export DDNS_CACHE="/home/user/.ddns_cache"
# 日志配置
export DDNS_LOG_LEVEL="DEBUG"
export DDNS_LOG_FILE="/var/log/ddns.log"
export DDNS_LOG_FORMAT="%(asctime)s %(levelname)s [%(filename)s:%(lineno)d]: %(message)s"
export DDNS_LOG_DATEFMT="%Y-%m-%d %H:%M:%S"
# TTL 设置
export DDNS_TTL="300"
# 运行
ddns
index4
, index6
, ipv4
, ipv6
, proxy
等数组参数支持两种格式:
'["item1", "item2"]'
(推荐)"item1,item2"
配置优先级和字段覆盖关系:
DDNS工具中的配置优先级顺序为:命令行参数 > JSON配置文件 > 环境变量
举例说明:
# 环境变量设置
export DDNS_TTL="600"
# JSON配置文件内容
{
"ttl": 300
}
# 命令行参数
ddns --ttl 900
在上述例子中:
ttl=900
ttl=300
ttl=600
另外,JSON配置文件中明确设置为null
的值会覆盖环境变量设置,相当于未设置该值。
大小写兼容: 环境变量名支持大写、小写或混合大小写
DDNS_TOKEN
等敏感信息.env
文件或密钥管理系统DDNS_LOG_LEVEL=DEBUG
获取详细日志信息