- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试获取 python 接口(interface)的当前公共(public) ipv6 地址。通过搜索,我发现了netifaces
包,它可以为我提供设备的所有 ipv6 地址列表。
这将包括
现在我说的电流是什么意思?通过隐私扩展 (RFC 4941),一个新地址会定期分配给接口(interface)。旧的全局 ipv6 地址仍然有效,但已标记为已弃用。我想要这个最新的。
这是我尝试过的(出于安全原因混淆了部分地址):
>>> import netifaces
>>> addrs = netifaces.ifaddresses('en0')
>>> for i in addrs[netifaces.AF_INET6]:
... print(i)
...
{'addr': 'fe80::caa:452a:b8cb:862e%en0', 'netmask': 'ffff:ffff:ffff:ffff::/64', 'flags': 1024}
{'addr': '2a02:____:____:9f1:cd8:e__e:e57b:eaa8', 'netmask': 'ffff:ffff:ffff:ffff::/64', 'flags': 1088}
{'addr': '2a02:____:____:9f1:3489:b__7:fb34:101', 'netmask': 'ffff:ffff:ffff:ffff::/64', 'flags': 192}
显然,第一个是链接本地地址。第二个和第三个是全局的,他们有一个标志,我不知道它是什么意思。
有什么方法(可能是通过标志,或 python 中的其他方法)找出当前(临时的,未弃用的)全局地址?
在 Linux 中,我知道我可以解析 ip -o -6 addr show dev interface
的输出并解析该输出,但这不起作用,例如在 Mac 上,如果有适用于它的 python 包,我不喜欢解析其他工具的输出。
编辑:这些标志似乎并不存在于每个操作系统上。上面的输出是在 Mac 上。这是同一网络中 Linux 机器上的输出(正常运行时间更长):
{'addr': '2a02:____:____:9f1:940c:f__f:f9c0:c274', 'netmask': 'ffff:ffff:ffff:ffff::/64'}
{'addr': '2a02:____:____:9f1:395a:6__d:650a:3a11', 'netmask': 'ffff:ffff:ffff:ffff::/64'}
{'addr': '2a02:____:____:9f1:d08a:6__d:d967:d28a', 'netmask': 'ffff:ffff:ffff:ffff::/64'}
{'addr': '2a02:____:____:9f1:9d20:b__7:3edc:96a4', 'netmask': 'ffff:ffff:ffff:ffff::/64'}
{'addr': '2a02:____:____:9f1:b584:d__b:16bf:5dd2', 'netmask': 'ffff:ffff:ffff:ffff::/64'}
{'addr': '2a02:____:____:9f1:61ba:d__b:78d8:197f', 'netmask': 'ffff:ffff:ffff:ffff::/64'}
{'addr': '2a02:____:____:9f1:c1df:7__7:236d:4219', 'netmask': 'ffff:ffff:ffff:ffff::/64'}
{'addr': '2a02:____:____:9f1:d021:4__3:1a44:4947', 'netmask': 'ffff:ffff:ffff:ffff::/64'}
{'addr': 'fe80::17ed:fbf5:a707:2a42%enp4s0', 'netmask': 'ffff:ffff:ffff:ffff::/64'}
编辑 2:
由于我对“当前”地址的含义有些混淆,这就是我的意思。在前面例子的 Linux 机器上:
% ip -o -6 addr show dev enp4s0
2: enp4s0 inet6 2a02:____:____:9f1:940c:f__f:f9c0:c274/64 scope global temporary dynamic \ valid_lft 530760sec preferred_lft 12247sec
2: enp4s0 inet6 2a02:____:____:9f1:395a:6__d:650a:3a11/64 scope global temporary deprecated dynamic \ valid_lft 444473sec preferred_lft 0sec
2: enp4s0 inet6 2a02:____:____:9f1:d08a:6__d:d967:d28a/64 scope global temporary deprecated dynamic \ valid_lft 358187sec preferred_lft 0sec
2: enp4s0 inet6 2a02:____:____:9f1:9d20:b__7:3edc:96a4/64 scope global temporary deprecated dynamic \ valid_lft 271901sec preferred_lft 0sec
2: enp4s0 inet6 2a02:____:____:9f1:b584:d__b:16bf:5dd2/64 scope global temporary deprecated dynamic \ valid_lft 185616sec preferred_lft 0sec
2: enp4s0 inet6 2a02:____:____:9f1:61ba:d__b:78d8:197f/64 scope global temporary deprecated dynamic \ valid_lft 99330sec preferred_lft 0sec
2: enp4s0 inet6 2a02:____:____:9f1:c1df:7__7:236d:4219/64 scope global temporary deprecated dynamic \ valid_lft 13044sec preferred_lft 0sec
2: enp4s0 inet6 2a02:____:____:9f1:d021:4__3:1a44:4947/64 scope global dynamic mngtmpaddr noprefixroute \ valid_lft 2591735sec preferred_lft 604535sec
2: enp4s0 inet6 fe80::17ed:fbf5:a707:2a42/64 scope link noprefixroute \ valid_lft forever preferred_lft forever
显然,所有“临时”地址都是有效地址。但只有一个未被标记为已弃用。该地址将用于出站连接。这就是我想要的。
最佳答案
如果你想要一个公共(public) IPv6 地址,那么试试这个。
socket.getaddrinfo(socket.gethostname(), None, socket.AF_INET6)[1][4][0]
关于python - 获取接口(interface)的最新全局 ipv6 地址,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52081008/
目前部署在 Kubernetes 中的服务,通过 Calico BGP 将 Service 与集群外网络打通,并在外部的 nginx 中配置 Service 地址对外进行服务暴露。经过一段时间的观察
如发现here , 有一种新的 kube 服务是 IPVS 并且有很多负载均衡算法。 唯一的问题是我没有找到指定这些算法的位置。 我的理解: rr:循环法->循环调用后端pod lc:最少连接-> 将
我想尝试这种新的代理模式以及它为我们的一些应用程序提供的各种调度程序。到目前为止,我一直无法找到更改默认模式的方法 iptables至 ipvs在 GKE 节点上。 每个人都说通过--proxy-mo
我想在现有集群中为 IPVS 启用 Kube-proxy 模式。目前,它在 IPtables 上运行。如何在不影响现有工作负载的情况下将其更改为 IPVS? 我已经安装了所有必需的模块来启用它。另外,
我正在开发的应用程序作为 Kubernetes 集群中的部署运行。为此部署创建的 Pod 分布在集群中的各个节点上。我们的应用程序一次只能处理一个 TCP 连接,并且会拒绝进一步的连接。目前,我们使用
我是一名优秀的程序员,十分优秀!