update github.com/docker/libnetwork to f0e46a7 - which bumps it's dependency to github.com/vishvananda/netlink to v1.0.0
Signed-off-by: Andrew Sy Kim <kiman@vmware.com> Co-authored-by: Moriadry <preciousdp11@gmail.com>
This commit is contained in:
2
vendor/github.com/docker/libnetwork/ipvs/BUILD
generated
vendored
2
vendor/github.com/docker/libnetwork/ipvs/BUILD
generated
vendored
@@ -15,11 +15,13 @@ go_library(
|
||||
"//vendor/github.com/sirupsen/logrus:go_default_library",
|
||||
"//vendor/github.com/vishvananda/netlink/nl:go_default_library",
|
||||
"//vendor/github.com/vishvananda/netns:go_default_library",
|
||||
"//vendor/golang.org/x/sys/unix:go_default_library",
|
||||
],
|
||||
"@io_bazel_rules_go//go/platform:linux": [
|
||||
"//vendor/github.com/sirupsen/logrus:go_default_library",
|
||||
"//vendor/github.com/vishvananda/netlink/nl:go_default_library",
|
||||
"//vendor/github.com/vishvananda/netns:go_default_library",
|
||||
"//vendor/golang.org/x/sys/unix:go_default_library",
|
||||
],
|
||||
"//conditions:default": [],
|
||||
}),
|
||||
|
20
vendor/github.com/docker/libnetwork/ipvs/constants.go
generated
vendored
20
vendor/github.com/docker/libnetwork/ipvs/constants.go
generated
vendored
@@ -145,3 +145,23 @@ const (
|
||||
// addresses.
|
||||
SourceHashing = "sh"
|
||||
)
|
||||
|
||||
const (
|
||||
// ConnFwdMask is a mask for the fwd methods
|
||||
ConnFwdMask = 0x0007
|
||||
|
||||
// ConnFwdMasq denotes forwarding via masquerading/NAT
|
||||
ConnFwdMasq = 0x0000
|
||||
|
||||
// ConnFwdLocalNode denotes forwarding to a local node
|
||||
ConnFwdLocalNode = 0x0001
|
||||
|
||||
// ConnFwdTunnel denotes forwarding via a tunnel
|
||||
ConnFwdTunnel = 0x0002
|
||||
|
||||
// ConnFwdDirectRoute denotes forwarding via direct routing
|
||||
ConnFwdDirectRoute = 0x0003
|
||||
|
||||
// ConnFwdBypass denotes forwarding while bypassing the cache
|
||||
ConnFwdBypass = 0x0004
|
||||
)
|
||||
|
34
vendor/github.com/docker/libnetwork/ipvs/ipvs.go
generated
vendored
34
vendor/github.com/docker/libnetwork/ipvs/ipvs.go
generated
vendored
@@ -3,14 +3,13 @@
|
||||
package ipvs
|
||||
|
||||
import (
|
||||
"net"
|
||||
"syscall"
|
||||
"time"
|
||||
|
||||
"fmt"
|
||||
"net"
|
||||
"time"
|
||||
|
||||
"github.com/vishvananda/netlink/nl"
|
||||
"github.com/vishvananda/netns"
|
||||
"golang.org/x/sys/unix"
|
||||
)
|
||||
|
||||
const (
|
||||
@@ -62,6 +61,17 @@ type Destination struct {
|
||||
LowerThreshold uint32
|
||||
ActiveConnections int
|
||||
InactiveConnections int
|
||||
Stats DstStats
|
||||
}
|
||||
|
||||
// DstStats defines IPVS destination (real server) statistics
|
||||
type DstStats SvcStats
|
||||
|
||||
// Config defines IPVS timeout configuration
|
||||
type Config struct {
|
||||
TimeoutTCP time.Duration
|
||||
TimeoutTCPFin time.Duration
|
||||
TimeoutUDP time.Duration
|
||||
}
|
||||
|
||||
// Handle provides a namespace specific ipvs handle to program ipvs
|
||||
@@ -87,16 +97,16 @@ func New(path string) (*Handle, error) {
|
||||
}
|
||||
defer n.Close()
|
||||
|
||||
sock, err := nl.GetNetlinkSocketAt(n, netns.None(), syscall.NETLINK_GENERIC)
|
||||
sock, err := nl.GetNetlinkSocketAt(n, netns.None(), unix.NETLINK_GENERIC)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
// Add operation timeout to avoid deadlocks
|
||||
tv := syscall.NsecToTimeval(netlinkSendSocketTimeout.Nanoseconds())
|
||||
tv := unix.NsecToTimeval(netlinkSendSocketTimeout.Nanoseconds())
|
||||
if err := sock.SetSendTimeout(&tv); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
tv = syscall.NsecToTimeval(netlinkRecvSocketsTimeout.Nanoseconds())
|
||||
tv = unix.NsecToTimeval(netlinkRecvSocketsTimeout.Nanoseconds())
|
||||
if err := sock.SetReceiveTimeout(&tv); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
@@ -184,3 +194,13 @@ func (i *Handle) GetService(s *Service) (*Service, error) {
|
||||
|
||||
return res[0], nil
|
||||
}
|
||||
|
||||
// GetConfig returns the current timeout configuration
|
||||
func (i *Handle) GetConfig() (*Config, error) {
|
||||
return i.doGetConfigCmd()
|
||||
}
|
||||
|
||||
// SetConfig set the current timeout configuration. 0: no change
|
||||
func (i *Handle) SetConfig(c *Config) error {
|
||||
return i.doSetConfigCmd(c)
|
||||
}
|
||||
|
61
vendor/github.com/docker/libnetwork/ipvs/netlink.go
generated
vendored
61
vendor/github.com/docker/libnetwork/ipvs/netlink.go
generated
vendored
@@ -12,6 +12,7 @@ import (
|
||||
"sync"
|
||||
"sync/atomic"
|
||||
"syscall"
|
||||
"time"
|
||||
"unsafe"
|
||||
|
||||
"github.com/sirupsen/logrus"
|
||||
@@ -443,6 +444,12 @@ func assembleDestination(attrs []syscall.NetlinkRouteAttr) (*Destination, error)
|
||||
d.ActiveConnections = int(native.Uint16(attr.Value))
|
||||
case ipvsDestAttrInactiveConnections:
|
||||
d.InactiveConnections = int(native.Uint16(attr.Value))
|
||||
case ipvsSvcAttrStats:
|
||||
stats, err := assembleStats(attr.Value)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
d.Stats = DstStats(stats)
|
||||
}
|
||||
}
|
||||
return &d, nil
|
||||
@@ -497,6 +504,60 @@ func (i *Handle) doGetDestinationsCmd(s *Service, d *Destination) ([]*Destinatio
|
||||
return res, nil
|
||||
}
|
||||
|
||||
// parseConfig given a ipvs netlink response this function will respond with a valid config entry, an error otherwise
|
||||
func (i *Handle) parseConfig(msg []byte) (*Config, error) {
|
||||
var c Config
|
||||
|
||||
//Remove General header for this message
|
||||
hdr := deserializeGenlMsg(msg)
|
||||
attrs, err := nl.ParseRouteAttr(msg[hdr.Len():])
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
for _, attr := range attrs {
|
||||
attrType := int(attr.Attr.Type)
|
||||
switch attrType {
|
||||
case ipvsCmdAttrTimeoutTCP:
|
||||
c.TimeoutTCP = time.Duration(native.Uint32(attr.Value)) * time.Second
|
||||
case ipvsCmdAttrTimeoutTCPFin:
|
||||
c.TimeoutTCPFin = time.Duration(native.Uint32(attr.Value)) * time.Second
|
||||
case ipvsCmdAttrTimeoutUDP:
|
||||
c.TimeoutUDP = time.Duration(native.Uint32(attr.Value)) * time.Second
|
||||
}
|
||||
}
|
||||
|
||||
return &c, nil
|
||||
}
|
||||
|
||||
// doGetConfigCmd a wrapper function to be used by GetConfig
|
||||
func (i *Handle) doGetConfigCmd() (*Config, error) {
|
||||
msg, err := i.doCmdWithoutAttr(ipvsCmdGetConfig)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
res, err := i.parseConfig(msg[0])
|
||||
if err != nil {
|
||||
return res, err
|
||||
}
|
||||
return res, nil
|
||||
}
|
||||
|
||||
// doSetConfigCmd a wrapper function to be used by SetConfig
|
||||
func (i *Handle) doSetConfigCmd(c *Config) error {
|
||||
req := newIPVSRequest(ipvsCmdSetConfig)
|
||||
req.Seq = atomic.AddUint32(&i.seq, 1)
|
||||
|
||||
req.AddData(nl.NewRtAttr(ipvsCmdAttrTimeoutTCP, nl.Uint32Attr(uint32(c.TimeoutTCP.Seconds()))))
|
||||
req.AddData(nl.NewRtAttr(ipvsCmdAttrTimeoutTCPFin, nl.Uint32Attr(uint32(c.TimeoutTCPFin.Seconds()))))
|
||||
req.AddData(nl.NewRtAttr(ipvsCmdAttrTimeoutUDP, nl.Uint32Attr(uint32(c.TimeoutUDP.Seconds()))))
|
||||
|
||||
_, err := execute(i.sock, req, 0)
|
||||
|
||||
return err
|
||||
}
|
||||
|
||||
// IPVS related netlink message format explained
|
||||
|
||||
/* EACH NETLINK MSG is of the below format, this is what we will receive from execute() api.
|
||||
|
Reference in New Issue
Block a user