Documentation ¶
Index ¶
- Constants
- func AddressCount(network *net.IPNet) float64
- func AppendGwByCidr(gateway, cidrStr string) (string, error)
- func ArpDetectIPConflict(nic, ip string, mac net.HardwareAddr) (net.HardwareAddr, error)
- func ArpResolve(nic, srcIP, dstIP string, timeout time.Duration, maxRetry int) (net.HardwareAddr, int, error)
- func BigInt2Ip(ipInt *big.Int) string
- func CIDRContainIP(cidrStr, ipStr string) bool
- func CIDRGlobalUnicast(cidr string) error
- func CIDROverlap(a, b string) bool
- func CheckCidrs(cidr string) error
- func CheckProtocol(address string) string
- func CheckSystemCIDR(cidrs []string) error
- func CompareVersion(version1 string, version2 string) int
- func ContainsIPs(excludeIP string, ip string) bool
- func ContainsString(slice []string, s string) bool
- func CountIpNums(excludeIPs []string) float64
- func DiffStringSlice(slice1, slice2 []string) []string
- func DoubleQuotedFields(s string) []string
- func ExecuteCommandInContainer(client kubernetes.Interface, cfg *rest.Config, namespace string, ...) (string, string, error)
- func ExecuteWithOptions(client kubernetes.Interface, cfg *rest.Config, options ExecOptions) (string, string, error)
- func ExpandExcludeIPs(excludeIPs []string, cidr string) []string
- func ExternalBridgeName(provider string) string
- func FirstIP(subnet string) (string, error)
- func GatewayContains(gatewayNodeStr, gateway string) bool
- func GenerateMac() string
- func GenerateMergePatchPayload(original, modified runtime.Object) ([]byte, error)
- func GenerateRandomV4IP(cidr string) string
- func GenerateStrategicMergePatchPayload(original, modified runtime.Object) ([]byte, error)
- func GetGwByCidr(cidrStr string) (string, error)
- func GetIpAddrWithMask(ip, cidr string) string
- func GetIpWithoutMask(ipStr string) string
- func GetNodeInternalIP(node v1.Node) (ipv4, ipv6 string)
- func GetStringIP(v4IP, v6IP string) string
- func IPToString(ip string) string
- func InitKlogMetrics()
- func Ip2BigInt(ipStr string) *big.Int
- func IsDefaultNet(defaultNetAnnotation string, attach *types.NetworkSelectionElement) bool
- func IsOvnNetwork(netCfg *types.DelegateNetConf) bool
- func IsStringIn(str string, slice []string) bool
- func IsStringsOverlap(a, b []string) bool
- func IsValidIP(ip string) bool
- func JoinHostPort(host string, port int32) string
- func LastIP(subnet string) (string, error)
- func LogFatalAndExit(err error, format string, a ...interface{})
- func ParsePodNetworkAnnotation(podNetworks, defaultNamespace string) ([]*types.NetworkSelectionElement, error)
- func ProtocolToFamily(protocol string) (int, error)
- func RemoveString(slice []string, s string) (result []string)
- func ServiceClusterIPs(svc v1.Service) []string
- func SetLinkUp(name string) error
- func SplitIpsByProtocol(excludeIps []string) ([]string, []string)
- func SplitStringIP(ipStr string) (string, string)
- func SubnetBroadcast(subnet string) string
- func SubnetNumber(subnet string) string
- func UniqString(a []string) []string
- func ValidateCidrConflict(subnet kubeovnv1.Subnet, subnetList []kubeovnv1.Subnet) error
- func ValidatePodCidr(cidr, ip string) error
- func ValidatePodNetwork(annotations map[string]string) error
- func ValidateSubnet(subnet kubeovnv1.Subnet) error
- func ValidateVpc(vpc *kubeovnv1.Vpc) error
- type ExecOptions
- type IPTableRule
- type LogicalRouter
- type LogicalSwitch
- type NamedPortInfo
- type Port
Constants ¶
View Source
const ( CniTypeName = "kube-ovn" ControllerName = "kube-ovn-controller" AllocatedAnnotation = "ovn.kubernetes.io/allocated" RoutedAnnotation = "ovn.kubernetes.io/routed" MacAddressAnnotation = "ovn.kubernetes.io/mac_address" IpAddressAnnotation = "ovn.kubernetes.io/ip_address" CidrAnnotation = "ovn.kubernetes.io/cidr" GatewayAnnotation = "ovn.kubernetes.io/gateway" IpPoolAnnotation = "ovn.kubernetes.io/ip_pool" BgpAnnotation = "ovn.kubernetes.io/bgp" SnatAnnotation = "ovn.kubernetes.io/snat" EipAnnotation = "ovn.kubernetes.io/eip" EipNameAnnotation = "ovn.kubernetes.io/eip_name" FipNameAnnotation = "ovn.kubernetes.io/fip_name" FipEnableAnnotation = "ovn.kubernetes.io/enable_fip" FipFinalizer = "ovn.kubernetes.io/fip" VipAnnotation = "ovn.kubernetes.io/vip" ChassisAnnotation = "ovn.kubernetes.io/chassis" VpcNatGatewayAnnotation = "ovn.kubernetes.io/vpc_nat_gw" VpcNatGatewayInitAnnotation = "ovn.kubernetes.io/vpc_nat_gw_init" VpcEipsAnnotation = "ovn.kubernetes.io/vpc_eips" VpcFloatingIpMd5Annotation = "ovn.kubernetes.io/vpc_floating_ips" VpcDnatMd5Annotation = "ovn.kubernetes.io/vpc_dnat_md5" VpcSnatMd5Annotation = "ovn.kubernetes.io/vpc_snat_md5" VpcCIDRsAnnotation = "ovn.kubernetes.io/vpc_cidrs" VpcLbAnnotation = "ovn.kubernetes.io/vpc_lb" VpcExternalLabel = "ovn.kubernetes.io/vpc_external" VpcEipLabel = "ovn.kubernetes.io/vpc_eip" VpcEipAnnotation = "ovn.kubernetes.io/vpc_eip" VpcDnatEPortLabel = "ovn.kubernetes.io/vpc_dnat_eport" VpcNatLabel = "ovn.kubernetes.io/vpc_nat" VpcNatAnnotation = "ovn.kubernetes.io/vpc_nat" SwitchLBRuleVipsAnnotation = "ovn.kubernetes.io/switch_lb_vip" LogicalRouterAnnotation = "ovn.kubernetes.io/logical_router" VpcAnnotation = "ovn.kubernetes.io/vpc" Layer2ForwardAnnotationTemplate = "%s.kubernetes.io/layer2_forward" PortSecurityAnnotationTemplate = "%s.kubernetes.io/port_security" PortVipAnnotationTemplate = "%s.kubernetes.io/port_vips" PortSecurityAnnotation = "ovn.kubernetes.io/port_security" NorthGatewayAnnotation = "ovn.kubernetes.io/north_gateway" AllocatedAnnotationSuffix = ".kubernetes.io/allocated" AllocatedAnnotationTemplate = "%s.kubernetes.io/allocated" RoutedAnnotationTemplate = "%s.kubernetes.io/routed" MacAddressAnnotationTemplate = "%s.kubernetes.io/mac_address" IpAddressAnnotationTemplate = "%s.kubernetes.io/ip_address" CidrAnnotationTemplate = "%s.kubernetes.io/cidr" GatewayAnnotationTemplate = "%s.kubernetes.io/gateway" IpPoolAnnotationTemplate = "%s.kubernetes.io/ip_pool" LogicalSwitchAnnotationTemplate = "%s.kubernetes.io/logical_switch" LogicalRouterAnnotationTemplate = "%s.kubernetes.io/logical_router" VlanIdAnnotationTemplate = "%s.kubernetes.io/vlan_id" IngressRateAnnotationTemplate = "%s.kubernetes.io/ingress_rate" EgressRateAnnotationTemplate = "%s.kubernetes.io/egress_rate" SecurityGroupAnnotationTemplate = "%s.kubernetes.io/security_groups" LiveMigrationAnnotationTemplate = "%s.kubernetes.io/allow_live_migration" DefaultRouteAnnotationTemplate = "%s.kubernetes.io/default_route" ProviderNetworkTemplate = "%s.kubernetes.io/provider_network" ProviderNetworkErrMessageTemplate = "%s.provider-network.kubernetes.io/err_mesg" ProviderNetworkReadyTemplate = "%s.provider-network.kubernetes.io/ready" ProviderNetworkExcludeTemplate = "%s.provider-network.kubernetes.io/exclude" ProviderNetworkInterfaceTemplate = "%s.provider-network.kubernetes.io/interface" ProviderNetworkMtuTemplate = "%s.provider-network.kubernetes.io/mtu" MirrorControlAnnotationTemplate = "%s.kubernetes.io/mirror" PodNicAnnotationTemplate = "%s.kubernetes.io/pod_nic_type" VmTemplate = "%s.kubernetes.io/virtualmachine" ExcludeIpsAnnotation = "ovn.kubernetes.io/exclude_ips" IngressRateAnnotation = "ovn.kubernetes.io/ingress_rate" EgressRateAnnotation = "ovn.kubernetes.io/egress_rate" PortNameAnnotation = "ovn.kubernetes.io/port_name" LogicalSwitchAnnotation = "ovn.kubernetes.io/logical_switch" TunnelInterfaceAnnotation = "ovn.kubernetes.io/tunnel_interface" OvsDpTypeLabel = "ovn.kubernetes.io/ovs_dp_type" VpcNameLabel = "ovn.kubernetes.io/vpc" SubnetNameLabel = "ovn.kubernetes.io/subnet" ICGatewayLabel = "ovn.kubernetes.io/ic-gw" ExGatewayLabel = "ovn.kubernetes.io/external-gw" VpcNatGatewayLabel = "ovn.kubernetes.io/vpc-nat-gw" IpReservedLabel = "ovn.kubernetes.io/ip_reserved" VpcNatGatewayNameLabel = "ovn.kubernetes.io/vpc-nat-gw-name" VpcLbLabel = "ovn.kubernetes.io/vpc_lb" VpcDnsNameLabel = "ovn.kubernetes.io/vpc-dns" NetworkPolicyLogAnnotation = "ovn.kubernetes.io/enable_log" ProtocolTCP = "tcp" ProtocolUDP = "udp" ProtocolSCTP = "sctp" NetworkTypeVlan = "vlan" NetworkTypeGeneve = "geneve" NetworkTypeVxlan = "vxlan" NetworkTypeStt = "stt" NodeNic = "ovn0" NodeAllowPriority = "3000" SecurityGroupHighestPriority = "2300" SecurityGroupAllowPriority = "2004" SecurityGroupDropPriority = "2003" IngressAllowPriority = "2001" IngressDefaultDrop = "2000" EgressAllowPriority = "2001" EgressDefaultDrop = "2000" SubnetAllowPriority = "1001" DefaultDropPriority = "1000" GeneveHeaderLength = 100 VxlanHeaderLength = 50 SttHeaderLength = 72 TcpIpHeaderLength = 40 OvnProvider = "ovn" AttachmentNetworkAnnotation = "k8s.v1.cni.cncf.io/networks" DefaultNetworkAnnotation = "v1.multus-cni.io/default-network" SRIOVResourceName = "mellanox.com/cx5_sriov_switchdev" InterconnectionConfig = "ovn-ic-config" ExternalGatewayConfig = "ovn-external-gw-config" InterconnectionSwitch = "ts" ExternalGatewaySwitch = "ovn-external" VpcNatGatewayConfig = "ovn-vpc-nat-gw-config" VpcExternalNet = "ovn-vpc-external-network" VpcLbNetworkAttachment = "ovn-vpc-lb" VpcDnsConfig = "vpc-dns-config" VpcDnsDepTemplate = "vpc-dns-dep" DefaultVpc = "ovn-cluster" DefaultSubnet = "ovn-default" EcmpRouteType = "ecmp" NormalRouteType = "normal" LrpUsingEip = "lrp" FipUsingEip = "fip" SnatUsingEip = "snat" DnatUsingEip = "dnat" OvnFip = "ovn" IptablesFip = "iptables" GatewayRouterPolicyPriority = 29000 NodeRouterPolicyPriority = 30000 SubnetRouterPolicyPriority = 31000 OvnICPolicyPriority = 29500 OffloadType = "offload-port" InternalType = "internal-port" DpdkType = "dpdk-port" HostnameEnv = "KUBE_NODE_NAME" ChasRetryTime = 5 ChasRetryIntev = 1 Vm = "VirtualMachine" VmInstance = "VirtualMachineInstance" MirrorControlAnnotation = "ovn.kubernetes.io/mirror" MirrorDefaultName = "m0" DenyAllSecurityGroup = "kubeovn_deny_all" NetemQosLatencyAnnotation = "ovn.kubernetes.io/latency" NetemQosLimitAnnotation = "ovn.kubernetes.io/limit" NetemQosLossAnnotation = "ovn.kubernetes.io/loss" NetemQosLatencyAnnotationTemplate = "%s.kubernetes.io/latency" NetemQosLimitAnnotationTemplate = "%s.kubernetes.io/limit" NetemQosLossAnnotationTemplate = "%s.kubernetes.io/loss" POD_IP = "POD_IP" ContentType = "application/vnd.kubernetes.protobuf" AcceptContentTypes = "application/vnd.kubernetes.protobuf,application/json" AttachmentProvider = "ovn.kubernetes.io/attachmentprovider" LbSvcPodImg = "ovn.kubernetes.io/lb_svc_img" OvnICKey = "origin" OvnICConnected = "connected" OvnICStatic = "static" MatchV4Src = "ip4.src" MatchV4Dst = "ip4.dst" U2OInterconnName = "u2o-interconnection.%s.%s" U2OExcludeIPAg = "%s.u2o_exclude_ip.%s" )
View Source
const ( DefaultHostVhostuserBaseDir = "/run/openvswitch/vhost_sockets" ChassisLoc = "/etc/openvswitch/system-id.conf" VfioSysDir = "/sys/bus/pci/drivers/vfio-pci" NetSysDir = "/sys/class/net" HtbQos = "linux-htb" NetemQos = "linux-netem" KoDir = "/tmp/" KoENV = "MODULES" RpmENV = "RPMS" )
View Source
const ( IPv4Multicast = "224.0.0.0/4" IPv4Loopback = "127.0.0.1/8" IPv4Broadcast = "255.255.255.255/32" IPv4Zero = "0.0.0.0/32" IPv4LinkLocalUnicast = "169.254.0.0/16" IPv6Unspecified = "::/128" IPv6Loopback = "::1/128" IPv6Multicast = "ff00::/8" IPv6LinkLocalUnicast = "FE80::/10" )
Variables ¶
This section is empty.
Functions ¶
func AddressCount ¶ added in v1.7.0
func AppendGwByCidr ¶ added in v1.7.0
func ArpDetectIPConflict ¶ added in v1.9.19
func ArpDetectIPConflict(nic, ip string, mac net.HardwareAddr) (net.HardwareAddr, error)
https://www.ietf.org/rfc/rfc5227.txt returns MAC of the host if the ip address is in use
func ArpResolve ¶ added in v1.9.19
func CIDRContainIP ¶ added in v1.7.0
func CIDRGlobalUnicast ¶ added in v1.10.7
func CIDROverlap ¶ added in v1.10.7
func CheckCidrs ¶ added in v1.7.0
func CheckProtocol ¶ added in v1.7.0
func CheckSystemCIDR ¶ added in v1.10.7
func CompareVersion ¶ added in v1.11.0
CompareVersion compare two version
func ContainsIPs ¶ added in v1.7.0
func ContainsString ¶ added in v1.7.0
Helper functions to check and remove string from a slice of strings.
func CountIpNums ¶ added in v1.7.0
func DiffStringSlice ¶ added in v0.5.0
func DoubleQuotedFields ¶ added in v1.10.7
func ExecuteCommandInContainer ¶ added in v1.7.0
func ExecuteWithOptions ¶ added in v1.7.0
func ExecuteWithOptions(client kubernetes.Interface, cfg *rest.Config, options ExecOptions) (string, string, error)
func ExpandExcludeIPs ¶ added in v1.7.0
ExpandExcludeIPs used to get exclude ips in range of subnet cidr, excludes cidr addr and broadcast addr
func ExternalBridgeName ¶ added in v1.7.1
ExternalBridgeName returns external bridge name of the provider network
func GatewayContains ¶ added in v1.7.0
func GenerateMergePatchPayload ¶ added in v1.9.17
func GenerateRandomV4IP ¶ added in v1.7.0
func GenerateStrategicMergePatchPayload ¶ added in v1.9.17
func GetGwByCidr ¶ added in v1.7.0
func GetIpAddrWithMask ¶ added in v1.7.0
func GetIpWithoutMask ¶ added in v1.7.0
func GetNodeInternalIP ¶ added in v1.7.0
func GetStringIP ¶ added in v1.7.0
func IPToString ¶ added in v1.7.0
func InitKlogMetrics ¶ added in v1.8.3
func InitKlogMetrics()
func IsDefaultNet ¶ added in v1.7.0
func IsDefaultNet(defaultNetAnnotation string, attach *types.NetworkSelectionElement) bool
func IsOvnNetwork ¶ added in v1.7.0
func IsOvnNetwork(netCfg *types.DelegateNetConf) bool
func IsStringIn ¶ added in v1.7.0
func IsStringsOverlap ¶ added in v1.7.0
IsStringsOverlap check if two string slices are overlapped
func JoinHostPort ¶ added in v1.8.2
func LogFatalAndExit ¶ added in v1.8.15
func ParsePodNetworkAnnotation ¶ added in v1.7.0
func ParsePodNetworkAnnotation(podNetworks, defaultNamespace string) ([]*types.NetworkSelectionElement, error)
func ProtocolToFamily ¶ added in v1.7.0
ProtocolToFamily converts protocol string to netlink family
func RemoveString ¶ added in v1.7.0
func ServiceClusterIPs ¶ added in v1.9.25
func SplitIpsByProtocol ¶ added in v1.7.0
func SplitStringIP ¶ added in v1.7.0
func SubnetBroadcast ¶ added in v1.7.1
func SubnetNumber ¶ added in v1.7.0
func UniqString ¶ added in v1.7.0
UniqString creates an array of string with unique values.
func ValidateCidrConflict ¶ added in v1.9.0
func ValidatePodCidr ¶ added in v1.7.0
func ValidatePodNetwork ¶ added in v0.4.0
func ValidateSubnet ¶ added in v1.7.0
func ValidateVpc ¶ added in v1.11.2
Types ¶
type ExecOptions ¶ added in v1.7.0
type IPTableRule ¶
IPTableRule wraps iptables rule
type LogicalRouter ¶ added in v1.8.0
type LogicalRouter struct { Name string Ports []Port LogicalSwitches []LogicalSwitch }
type LogicalSwitch ¶ added in v1.8.0
type NamedPortInfo ¶ added in v1.11.2
Click to show internal directories.
Click to hide internal directories.