Documentation ¶
Index ¶
- func GetNodeLoopIFInfo(node *telemetrymodel.Node) (*telemetrymodel.NodeInterface, error)
- type K8sDataStore
- func (k *K8sDataStore) CreateK8sNode(name string, PodCIDR string, ProviderID string, Addresses []*node.NodeAddress, ...) error
- func (k *K8sDataStore) CreatePod(name, Namespace string, label []*pod2.Pod_Label, ...) error
- func (k *K8sDataStore) DeleteK8sNode(name string) error
- func (k *K8sDataStore) DeletePod(name string) error
- func (k *K8sDataStore) ReinitializeCache()
- func (k *K8sDataStore) RetrieveAllK8sNodes() []*node.Node
- func (k *K8sDataStore) RetrieveAllPods() []*telemetrymodel.Pod
- func (k *K8sDataStore) RetrieveK8sNode(name string) (*node.Node, error)
- func (k *K8sDataStore) RetrievePod(name string) (*telemetrymodel.Pod, error)
- func (k *K8sDataStore) UpdateK8sNode(name string, PodCIDR string, ProviderID string, Addresses []*node.NodeAddress, ...) error
- func (k *K8sDataStore) UpdatePod(name string, namespace string, label []*pod2.Pod_Label, ...) error
- type SimpleReport
- func (r *SimpleReport) AppendToNodeReport(nodeName string, errString string)
- func (r *SimpleReport) Clear()
- func (r *SimpleReport) GetTimeStamp() time.Time
- func (r *SimpleReport) LogErrAndAppendToNodeReport(nodeName string, errString string)
- func (r *SimpleReport) Print()
- func (r *SimpleReport) RetrieveReport() telemetrymodel.Reports
- func (r *SimpleReport) SetPrefix(pfx string)
- func (r *SimpleReport) SetTimeStamp(time time.Time)
- type VppDataStore
- func (vds *VppDataStore) ClearCache()
- func (vds *VppDataStore) CreateNode(ID uint32, nodeName, IPAddr string) error
- func (vds *VppDataStore) DeleteNode(nodeName string) error
- func (vds *VppDataStore) DumpCache()
- func (vds *VppDataStore) ReinitializeCache()
- func (vds *VppDataStore) RetrieveAllNodes() []*telemetrymodel.Node
- func (vds *VppDataStore) RetrieveNode(nodeName string) (n *telemetrymodel.Node, err error)
- func (vds *VppDataStore) RetrieveNodeByGigEIPAddr(ipAddress string) (*telemetrymodel.Node, error)
- func (vds *VppDataStore) RetrieveNodeByHostIPAddr(ipAddr string) (*telemetrymodel.Node, error)
- func (vds *VppDataStore) RetrieveNodeByLoopIPAddr(ipAddress string) (*telemetrymodel.Node, error)
- func (vds *VppDataStore) RetrieveNodeByLoopMacAddr(macAddress string) (*telemetrymodel.Node, error)
- func (vds *VppDataStore) SetLinuxInterfaces(nodeName string, nInt telemetrymodel.LinuxInterfaces) error
- func (vds *VppDataStore) SetNodeBridgeDomain(nodeName string, nBridge telemetrymodel.NodeBridgeDomains) error
- func (vds *VppDataStore) SetNodeIPARPs(nodeName string, nArps telemetrymodel.NodeIPArpTable) error
- func (vds *VppDataStore) SetNodeIPam(nodeName string, nIPam ipnet.IPAMData) error
- func (vds *VppDataStore) SetNodeInterfaces(nodeName string, nInt telemetrymodel.NodeInterfaces) error
- func (vds *VppDataStore) SetNodeL2Fibs(nodeName string, nL2F telemetrymodel.NodeL2FibTable) error
- func (vds *VppDataStore) SetNodeLiveness(nodeName string, nLive *status.AgentStatus) error
- func (vds *VppDataStore) SetNodeStaticRoutes(nodeName string, nSrs telemetrymodel.NodeStaticRoutes) error
- func (vds *VppDataStore) SetNodeTelemetry(nodeName string, nTele map[string]telemetrymodel.NodeTelemetry) error
- func (vds *VppDataStore) SetSecondaryNodeIndices(node *telemetrymodel.Node) []string
- func (vds *VppDataStore) UpdateNode(ID uint32, nodeName, IPAddr string) error
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func GetNodeLoopIFInfo ¶
func GetNodeLoopIFInfo(node *telemetrymodel.Node) (*telemetrymodel.NodeInterface, error)
GetNodeLoopIFInfo gets the loop interface for the given node
Types ¶
type K8sDataStore ¶
type K8sDataStore struct {
// contains filtered or unexported fields
}
K8sDataStore implements the K8sCache interface. The K8sDataStore structure holds k8s related information separate from vpp related information
func NewK8sDataStore ¶
func NewK8sDataStore() *K8sDataStore
NewK8sDataStore will return a pointer to a new cache which holds various types of k8s related information.
func (*K8sDataStore) CreateK8sNode ¶
func (k *K8sDataStore) CreateK8sNode(name string, PodCIDR string, ProviderID string, Addresses []*node.NodeAddress, NodeInfo *node.NodeSystemInfo) error
CreateK8sNode will add a k8s type node to the Contiv Telemtry cache, making sure there are no duplicates.
func (*K8sDataStore) CreatePod ¶
func (k *K8sDataStore) CreatePod(name, Namespace string, label []*pod2.Pod_Label, IPAddress, hostIPAddress string, container []*pod2.Pod_Container) error
CreatePod adds a pod with the given parameters to the contiv telemetry cache.
func (*K8sDataStore) DeleteK8sNode ¶
func (k *K8sDataStore) DeleteK8sNode(name string) error
DeleteK8sNode deletes the specified node from the K8s cache. If the node is found, the node is deleted; otherwise, an error is returned.
func (*K8sDataStore) DeletePod ¶
func (k *K8sDataStore) DeletePod(name string) error
DeletePod deletes the specified pod from the K8s cache. If the pod is found, the pod is deleted; otherwise, an error is returned.
func (*K8sDataStore) ReinitializeCache ¶
func (k *K8sDataStore) ReinitializeCache()
ReinitializeCache will clear all data from the data store
func (*K8sDataStore) RetrieveAllK8sNodes ¶
func (k *K8sDataStore) RetrieveAllK8sNodes() []*node.Node
RetrieveAllK8sNodes returns a list of all nodes in the data store.
func (*K8sDataStore) RetrieveAllPods ¶
func (k *K8sDataStore) RetrieveAllPods() []*telemetrymodel.Pod
RetrieveAllPods returns a list of all pods in the data store.
func (*K8sDataStore) RetrieveK8sNode ¶
func (k *K8sDataStore) RetrieveK8sNode(name string) (*node.Node, error)
RetrieveK8sNode will retrieve a k8s node from the cache with the given name or return an error if it is not found.gi
func (*K8sDataStore) RetrievePod ¶
func (k *K8sDataStore) RetrievePod(name string) (*telemetrymodel.Pod, error)
RetrievePod will retrieve a pod from the cache with the given name or return an error if it is not found.
func (*K8sDataStore) UpdateK8sNode ¶
func (k *K8sDataStore) UpdateK8sNode(name string, PodCIDR string, ProviderID string, Addresses []*node.NodeAddress, NodeInfo *node.NodeSystemInfo) error
UpdateK8sNode updates the specified node in the K8s cache. If the node is found, its data is updated; otherwise, an error is returned.
func (*K8sDataStore) UpdatePod ¶
func (k *K8sDataStore) UpdatePod(name string, namespace string, label []*pod2.Pod_Label, IPAddress, hostIPAddress string, container []*pod2.Pod_Container) error
UpdatePod updates the specified pod in the K8s cache. If the pod is found, its data is updated; otherwise, an error is returned.
type SimpleReport ¶
type SimpleReport struct { Log logging.Logger Data telemetrymodel.Reports Output io.Writer TimeStamp time.Time Prefix string }
SimpleReport holds error/warning messages recorded during data collection / validation
func NewSimpleReport ¶
func NewSimpleReport(log logging.Logger) *SimpleReport
NewSimpleReport creates a new SimpleReport instance
func (*SimpleReport) AppendToNodeReport ¶
func (r *SimpleReport) AppendToNodeReport(nodeName string, errString string)
AppendToNodeReport appends the string to the status log
func (*SimpleReport) GetTimeStamp ¶
func (r *SimpleReport) GetTimeStamp() time.Time
GetTimeStamp returns the reports time stamp.
func (*SimpleReport) LogErrAndAppendToNodeReport ¶
func (r *SimpleReport) LogErrAndAppendToNodeReport(nodeName string, errString string)
LogErrAndAppendToNodeReport log an error and appends the string to the status log
func (*SimpleReport) RetrieveReport ¶
func (r *SimpleReport) RetrieveReport() telemetrymodel.Reports
RetrieveReport returns the map of report strings
func (*SimpleReport) SetPrefix ¶ added in v1.4.0
func (r *SimpleReport) SetPrefix(pfx string)
SetPrefix sets a prefix that will be henceforth prepended to each error message, so that the source of the error can be easier identified. Each validation routine should set it own prefix.
func (*SimpleReport) SetTimeStamp ¶
func (r *SimpleReport) SetTimeStamp(time time.Time)
SetTimeStamp sets the reports timestamp based on the time passed.
type VppDataStore ¶
type VppDataStore struct { NodeMap map[string]*telemetrymodel.Node LoopIPMap map[string]*telemetrymodel.Node GigEIPMap map[string]*telemetrymodel.Node LoopMACMap map[string]*telemetrymodel.Node HostIPMap map[string]*telemetrymodel.Node // contains filtered or unexported fields }
VppDataStore holds various maps which all take different keys but point to the same underlying value.
func NewVppDataStore ¶
func NewVppDataStore() (n *VppDataStore)
NewVppDataStore returns a reference to a new Vpp data store
func (*VppDataStore) ClearCache ¶
func (vds *VppDataStore) ClearCache()
ClearCache with clear all vpp cache data except for the base NodeMap that contains the discovered nodes..
func (*VppDataStore) CreateNode ¶
func (vds *VppDataStore) CreateNode(ID uint32, nodeName, IPAddr string) error
CreateNode will add a node to the node cache with the given parameters, making sure there are no duplicates.
func (*VppDataStore) DeleteNode ¶
func (vds *VppDataStore) DeleteNode(nodeName string) error
DeleteNode handles node deletions from the cache. The delete callback actually hands off to us the node ID in a string format, so we have to first find the node by its ID, not its name. If the nodeName parameter is invalid, or it does not identify a node that is present in the cache, we return an error.
func (*VppDataStore) DumpCache ¶ added in v1.4.0
func (vds *VppDataStore) DumpCache()
DumpCache prints basic cache information to the console. The intended use of this function is debugging.
func (*VppDataStore) ReinitializeCache ¶
func (vds *VppDataStore) ReinitializeCache()
ReinitializeCache completely re-initializes the cache, clearing all data including the discovered nodes.
func (*VppDataStore) RetrieveAllNodes ¶
func (vds *VppDataStore) RetrieveAllNodes() []*telemetrymodel.Node
RetrieveAllNodes returns an ordered slice of all nodes in a database organized by name.
func (*VppDataStore) RetrieveNode ¶
func (vds *VppDataStore) RetrieveNode(nodeName string) (n *telemetrymodel.Node, err error)
RetrieveNode returns a pointer to a node for the given key. Returns an error if that key is not found.
func (*VppDataStore) RetrieveNodeByGigEIPAddr ¶
func (vds *VppDataStore) RetrieveNodeByGigEIPAddr(ipAddress string) (*telemetrymodel.Node, error)
RetrieveNodeByGigEIPAddr returns a reference to node dat for the specified VPP GigE IP address.
func (*VppDataStore) RetrieveNodeByHostIPAddr ¶
func (vds *VppDataStore) RetrieveNodeByHostIPAddr(ipAddr string) (*telemetrymodel.Node, error)
RetrieveNodeByHostIPAddr returns a reference to node dat for the specified management (host) IP address.
func (*VppDataStore) RetrieveNodeByLoopIPAddr ¶
func (vds *VppDataStore) RetrieveNodeByLoopIPAddr(ipAddress string) (*telemetrymodel.Node, error)
RetrieveNodeByLoopIPAddr returns a reference to node dat for the specified loopback Loop0 IP address.
func (*VppDataStore) RetrieveNodeByLoopMacAddr ¶
func (vds *VppDataStore) RetrieveNodeByLoopMacAddr(macAddress string) (*telemetrymodel.Node, error)
RetrieveNodeByLoopMacAddr returns a reference to node dat for the specified loopback Loop0 MAC address.
func (*VppDataStore) SetLinuxInterfaces ¶ added in v1.5.1
func (vds *VppDataStore) SetLinuxInterfaces(nodeName string, nInt telemetrymodel.LinuxInterfaces) error
SetLinuxInterfaces is a simple function to set a nodes interface given its name.
func (*VppDataStore) SetNodeBridgeDomain ¶
func (vds *VppDataStore) SetNodeBridgeDomain(nodeName string, nBridge telemetrymodel.NodeBridgeDomains) error
SetNodeBridgeDomain is a simple function to set a nodes bridge domain given its name.
func (*VppDataStore) SetNodeIPARPs ¶
func (vds *VppDataStore) SetNodeIPARPs(nodeName string, nArps telemetrymodel.NodeIPArpTable) error
SetNodeIPARPs is a simple function to set a nodes ip arp table given its name.
func (*VppDataStore) SetNodeIPam ¶
func (vds *VppDataStore) SetNodeIPam(nodeName string, nIPam ipnet.IPAMData) error
SetNodeIPam is a simple function to set the node with the given node name's ipam
func (*VppDataStore) SetNodeInterfaces ¶
func (vds *VppDataStore) SetNodeInterfaces(nodeName string, nInt telemetrymodel.NodeInterfaces) error
SetNodeInterfaces is a simple function to set a nodes interface given its name.
func (*VppDataStore) SetNodeL2Fibs ¶
func (vds *VppDataStore) SetNodeL2Fibs(nodeName string, nL2F telemetrymodel.NodeL2FibTable) error
SetNodeL2Fibs is a simple function to set a nodes l2 fibs given its name.
func (*VppDataStore) SetNodeLiveness ¶
func (vds *VppDataStore) SetNodeLiveness(nodeName string, nLive *status.AgentStatus) error
SetNodeLiveness is a simple function to set a nodes liveness given its name.
func (*VppDataStore) SetNodeStaticRoutes ¶
func (vds *VppDataStore) SetNodeStaticRoutes(nodeName string, nSrs telemetrymodel.NodeStaticRoutes) error
SetNodeStaticRoutes is a simple function to set a nodes static routes given its name.
func (*VppDataStore) SetNodeTelemetry ¶
func (vds *VppDataStore) SetNodeTelemetry(nodeName string, nTele map[string]telemetrymodel.NodeTelemetry) error
SetNodeTelemetry is a simple function to set a nodes telemetry data given its name.
func (*VppDataStore) SetSecondaryNodeIndices ¶
func (vds *VppDataStore) SetSecondaryNodeIndices(node *telemetrymodel.Node) []string
SetSecondaryNodeIndices populates many of needed node maps for processing once all of the information has been retrieved. It also checks to make sure that there are no duplicate addresses within the map.
func (*VppDataStore) UpdateNode ¶
func (vds *VppDataStore) UpdateNode(ID uint32, nodeName, IPAddr string) error
UpdateNode handles updates of node data in the cache. If the node identified by 'nodeName' exists, its data is updated and nil error is returned. otherwise, an error is returned.