搭建自己的DDNS服务器教程
创作时间:
作者:
@小白创作中心
搭建自己的DDNS服务器教程
引用
1
来源
1.
https://www.cnblogs.com/darkchen/p/18044915
DDNS(动态域名系统)可以解决ADSL拨号和内网服务器无法提供稳定互联网IP的问题,通过域名绑定动态IP地址,实现域名与IP地址的动态解析。
前置条件
- 拥有公网地址:查看路由器WAN口地址是否是公网地址
- 在GoDaddy上注册一个自己的域名
- 一台海外主机
申请GoDaddy的API密钥
访问GoDaddy开发者平台申请API密钥,并复制保存。
GoDaddy API文档
参考GoDaddy API文档。API请求示例如下:
PUT https://api.godaddy.com/v1/domains/yourdomain.com/records/A/yoursubdomain
Content-Type: application/json
Authorization: sso-key yourkey:yoursecret
[
{
"data": "1.1.1.1",
"port": 65535,
"priority": 0,
"protocol": "string",
"service": "string",
"ttl": 600,
"weight": 0
}
]
Python实现方案
设计思路
- 服务端使用海外主机监听客户端发送的数据,并调用GoDaddy API更新域名解析
- 客户端定期连接服务器的socket,发送需要添加解析的域名
- 服务端验证客户端合法性和socket的源IP是否发生变动,变动后调用API更新解析记录
服务端代码
import requests
import socket
import logging
import os
import sys
import json
def logger():
log_name = os.path.join(base_dir, 'ddns.log')
logger = logging.getLogger()
fh = logging.FileHandler(log_name)
formatter = logging.Formatter("%(asctime)s - %(filename)s[line:%(lineno)d] - %(levelname)s: %(message)s")
fh.setFormatter(formatter)
logger.setLevel(logging.WARNING)
logger.addHandler(fh)
return logger
def sock():
host = '0.0.0.0'
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
address = ('your_server_address', your_port)
s.bind(address)
s.listen(200)
while True:
try:
conn, addr = s.accept()
client_data = conn.recv(1024)
data = json.loads(client_data.decode('utf-8'))
key, domain = data['key'], data['domain']
print(key, domain)
except Exception as e:
log.warning(e)
continue
finally:
conn.close()
if key == 'your_custom_key':
newhost, port = addr
if newhost != host:
host = newhost
ddns(host, domain)
else:
pass
def ddns(host, domain):
try:
url = f'https://api.godaddy.com/v1/domains/yourdomain.com/records/A/{domain}'
headers = {
'accept': 'application/json',
'Content-Type': 'application/json',
'Authorization': 'sso-key yourkey:yoursecret'
}
data = [
{
"data": host,
"port": 65535,
"priority": 0,
"ttl": 600,
"weight": 0
}
]
response = requests.put(url, json=data, headers=headers)
log.warning(response)
except Exception as e:
log.warning(str(e))
if __name__ == '__main__':
base_dir = os.path.dirname(os.path.realpath(sys.argv[0]))
log = logger()
sock()
客户端代码
import socket
import time
import logging
import os
import sys
def logger():
log_name = os.path.join(base_dir, 'ddns.log')
logger = logging.getLogger()
fh = logging.FileHandler(log_name)
formatter = logging.Formatter("%(asctime)s - %(filename)s[line:%(lineno)d] - %(levelname)s: %(message)s")
fh.setFormatter(formatter)
logger.setLevel(logging.WARNING)
logger.addHandler(fh)
return logger
def client(data):
while True:
try:
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.settimeout(3)
s.connect(('your_server_address', your_port))
s.sendall(data.encode())
except Exception as e:
log.warning(str(e))
time.sleep(10)
if __name__ == '__main__':
base_dir = os.path.dirname(os.path.realpath(sys.argv[0]))
data = '{"key":"your_custom_key","domain":"your_subdomain"}'
log = logger()
client(data)
注意事项
- 请将代码中的
yourdomain.com、your_subdomain、yourkey、yoursecret、your_custom_key、your_server_address和your_port等占位符替换为实际值。 - 确保海外主机能够访问GoDaddy API。
- 客户端需要定期运行,建议使用定时任务(如cron)来实现。
热门推荐
冬季感冒常用药阿咖酚散:解热镇痛效果好,但需遵医嘱服用
流感季必备:何济公牌阿咖酚散使用指南
科学预防骨骼肌抽搐:五大实用方法详解
“呼吸困难、手脚发麻”?当心是过度通气综合征
《经典咏流传》揭秘“乐言”:一个名字里的传统文化
双肺肺炎护理指南
酸菜猪肉粉条炖:家常食谱分享,简单几步,美味即刻呈现!
2025双春年,你准备怎么“躲春”?
台湾风水大师梁湘润揭秘:八字命理中的元辰真相
鞠婧祎新剧《花戎》开机,挑战仙侠剧女主展现演艺新突破
鞠婧祎多重身份挑战:从《月鳞绮纪》到品牌代言
《千香引》:鞠婧祎宋威龙三度合作,演绎仙妖魔三界虐恋情深
鞠婧祎《花间令》造型演技双在线,新剧《千香》令人期待
《战锤40K暗潮》游戏狂信徒战斧配装全攻略(重装上阵)
喀什古城开城仪式重装上阵 全新编排备受游客热捧
王者荣耀四大强力打野英雄详解:澜、镜、孙悟空、曜
K甲常规赛打野英雄盘点,杨玉环新晋野王
隐形利剑歼-20:突破技术封锁的航空杰作
“眼皮跳”:传统文化中的吉凶象征与科学解读
杜牧《张好好诗》:书法界的“顶流”之作
论文写作技巧,让你的学术交流更出色
小学奥数有必要学吗
暗恋网名流行语大盘点:53个让你心动的词语
暗恋网名大揭秘:5个甜甜昵称引爆朋友圈
教你打造最撩人暗恋网名:从“月下风流”到“心动轨迹”
王子,晚安:暗恋网名大集合
邯郸市东风剧团:豫剧北派艺术的传承与创新
过量饮用黑咖啡,八大系统受损风险增加
糖尿病饮食六大误区:专家解析从主食到水果的饮食迷思
拜新同的功效与使用指南