mirror of
https://github.com/moby/moby.git
synced 2022-11-09 12:21:53 -05:00
Merge pull request #2547 from thaJeztah/bump_ipvs
vendor: update moby/ipvs v1.0.1
This commit is contained in:
commit
b1729e8588
2 changed files with 47 additions and 2 deletions
|
@ -58,4 +58,4 @@ go.opencensus.io 9c377598961b706d1542bd2d84d538b5094d596e
|
||||||
gotest.tools 1083505acf35a0bd8a696b26837e1fb3187a7a83 # v2.3.0
|
gotest.tools 1083505acf35a0bd8a696b26837e1fb3187a7a83 # v2.3.0
|
||||||
github.com/google/go-cmp 3af367b6b30c263d47e8895973edcca9a49cf029 # v0.2.0
|
github.com/google/go-cmp 3af367b6b30c263d47e8895973edcca9a49cf029 # v0.2.0
|
||||||
|
|
||||||
github.com/moby/ipvs 8f137da6850a975020f4f739c589d293dd3a9d7b # v1.0.0
|
github.com/moby/ipvs 4566ccea0e08d68e9614c3e7a64a23b850c4bb35 # v1.0.1
|
||||||
|
|
47
libnetwork/vendor/github.com/moby/ipvs/netlink.go
generated
vendored
47
libnetwork/vendor/github.com/moby/ipvs/netlink.go
generated
vendored
|
@ -5,6 +5,7 @@ package ipvs
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
"encoding/binary"
|
"encoding/binary"
|
||||||
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"net"
|
"net"
|
||||||
"os/exec"
|
"os/exec"
|
||||||
|
@ -449,7 +450,7 @@ func assembleDestination(attrs []syscall.NetlinkRouteAttr) (*Destination, error)
|
||||||
d.ActiveConnections = int(native.Uint16(attr.Value))
|
d.ActiveConnections = int(native.Uint16(attr.Value))
|
||||||
case ipvsDestAttrInactiveConnections:
|
case ipvsDestAttrInactiveConnections:
|
||||||
d.InactiveConnections = int(native.Uint16(attr.Value))
|
d.InactiveConnections = int(native.Uint16(attr.Value))
|
||||||
case ipvsSvcAttrStats:
|
case ipvsDestAttrStats:
|
||||||
stats, err := assembleStats(attr.Value)
|
stats, err := assembleStats(attr.Value)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
|
@ -458,6 +459,19 @@ func assembleDestination(attrs []syscall.NetlinkRouteAttr) (*Destination, error)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// in older kernels (< 3.18), the destination address family attribute doesn't exist so we must
|
||||||
|
// assume it based on the destination address provided.
|
||||||
|
if d.AddressFamily == 0 {
|
||||||
|
// we can't check the address family using net stdlib because netlink returns
|
||||||
|
// IPv4 addresses as the first 4 bytes in a []byte of length 16 where as
|
||||||
|
// stdlib expects it as the last 4 bytes.
|
||||||
|
addressFamily, err := getIPFamily(addressBytes)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
d.AddressFamily = addressFamily
|
||||||
|
}
|
||||||
|
|
||||||
// parse Address after parse AddressFamily incase of parseIP error
|
// parse Address after parse AddressFamily incase of parseIP error
|
||||||
if addressBytes != nil {
|
if addressBytes != nil {
|
||||||
ip, err := parseIP(addressBytes, d.AddressFamily)
|
ip, err := parseIP(addressBytes, d.AddressFamily)
|
||||||
|
@ -470,6 +484,37 @@ func assembleDestination(attrs []syscall.NetlinkRouteAttr) (*Destination, error)
|
||||||
return &d, nil
|
return &d, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// getIPFamily parses the IP family based on raw data from netlink.
|
||||||
|
// For AF_INET, netlink will set the first 4 bytes with trailing zeros
|
||||||
|
// 10.0.0.1 -> [10 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0]
|
||||||
|
// For AF_INET6, the full 16 byte array is used:
|
||||||
|
// 2001:db8:3c4d:15::1a00 -> [32 1 13 184 60 77 0 21 0 0 0 0 0 0 26 0]
|
||||||
|
func getIPFamily(address []byte) (uint16, error) {
|
||||||
|
if len(address) == 4 {
|
||||||
|
return syscall.AF_INET, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
if isZeros(address) {
|
||||||
|
return 0, errors.New("could not parse IP family from address data")
|
||||||
|
}
|
||||||
|
|
||||||
|
// assume IPv4 if first 4 bytes are non-zero but rest of the data is trailing zeros
|
||||||
|
if !isZeros(address[:4]) && isZeros(address[4:]) {
|
||||||
|
return syscall.AF_INET, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
return syscall.AF_INET6, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func isZeros(b []byte) bool {
|
||||||
|
for i := 0; i < len(b); i++ {
|
||||||
|
if b[i] != 0 {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
|
||||||
// parseDestination given a ipvs netlink response this function will respond with a valid destination entry, an error otherwise
|
// parseDestination given a ipvs netlink response this function will respond with a valid destination entry, an error otherwise
|
||||||
func (i *Handle) parseDestination(msg []byte) (*Destination, error) {
|
func (i *Handle) parseDestination(msg []byte) (*Destination, error) {
|
||||||
var dst *Destination
|
var dst *Destination
|
||||||
|
|
Loading…
Reference in a new issue