Documentation ¶
Index ¶
Constants ¶
const ( // FlagPersistent specify IPVS service session affinity FlagPersistent = 0x1 // FlagHashed specify IPVS service hash flag FlagHashed = 0x2 // IPVSProxyMode is match set up cluster with ipvs proxy model IPVSProxyMode = "ipvs" )
const ( // ModIPVS is the kernel module "ip_vs" ModIPVS string = "ip_vs" // ModIPVSRR is the kernel module "ip_vs_rr" ModIPVSRR string = "ip_vs_rr" // ModIPVSWRR is the kernel module "ip_vs_wrr" ModIPVSWRR string = "ip_vs_wrr" // ModIPVSSH is the kernel module "ip_vs_sh" ModIPVSSH string = "ip_vs_sh" // ModNfConntrackIPV4 is the module "nf_conntrack_ipv4" ModNfConntrackIPV4 string = "nf_conntrack_ipv4" // ModNfConntrack is the kernel module "nf_conntrack" ModNfConntrack string = "nf_conntrack" )
IPVS required kernel modules.
Variables ¶
This section is empty.
Functions ¶
Types ¶
type Interface ¶
type Interface interface { // Flush clears all virtual servers in system. return occurred error immediately. Flush() error // AddVirtualServer creates the specified virtual server. AddVirtualServer(*VirtualServer) error // UpdateVirtualServer updates an already existing virtual server. If the virtual server does not exist, return error. UpdateVirtualServer(*VirtualServer) error // DeleteVirtualServer deletes the specified virtual server. If the virtual server does not exist, return error. DeleteVirtualServer(*VirtualServer) error // Given a partial virtual server, GetVirtualServer will return the specified virtual server information in the system. GetVirtualServer(*VirtualServer) (*VirtualServer, error) // GetVirtualServers lists all virtual servers in the system. GetVirtualServers() ([]*VirtualServer, error) // AddRealServer creates the specified real server for the specified virtual server. AddRealServer(*VirtualServer, *RealServer) error // GetRealServers returns all real servers for the specified virtual server. GetRealServers(*VirtualServer) ([]*RealServer, error) // DeleteRealServer deletes the specified real server from the specified virtual server. DeleteRealServer(*VirtualServer, *RealServer) error // UpdateRealServer updates the specified real server from the specified virtual server. UpdateRealServer(*VirtualServer, *RealServer) error }
Interface is an injectable interface for running ipvs commands. Implementations must be goroutine-safe.
type RealServer ¶
RealServer is an user-oriented definition of an IPVS real server in its entirety.
func (*RealServer) Equal ¶
func (rs *RealServer) Equal(other *RealServer) bool
Equal check the equality of real server. We don't use struct == since it doesn't work because of slice.
func (*RealServer) String ¶
func (rs *RealServer) String() string
type RequiredIPVSKernelModulesAvailableCheck ¶
RequiredIPVSKernelModulesAvailableCheck tests IPVS required kernel modules.
func (RequiredIPVSKernelModulesAvailableCheck) Check ¶
func (r RequiredIPVSKernelModulesAvailableCheck) Check() (warnings, errors []error)
Check try to validates IPVS required kernel modules exists or not. The name of function can not be changed.
func (RequiredIPVSKernelModulesAvailableCheck) Name ¶
func (r RequiredIPVSKernelModulesAvailableCheck) Name() string
Name returns label for RequiredIPVSKernelModulesAvailableCheck
type ServiceFlags ¶
type ServiceFlags uint32
ServiceFlags is used to specify session affinity, ip hash etc.
type VirtualServer ¶
type VirtualServer struct { Address net.IP Protocol string Port uint16 Scheduler string Flags ServiceFlags Timeout uint32 }
VirtualServer is an user-oriented definition of an IPVS virtual server in its entirety.
func (*VirtualServer) Equal ¶
func (svc *VirtualServer) Equal(other *VirtualServer) bool
Equal check the equality of virtual server. We don't use struct == since it doesn't work because of slice.
func (*VirtualServer) String ¶
func (svc *VirtualServer) String() string