im, используя следующий модуль:
#!/usr/bin/python
# module for getting the lan ip address of the computer
import os
import socket
if os.name != "nt":
import fcntl
import struct
def get_interface_ip(ifname):
s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
return socket.inet_ntoa(fcntl.ioctl(
s.fileno(),
0x8915, # SIOCGIFADDR
struct.pack('256s', bytes(ifname[:15], 'utf-8'))
# Python 2.7: remove the second argument for the bytes call
)[20:24])
def get_lan_ip():
ip = socket.gethostbyname(socket.gethostname())
if ip.startswith("127.") and os.name != "nt":
interfaces = ["eth0","eth1","eth2","wlan0","wlan1","wifi0","ath0","ath1","ppp0"]
for ifname in interfaces:
try:
ip = get_interface_ip(ifname)
break;
except IOError:
pass
return ip
Протестировано с помощью окон и linux (и не требует дополнительных модулей для них), предназначенных для использования в системах, которые находятся в одной локальной сети на основе IPv4.
Фиксированный список имен интерфейсов не работает для последних версий Linux, которые приняли изменение systemd v197 относительно предсказуемых имен интерфейсов, как указано Alexander . В таких случаях вам нужно вручную заменить список именами интерфейса в вашей системе или использовать другое решение, например netifaces .
Вы указываете localhost, но в Docker каждый localhost является локальным для работающего образа, но не для хоста. Как я вижу, у вас есть порты, связанные с сетью хоста, поэтому вам нужно указать IP-адрес вашей машины вместо localhost.
P.S. Кроме того, почему вы упаковываете приложение с Кассандрой? Это не то, как работает Docker - каждый процесс должен выполняться в отдельном контейнере ...
Каждый узел в Cassandra должен связываться с отдельным IP-адресом, даже на физических серверах или докерах, на которых работают 2 экземпляра / узла.