Documentation ¶
Index ¶
- Variables
- func CiliumEndpointsInit(ciliumNPClient cilium_cli.CiliumV2Interface, stopCh <-chan struct{})
- func HasCE(ns, name string) (*cilium_api_v2.CiliumEndpoint, bool, error)
- func HasCEWithIdentity(identity string) bool
- func PodsInit(k8sClient kubernetes.Interface, stopCh <-chan struct{})
- func StartSynchronizingServices(shared bool, cfg ServiceSyncConfiguration)
- func UnmanagedPodsInit(k8sClient kubernetes.Interface)
- type ServiceGetter
- type ServiceSyncConfiguration
Constants ¶
This section is empty.
Variables ¶
var ( // CiliumEndpointStore contains all CiliumEndpoint present in k8s. // Warning: The CiliumEndpoints stored in the cache are not intended to be // used for Update operations in k8s as some of its fields were are not // populated. CiliumEndpointStore cache.Indexer // CiliumEndpointsSynced is closed once the CiliumEndpointStore is synced // with k8s. CiliumEndpointsSynced = make(chan struct{}) )
var ( // PodStore has a minimal copy of all pods running in the cluster. // Warning: The pods stored in the cache are not intended to be used for Update // operations in k8s as some of its fields are not populated. PodStore cache.Store // PodStoreSynced is closed once the PodStore is synced with k8s. PodStoreSynced = make(chan struct{}) // UnmanagedPodStore has a minimal copy of the unmanaged kube-dns pods running // in the cluster. // Warning: The pods stored in the cache are not intended to be used for Update // operations in k8s as some of its fields are not populated. UnmanagedPodStore cache.Store // UnmanagedPodStoreSynced is closed once the UnmanagedPodStore is synced // with k8s. UnmanagedPodStoreSynced = make(chan struct{}) )
var (
K8sSvcCache = k8s.NewServiceCache(nil)
)
Functions ¶
func CiliumEndpointsInit ¶
func CiliumEndpointsInit(ciliumNPClient cilium_cli.CiliumV2Interface, stopCh <-chan struct{})
CiliumEndpointsInit starts a CiliumEndpointWatcher
func HasCE ¶
func HasCE(ns, name string) (*cilium_api_v2.CiliumEndpoint, bool, error)
HasCE returns true or false if the Cilium Endpoint store has the endpoint with the given name.
func HasCEWithIdentity ¶
HasCEWithIdentity returns true or false if the Cilium Endpoint store has the given identity.
func PodsInit ¶
func PodsInit(k8sClient kubernetes.Interface, stopCh <-chan struct{})
func StartSynchronizingServices ¶
func StartSynchronizingServices(shared bool, cfg ServiceSyncConfiguration)
StartSynchronizingServices starts a controller for synchronizing services from k8s to kvstore 'shared' specifies whether only shared services are synchronized. If 'false' then all services will be synchronized. For clustermesh we only need to synchronize shared services, while for VM support we need to sync all the services.
func UnmanagedPodsInit ¶
func UnmanagedPodsInit(k8sClient kubernetes.Interface)
Types ¶
type ServiceGetter ¶
type ServiceGetter struct {
// contains filtered or unexported fields
}
ServiceGetter is a wrapper for 2 k8sCaches, its intention is for `shortCutK8sCache` to be used until `k8sSvcCacheSynced` is closed, for which `k8sCache` is started to be used.
func NewServiceGetter ¶
func NewServiceGetter(sc *k8s.ServiceCache) *ServiceGetter
NewServiceGetter returns a new ServiceGetter holding 2 k8sCaches
func (*ServiceGetter) GetServiceIP ¶
func (s *ServiceGetter) GetServiceIP(svcID k8s.ServiceID) *loadbalancer.L3n4Addr
GetServiceIP returns the result of GetServiceIP for `s.shortCutK8sCache` until `k8sSvcCacheSynced` is closed. This is helpful as we can have a shortcut of `s.k8sCache` since we can pre-populate `s.shortCutK8sCache` with the entries that we need until `s.k8sCache` is synchronized with kubernetes.
type ServiceSyncConfiguration ¶
type ServiceSyncConfiguration interface { // LocalClusterName must return the local cluster name LocalClusterName() string utils.ServiceConfiguration }
ServiceSyncConfiguration is the required configuration for StartSynchronizingServices