使用Python自动化国外VPS域名解析:动态DNS更新脚本
文章分类:技术文档 /
创建时间:2025-06-30
在数字化服务搭建中,国外VPS因其稳定的网络环境和灵活的配置,成为个人开发者与中小企业部署网站、API服务的热门选择。但这类VPS常采用动态IP分配机制——IP地址可能随网络波动或服务商策略调整而变化,若未及时更新域名解析记录,用户访问时就会出现"页面无法打开"的尴尬。如何解决这一痛点?用Python写个动态DNS更新脚本是高效方案,本文手把手带你实现。

动态DNS更新的底层逻辑
动态DNS(DDNS)的核心原理类似"自动门牌更换员":定期检测当前公网IP,对比域名解析商(如Cloudflare)后台记录的IP,若发现差异则调用API自动更新。举个生活例子:你搬了新家却没改快递地址,快递就会送错;DDNS就像让快递系统实时获取你的新地址,确保包裹(网络请求)准确送达。
前期准备:工具与权限
要编写脚本,需先准备好基础工具和API权限:
1. Python环境:推荐Python 3.7及以上版本(主流Linux系统已预装,Windows用户可从官网下载安装包);
2. requests库:用于发送HTTP请求,安装命令`pip install requests`(若提示权限问题,Linux/Mac需加`sudo`);
3. 域名解析商API凭证:以Cloudflare为例,需在后台获取:
- API Token(需勾选"Zone:DNS:Edit"权限);
- Zone ID(对应域名的全局标识符,在域名概览页查看);
- DNS Record ID(具体解析记录的ID,在DNS管理页点击记录即可看到)。
Python脚本:从IP检测到自动更新
以下是核心脚本代码,包含IP获取、DNS更新两大功能模块:
import requests
import json
def get_public_ip():
"""获取当前公网IP(调用第三方API)"""
try:
resp = requests.get('https://api.ipify.org?format=json', timeout=5)
return resp.json()['ip'] if resp.status_code == 200 else None
except Exception as e:
print(f"IP获取失败:{str(e)}")
return None
def update_cloudflare_dns(api_token, zone_id, record_id, new_ip):
"""调用Cloudflare API更新A记录"""
headers = {
"Authorization": f"Bearer {api_token}",
"Content-Type": "application/json"
}
payload = json.dumps({
"type": "A",
"name": "your_domain.com", # 替换为你的域名(如blog.example.com)
"content": new_ip,
"ttl": 120, # TTL设为2分钟,更新生效更快
"proxied": False # 关闭CDN代理(根据需求调整)
})
url = f"https://api.cloudflare.com/client/v4/zones/{zone_id}/dns_records/{record_id}"
try:
resp = requests.put(url, headers=headers, data=payload)
if resp.status_code == 200:
print(f"DNS更新成功!新IP:{new_ip}")
else:
print(f"更新失败,状态码:{resp.status_code},错误信息:{resp.text}")
except Exception as e:
print(f"请求异常:{str(e)}")
def main():
# 替换为你的实际凭证
config = {
"api_token": "your_cloudflare_token",
"zone_id": "your_zone_id",
"record_id": "your_record_id"
}
current_ip = get_public_ip()
if current_ip:
update_cloudflare_dns(**config, new_ip=current_ip)
if __name__ == "__main__":
main()
关键功能说明:
- `get_public_ip`函数调用`api.ipify.org`获取公网IP(也可替换为其他可靠API如`icanhazip.com`);
- `update_cloudflare_dns`函数通过PUT请求调用Cloudflare API更新指定A记录,需注意`proxied`参数控制是否启用CDN加速(建站场景建议关闭以直接暴露VPS IP);
- 主函数中需替换`config`字典内的实际凭证(建议后续通过环境变量或配置文件管理,避免硬编码)。
定时执行:让脚本自动"巡逻"
脚本写好后,需设置定时任务实现"自动巡逻"。以Linux系统为例,使用`crontab`工具:
1. 打开定时任务编辑器:`crontab -e`;
2. 添加任务(每15分钟执行一次):
*/15 * * * * /usr/bin/python3 /path/to/your_script.py >> /var/log/ddns.log 2>&1
(`>>`将输出重定向到日志文件,方便排查问题;`2>&1`同步记录错误信息)
注意事项与优化方向
- IP获取可靠性:可增加备用API(如同时请求`https://ipinfo.io/ip`),避免单一API故障导致脚本失效;
- 防重复更新:在脚本中添加"当前IP与DNS记录IP比对"逻辑(调用Cloudflare API获取当前记录IP),仅当IP变化时才发起更新,减少API调用次数;
- 多域名支持:通过循环遍历多个域名的`zone_id`和`record_id`,可扩展为多域名批量更新脚本,特别适合管理多IP站群场景。
通过这套方案,即使国外VPS的IP地址因网络波动频繁变化,你的域名也能始终精准指向最新IP,确保网站、远程服务的稳定访问。对于需要长期维护的技术型站点或企业级应用,这种自动化运维手段能大幅降低人工监控成本,让技术投入更聚焦核心业务。