diff options
| author | Chris Lu <chris.lu@gmail.com> | 2020-12-14 00:32:17 -0800 |
|---|---|---|
| committer | Chris Lu <chris.lu@gmail.com> | 2020-12-14 00:32:17 -0800 |
| commit | bf5873022d2f78aa2780b458afa18985057e0b60 (patch) | |
| tree | 81f5810adf3320422e8efbe9e3a61c15519c4bff /weed/util | |
| parent | 5cffddebb91d71c395721f02c69279da8e685ed1 (diff) | |
| parent | b7e3ca91727d6ad12f99aa7fd18ad23e13875f6c (diff) | |
| download | seaweedfs-bf5873022d2f78aa2780b458afa18985057e0b60.tar.xz seaweedfs-bf5873022d2f78aa2780b458afa18985057e0b60.zip | |
Merge branch 'master' into support_ssd_volume
Diffstat (limited to 'weed/util')
| -rw-r--r-- | weed/util/network.go | 22 |
1 files changed, 16 insertions, 6 deletions
diff --git a/weed/util/network.go b/weed/util/network.go index 7108cfea6..55a123667 100644 --- a/weed/util/network.go +++ b/weed/util/network.go @@ -7,16 +7,26 @@ import ( ) func DetectedHostAddress() string { - addrs, err := net.InterfaceAddrs() + netInterfaces, err := net.Interfaces() if err != nil { - glog.V(0).Infof("failed to detect ip address: %v", err) + glog.V(0).Infof("failed to detect net interfaces: %v", err) return "" } - for _, a := range addrs { - if ipnet, ok := a.(*net.IPNet); ok && !ipnet.IP.IsLoopback() { - if ipnet.IP.To4() != nil { - return ipnet.IP.String() + for _, netInterface := range netInterfaces { + if (netInterface.Flags & net.FlagUp) == 0 { + continue + } + addrs, err := netInterface.Addrs() + if err != nil { + glog.V(0).Infof("get interface addresses: %v", err) + } + + for _, a := range addrs { + if ipNet, ok := a.(*net.IPNet); ok && !ipNet.IP.IsLoopback() { + if ipNet.IP.To4() != nil { + return ipNet.IP.String() + } } } } |
