Python获取当前服务器的公网IP

因为需要将dns的域名指向改为当前服务器,因此需要获取当服务器的公网IP,要在 Python 中获取当前服务器的公网 IP,你可以使用第三方服务提供的 API。这里提供两种常用的方法:

方法一:使用 ipify API

复制代码
import requests

def get_public_ip():
    try:
        response = requests.get('https://api.ipify.org?format=json')
        response.raise_for_status()
        data = response.json()
        return data['ip']
    except requests.exceptions.RequestException as e:
        print(f"获取公网 IP 失败:{e}")
        return None

public_ip = get_public_ip()
if public_ip:
    print(f"当前服务器的公网 IP 是:{public_ip}")
else:
    print("无法获取公网 IP")

方法二:使用 httpbin.org API

复制代码
import requests

def get_public_ip():
    try:
        response = requests.get('http://httpbin.org/ip')
        response.raise_for_status()
        data = response.json()
        return data['origin']
    except requests.exceptions.RequestException as e:
        print(f"获取公网 IP 失败:{e}")
        return None

public_ip = get_public_ip()
if public_ip:
    print(f"当前服务器的公网 IP 是:{public_ip}")
else:
    print("无法获取公网 IP")

这两种方法都使用了 requests 库发送 HTTP 请求到第三方 API 服务,以获取服务器的公网 IP。第一种方法使用了 ipify API,第二种方法使用了 httpbin.org API。

请注意,这些方法依赖于第三方服务,因此需要确保服务器可以访问这些 API 地址。如果服务器位于防火墙或代理之后,可能需要进行额外的网络配置。

在使用这些方法之前,请确保已经安装了 requests 库。你可以使用以下命令安装:

复制代码
pip install requests

如果你的服务器无法直接访问互联网,或者你希望使用其他方式获取公网 IP,可以考虑以下替代方案:

  1. 使用命令行工具,如 curlwget,访问类似的 IP 查询服务。

  2. 如果服务器位于云平台(如 AWS、Google Cloud 或 Azure),可以使用平台提供的 API 或元数据服务获取公网 IP。

  3. 如果你有可靠的外部服务器,可以设置一个定期更新 IP 的脚本,将当前服务器的公网 IP 发送到该外部服务器,然后从外部服务器获取 IP。

选择适合你的方案时,请考虑服务器的网络环境、安全要求和可用的资源。

相关推荐
良木生香8 分钟前
【Linux系统编程】Linux基础指令(1)---一文带你了解Linux的基础指令
linux·运维·服务器·ubuntu·机器学习·系统架构·centos
Cx330❀10 分钟前
深度解析:从原理到实战,一文吃透 Linux 信号机制(上)
大数据·linux·运维·服务器·人工智能·elasticsearch
bestcxx11 分钟前
多个维度对 Java、Python、C#、Go 这四种主流编程语言进行比较
java·python·c#
装杯让你飞起来啊11 分钟前
Kotlin 条件判断 if / when 与智能转换 smart cast
开发语言·python·kotlin
hj28625119 分钟前
Linux基础知识day06
linux·运维·服务器
wangl_9234 分钟前
Modbus RTU 与 Modbus TCP 深入指南-目录
网络·网络协议·tcp/ip·tcp·modbus·rtu
Shadow(⊙o⊙)36 分钟前
linux基础指令2.0
linux·运维·服务器·学习·apache
计算机毕业编程指导师40 分钟前
【大数据毕设推荐】Hadoop+Spark电影票房分析系统,Python+Django全栈实现 毕业设计 选题推荐 毕设选题 数据分析 机器学习 数据挖掘
大数据·hadoop·python·计算机·spark·毕业设计·电影票房
代码中介商1 小时前
Linux TCP/UDP 网络编程完全指南:从基础到实践
linux·网络·tcp/ip
嵌入式×边缘AI:打怪升级日志1 小时前
嵌入式 Linux V4L2 摄像头采集编程(五):MMAP + 亮度实时控制(附完整代码与面试题)
linux·运维·服务器