From 5b3f004edc605e0406f68a83505e25f47600f38c Mon Sep 17 00:00:00 2001 From: lowzj Date: Mon, 24 Dec 2018 16:08:05 +0800 Subject: [PATCH] fix: unreachable supernode ip in p2p-network see issue: #252 Signed-off-by: lowzj --- src/supernode/src/main/docker/Dockerfile | 3 +- .../src/main/docker/sources/start.sh | 2 +- .../supernode/config/SupernodeProperties.java | 55 ++++++++++++++++++- 3 files changed, 57 insertions(+), 3 deletions(-) diff --git a/src/supernode/src/main/docker/Dockerfile b/src/supernode/src/main/docker/Dockerfile index af8e2e517..d919cfa1c 100644 --- a/src/supernode/src/main/docker/Dockerfile +++ b/src/supernode/src/main/docker/Dockerfile @@ -23,5 +23,6 @@ ADD supernode.jar supernode.jar EXPOSE 8001 8002 -ENTRYPOINT ["/root/start.sh"] +CMD ["-Dsupernode.advertiseIp="] +ENTRYPOINT /root/start.sh $0 $@ diff --git a/src/supernode/src/main/docker/sources/start.sh b/src/supernode/src/main/docker/sources/start.sh index 99c19afab..56754fc80 100755 --- a/src/supernode/src/main/docker/sources/start.sh +++ b/src/supernode/src/main/docker/sources/start.sh @@ -2,4 +2,4 @@ nginx -java -Djava.security.egd=file:/dev/./urandom -jar supernode.jar \ No newline at end of file +java -Djava.security.egd=file:/dev/./urandom "$@" -jar supernode.jar diff --git a/src/supernode/src/main/java/com/dragonflyoss/dragonfly/supernode/config/SupernodeProperties.java b/src/supernode/src/main/java/com/dragonflyoss/dragonfly/supernode/config/SupernodeProperties.java index 68956ae90..841091af3 100644 --- a/src/supernode/src/main/java/com/dragonflyoss/dragonfly/supernode/config/SupernodeProperties.java +++ b/src/supernode/src/main/java/com/dragonflyoss/dragonfly/supernode/config/SupernodeProperties.java @@ -17,16 +17,21 @@ package com.dragonflyoss.dragonfly.supernode.config; import javax.annotation.PostConstruct; +import java.net.Inet4Address; +import java.net.InetAddress; +import java.net.NetworkInterface; import java.nio.file.Files; import java.nio.file.Paths; import java.util.ArrayList; +import java.util.Enumeration; import java.util.List; -import com.dragonflyoss.dragonfly.supernode.common.Constants; import com.alibaba.fastjson.JSON; +import com.dragonflyoss.dragonfly.supernode.common.Constants; import lombok.Data; import lombok.extern.slf4j.Slf4j; +import org.apache.commons.lang3.StringUtils; import org.springframework.boot.context.properties.ConfigurationProperties; /** @@ -68,6 +73,12 @@ public class SupernodeProperties { */ private String dfgetPath = Constants.DFGET_PATH; + /** + * The advertise ip is used to set the ip that we advertise to other peer in the p2p-network. + * By default, the first non-loop address is advertised. + */ + private String advertiseIp; + @PostConstruct public void init() { String cdnHome = baseHome + "/repo"; @@ -82,6 +93,48 @@ public void init() { log.error("create repo dir error", e); System.exit(1); } + + setLocalIp(); + log.info("cluster members: {}", JSON.toJSONString(cluster)); } + + private void setLocalIp() { + if (StringUtils.isNotBlank(advertiseIp)) { + Constants.localIp = advertiseIp; + Constants.generateNodeCid(); + log.info("init local ip of supernode, use ip:{}", Constants.localIp); + } else { + List ips = getAllIps(); + if (!ips.isEmpty()) { + Constants.localIp = ips.get(0); + Constants.generateNodeCid(); + } + log.info("init local ip of supernode, ip list:{}, use ip:{}", + JSON.toJSONString(ips), Constants.localIp); + } + } + + private List getAllIps() { + List ips = new ArrayList(); + try { + Enumeration allNetInterfaces = NetworkInterface + .getNetworkInterfaces(); + while (allNetInterfaces.hasMoreElements()) { + NetworkInterface netInterface = allNetInterfaces.nextElement(); + Enumeration addresses = netInterface + .getInetAddresses(); + while (addresses.hasMoreElements()) { + InetAddress ip = addresses.nextElement(); + if (ip instanceof Inet4Address && !ip.isAnyLocalAddress() + && !ip.isLoopbackAddress()) { + ips.add(ip.getHostAddress()); + } + } + } + } catch (Exception e) { + log.error("getAllIps error:{}", e.getMessage(), e); + } + return ips; + } }