Ubuntu技巧-Ubuntu远程访问之电信公网IP

2024-08-22 08:04

本文主要是介绍Ubuntu技巧-Ubuntu远程访问之电信公网IP,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

💡
大家好,我是可夫小子,《小白玩转ChatGPT》专栏作者,关注AIGC、互联网和自媒体。

前面文章介绍了家庭服务器接入外网的三种方式的第一种,今天介绍第二种,即通过获得电脑公网IP,然后再设置动态DNS保持更新。这种方案的成功率与你所使用网络运营商相关,我了解有些地方运营商并不同意给你分配公网IP。

框架

先看一下大概的框架,主要的思路就是自己在家庭路由器上拨号获得外网的IP,然后与服务器的端口绑定,就能通过外网访问家庭服务器了。

获得运营商的公网IP

我家里是使用电脑的网络,我就以电信为例

  1. 与10000客服沟通:电信光猫改成桥接模式,在路由器端重新拨号;

  2. 与10000客服沟通:把外网IP设置为公网IP(他们一般不会同意,说没有了。强烈要求,不给投诉,就可以免费一年)

  3. 重新在路由器上拨号就看得到公网IP(如果判断是不是公网IP,在https://www.ip138.com/查一下本机IP和外网IP是同一个,此时的IP就是公网IP)。同时也可以通过curl ifconfig.me获得外网IP。

  4. 在路由器设置端口转发

到此,已经获得一个公网IP,并与ubuntu服务器做了端口映射。

域名绑定

  1. 购买域名,在阿里云购买一个top域名,大概22元/年。

  2. 阿里云域名映射:添加一条A记录
    此时获得虽然是公网IP,但这个IP是动态,我测试下来大概一周变更一次,就需要写一个脚本,定时更新这个阿里云域名DNS服务,这个下再再讲。

  3. 测试:ssh -p 26919 koffu@xxxxx.top

动态域名设置

之前提到,运营商给发布的IP虽然是公网的,但是动态的,我测试下来大概一周变更一次。所以,接下来我们要设置一个自动化任务,每天固定时间点去获取公网IP,然后通过软件接口去更新阿里云的域名解析的A记录。那么无论你什么时候访问这个域名,都是解析到更新的正常的IP。

先在阿里云的RAM访问控制,创建一个用户。




接下来完成账号验证,就创建成功了,AccessKey ID和Secret生成了,后面需要用到。


点击用户名,进行权限管理,添加DNS解析权限

自动更新的python代码如下,自行替换自己的ID和SECRET

#!/usr/bin/env python
#coding=utf-8# 加载核心SDK
from aliyunsdkcore.client import AcsClient
from aliyunsdkcore.acs_exception.exceptions import ClientException
from aliyunsdkcore.acs_exception.exceptions import ServerException
from datetime import datetime# 加载获取 、 新增、 更新、 删除接口
from aliyunsdkalidns.request.v20150109 import DescribeSubDomainRecordsRequest, AddDomainRecordRequest, UpdateDomainRecordRequest, DeleteDomainRecordRequest# 加载内置模块
import json,urllib# AccessKey 和 Secret  建议使用 RAM 子账户的 KEY 和 SECRET 增加安全性
ID = ''
SECRET = ''# 地区节点 可选地区取决于你的阿里云帐号等级,普通用户只有四个,分别是杭州、上海、深圳、河北,具体参考官网API
regionId = 'cn-hangzhou'# 配置认证信息
client = AcsClient(ID, SECRET, regionId)# 设置主域名
DomainName = ''# 子域名列表  列表参数可根据实际需求增加或减少值
SubDomainList = ['tl']# 获取外网IP   三个地址返回的ip地址格式各不相同,3322 的是最纯净的格式, 备选1为 json格式  备选2 为curl方式获取  两个备选地址都需要对获取值作进一步处理才能使用
def getIp():# 备选地址:1, http://pv.sohu.com/cityjson?ie=utf-8    2,curl -L tool.lu/ipwith urllib.request.urlopen('https://ifconfig.me/') as response:html = response.read()ip = str(html, encoding='utf-8').replace("\n", "")return ip# 查询记录
def getDomainInfo(SubDomain):request = DescribeSubDomainRecordsRequest.DescribeSubDomainRecordsRequest()request.set_accept_format('json')# 设置要查询的记录类型为 A记录   官网支持A / CNAME / MX / AAAA / TXT / NS / SRV / CAA / URL隐性(显性)转发  如果有需要可将该值配置为参数传入request.set_Type("A")# 指定查记的域名 格式为 'test.binghe.com'request.set_SubDomain('tl.agihub.top')response = client.do_action_with_exception(request)response = str(response, encoding='utf-8')# 将获取到的记录转换成json对象并返回return json.loads(response)# 新增记录 (默认都设置为A记录,通过配置set_Type可设置为其他记录)
def addDomainRecord(client,value,rr,domainname):request = AddDomainRecordRequest.AddDomainRecordRequest()request.set_accept_format('json')# request.set_Priority('1')  # MX 记录时的必选参数request.set_TTL('600')       # 可选值的范围取决于你的阿里云账户等级,免费版为 600 - 86400 单位为秒 request.set_Value(value)     # 新增的 ip 地址request.set_Type('A')        # 记录类型request.set_RR(rr)           # 子域名名称  request.set_DomainName(domainname) #主域名# 获取记录信息,返回信息中包含 TotalCount 字段,表示获取到的记录条数 0 表示没有记录, 其他数字为多少表示有多少条相同记录,正常有记录的值应该为1,如果值大于1则应该检查是不是重复添加了相同的记录response = client.do_action_with_exception(request)response = str(response, encoding='utf-8')relsult = json.loads(response)return relsult# 更新记录
def updateDomainRecord(client,value,rr,record_id):request = UpdateDomainRecordRequest.UpdateDomainRecordRequest()request.set_accept_format('json')# request.set_Priority('1')request.set_TTL('600')request.set_Value(value) # 新的ip地址request.set_Type('A')request.set_RR(rr)request.set_RecordId(record_id)  # 更新记录需要指定 record_id ,该字段为记录的唯一标识,可以在获取方法的返回信息中得到该字段的值response = client.do_action_with_exception(request)response = str(response, encoding='utf-8')return response# 删除记录
def delDomainRecord(client,subdomain):info = getDomainInfo(subdomain)if info['TotalCount'] == 0:print('没有相关的记录信息,删除失败!')elif info["TotalCount"] == 1:print('准备删除记录')request = DeleteDomainRecordRequest.DeleteDomainRecordRequest()request.set_accept_format('json')record_id = info["DomainRecords"]["Record"][0]["RecordId"]request.set_RecordId(record_id) # 删除记录需要指定 record_id ,该字段为记录的唯一标识,可以在获取方法的返回信息中得到该字段的值result = client.do_action_with_exception(request)print('删除成功,返回信息:')print(result)else:# 正常不应该有多条相同的记录,如果存在这种情况,应该手动去网站检查核实是否有操作失误print("存在多个相同子域名解析记录值,请核查后再操作!")# 有记录则更新,没有记录则新增
def setDomainRecord(client,value,subname,domainname):info = getDomainInfo(subname + '.' + domainname)if info['TotalCount'] == 0:print('准备添加新记录')add_result = addDomainRecord(client,value,subname,domainname)print(add_result)elif info["TotalCount"] == 1:print('准备更新已有记录')record_id = info["DomainRecords"]["Record"][0]["RecordId"]cur_ip = getIp()old_ip = info["DomainRecords"]["Record"][0]["Value"]print ('当前IP:' + cur_ip + '; 原IP:' + old_ip )if cur_ip == old_ip:print ("新ip与原ip相同,不更新!")else:update_result = updateDomainRecord(client,value,subname,record_id)print('更新成功,返回信息:')print(update_result)else:# 正常不应该有多条相同的记录,如果存在这种情况,应该手动去网站检查核实是否有操作失误print("存在多个相同子域名解析记录值,请核查删除后再操作!")# 获取当前IP
IP = getIp()# 获取当前时间
current_time = datetime.now().strftime("%Y-%m-%d %H:%M:%S")
print('===ready update DNS:' + current_time + '===')# 循环子域名列表进行批量操作
for x in SubDomainList:setDomainRecord(client,IP,x,DomainName)

小结

到此,本文就详细介绍了如何从运营商获取公网IP,并绑定一个域名,同时在服务上跑一个定时任务,运行脚本更新IP和域名的映射关系,实现DDNS。如果有遇到什么问题,欢迎留言讨论

这篇关于Ubuntu技巧-Ubuntu远程访问之电信公网IP的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1095699

相关文章

游戏闪退弹窗提示找不到storm.dll文件怎么办? Stormdll文件损坏修复技巧

《游戏闪退弹窗提示找不到storm.dll文件怎么办?Stormdll文件损坏修复技巧》DLL文件丢失或损坏会导致软件无法正常运行,例如我们在电脑上运行软件或游戏时会得到以下提示:storm.dll... 很多玩家在打开游戏时,突然弹出“找不到storm.dll文件”的提示框,随后游戏直接闪退,这通常是由于

WinForm跨线程访问UI及UI卡死的解决方案

《WinForm跨线程访问UI及UI卡死的解决方案》在WinForm开发过程中,跨线程访问UI控件和界面卡死是常见的技术难题,由于Windows窗体应用程序的UI控件默认只能在主线程(UI线程)上操作... 目录前言正文案例1:直接线程操作(无UI访问)案例2:BeginInvoke访问UI(错误用法)案例

Ubuntu 24.04启用root图形登录的操作流程

《Ubuntu24.04启用root图形登录的操作流程》Ubuntu默认禁用root账户的图形与SSH登录,这是为了安全,但在某些场景你可能需要直接用root登录GNOME桌面,本文以Ubuntu2... 目录一、前言二、准备工作三、设置 root 密码四、启用图形界面 root 登录1. 修改 GDM 配

MySQL 多列 IN 查询之语法、性能与实战技巧(最新整理)

《MySQL多列IN查询之语法、性能与实战技巧(最新整理)》本文详解MySQL多列IN查询,对比传统OR写法,强调其简洁高效,适合批量匹配复合键,通过联合索引、分批次优化提升性能,兼容多种数据库... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析

如何在Ubuntu 24.04上部署Zabbix 7.0对服务器进行监控

《如何在Ubuntu24.04上部署Zabbix7.0对服务器进行监控》在Ubuntu24.04上部署Zabbix7.0监控阿里云ECS服务器,需配置MariaDB数据库、开放10050/1005... 目录软硬件信息部署步骤步骤 1:安装并配置mariadb步骤 2:安装Zabbix 7.0 Server

Ubuntu如何分配​​未使用的空间

《Ubuntu如何分配​​未使用的空间》Ubuntu磁盘空间不足,实际未分配空间8.2G因LVM卷组名称格式差异(双破折号误写)导致无法扩展,确认正确卷组名后,使用lvextend和resize2fs... 目录1:原因2:操作3:报错5:解决问题:确认卷组名称​6:再次操作7:验证扩展是否成功8:问题已解

Python使用vllm处理多模态数据的预处理技巧

《Python使用vllm处理多模态数据的预处理技巧》本文深入探讨了在Python环境下使用vLLM处理多模态数据的预处理技巧,我们将从基础概念出发,详细讲解文本、图像、音频等多模态数据的预处理方法,... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.

一文详解Git中分支本地和远程删除的方法

《一文详解Git中分支本地和远程删除的方法》在使用Git进行版本控制的过程中,我们会创建多个分支来进行不同功能的开发,这就容易涉及到如何正确地删除本地分支和远程分支,下面我们就来看看相关的实现方法吧... 目录技术背景实现步骤删除本地分支删除远程www.chinasem.cn分支同步删除信息到其他机器示例步骤

MySQL中的InnoDB单表访问过程

《MySQL中的InnoDB单表访问过程》:本文主要介绍MySQL中的InnoDB单表访问过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、环境3、访问类型【1】const【2】ref【3】ref_or_null【4】range【5】index【6】