美文网首页
没固定公网 IP 的内网实现动态域名解析( 阿里云万网解析 )

没固定公网 IP 的内网实现动态域名解析( 阿里云万网解析 )

作者: O无为学长O | 来源:发表于2020-07-17 03:42 被阅读0次

    情景说明

    手里一台thinkpad旧电脑一直在吃灰,最近收拾房间时再次翻了出来,于是想拿来搭建一台个人服务器,方便做各种测试环境测试。
    折腾了一个晚上,将原来的win7升级成了win10,然后又安装了一个ubuntu的双系统(ubuntu是通过硬盘方式安装,不借助光盘或U盘,稍后也会写成文章记录下来,有兴趣的朋友可以去翻翻看)。
    安装完双系统,下了一个XAMPP集成环境包,又想尝试看看能不能把服务器放到公网上,于是就有了这篇文章。
    因为我对于服务器这块比较小白,所以翻了两个晚上的百度才勉强实现了自己的需求。本文章关于实现动态域名解析这块几本是完全按照网上大佬的博客文章来实现的,只有极少量的代码修改,后面会附上大佬博客原文地址

    准备工作

    因为是通过阿里云的域名解析实现的,所以需要有一个阿里云账号,并且有一个已备案的域名。
    满足这两个条件之后,登陆阿里云创建一个 Accesskey ,这个东西将作为我们登录阿里云更新解析的用户,具体创建方法可以参考百度,创建完成后记得保留好生成的 Key 和 Secret:


    979767-20180626140650670-555806177.jpg

    如果你的阿里云账号是有多用户管理的,需要指定用户并且授权 DNS 管理 的权限,否则无法更新,我就是一个个人账号,所以并没有做授权这一步。
    原博主使用的是centOS作为系统环境,而我使用的是ubuntu,目前为止linux系统也只用过ubuntu。

    服务配置

    【1】安装 pip
    我安装的是ubuntu20.04LTS版本,系统已经自带了python3.0,但是没有2.x版本的python, 经过测试发现阿里云的依赖包似乎只能支持python2.x,至少我目前测试的结果是这样,所以为了安全我把 python2 安装上了,版本是2.7.18。
    不同版本的python对应不同版本的 pip,我也同时安装了 pip3 和 pip2,主要是为了省事,安装方法大家自行百度一下,这篇文章并不是在ubuntu下写的,就不倒腾截图了。
    【2】安安装依赖的阿里云 Python 包:前者是阿里云需要的包,后者是模拟请求需要的包

    pip install aliyun-python-sdk-alidns
    pip install requests
    

    【3】编辑更新脚本 ddns_update.py,内容如下:
    备注:脚本复制的是原博文,只是修改了获取ip地址的部分代码,可能因为时间关系,原博文中的代码已经不能正确获取到ip地址了。
    注意:这里解析有一个前提条件,就是你需要修改的那条解析规则必须已经存在,该脚本不能新增,只能修改旧的

    #coding:utf-8
    from aliyunsdkcore import client
    from aliyunsdkalidns.request.v20150109 import DescribeDomainsRequest,DescribeDomainRecordsRequest,UpdateDomainRecordRequest
    import json,os
    
    ######################################################################################
    # 个人配置区域
    #####################################################################################
    # 创建的 AccessKey
    ID="xxxxxxx"
    Secret="xxxxxxx"
    
    # 默认
    RegionId="cn-hangzhou"
    
    # 你的域名
    DomainName="abc.com"
    
    # 你想解析的二级域名,是一个列表,可以写多个
    HostNameList = ['blog', 'test']
    
    # 默认
    Types = "A"
    clt = client.AcsClient(ID,Secret,RegionId)
    ######################################################################################
    
    
    # 动态获取当前公司对外的公网 IP
    def GetLocalIP():
        IPInfo = os.popen('curl -L tool.lu/ip').readlines()
        IP = IPInfo[0][10:25]
        return IP
    
        
    # 更新域名 IP
    def EditDomainRecord(HostName, RecordId, Types, IP):
        UpdateDomainRecord = UpdateDomainRecordRequest.UpdateDomainRecordRequest()
        UpdateDomainRecord.set_accept_format('json')
        UpdateDomainRecord.set_RecordId(RecordId)
        UpdateDomainRecord.set_RR(HostName)
        UpdateDomainRecord.set_Type(Types)
        UpdateDomainRecord.set_TTL('600')
        UpdateDomainRecord.set_Value(IP)
        UpdateDomainRecordJson = json.loads(clt.do_action_with_exception(UpdateDomainRecord))
        print UpdateDomainRecordJson
    
        
    # 获取域名信息
    def GetAllDomainRecords(DomainName, Types, IP):
        DomainRecords = DescribeDomainRecordsRequest.DescribeDomainRecordsRequest()
        DomainRecords.set_accept_format('json')
        DomainRecords.set_DomainName(DomainName)
        DomainRecordsJson = json.loads(clt.do_action_with_exception(DomainRecords))
        
        print DomainRecordsJson['DomainRecords']['Record']
        
        for HostName in HostNameList:
            for x in DomainRecordsJson['DomainRecords']['Record']:
                RR = x['RR']
                Type = x['Type']
                if RR == HostName and Type == Types:
                    RecordId = x['RecordId']
                    print RecordId
                    EditDomainRecord(HostName, RecordId, Types, IP)
    
                    
    IP = GetLocalIP()
    GetAllDomainRecords(DomainName, Types, IP)
    

    【4】添加定时任务: 每两小时更新一次
    备注: 这里也是复制的原博文代码,但我其实并没按这上面的方式来添加定时任务,我是自己手动通过 crontab 命令来添加的定时任务

    # 授执行权限
    chmod 755 /scripts/ddns_update.py
    
    # 添加定时任务
    echo "* */2 * * * /usr/bin/python /scripts/ddns_update.py" >> /var/spool/cron/root
    

    【5】配置完成,按照上面的代码,我手动运行测试是可以成功修改阿里云的解析配置的。

    写在最后

    感谢原博文博主的分享,全都是干货,我几乎就是按部就班地就完成了配置。
    另外其实是还有一个问题:因为现在几乎所有网络服务商都禁止了80和8080端口的原故,导致想要正常访问站点不得不加上一个难看的端口号,百度了很多文章,都说可以使用 nginx 反向代理来隐藏端口号,但因为我对nginx代理完全不懂,暂时无从下手,如果看到文章的你有好的关于这方面的文章分享,欢迎留言告知,感激不尽!

    最后附上原文地址: https://www.cnblogs.com/Dy1an/p/9229074.html

    相关文章

      网友评论

          本文标题:没固定公网 IP 的内网实现动态域名解析( 阿里云万网解析 )

          本文链接:https://www.haomeiwen.com/subject/lknahktx.html