Documentation ¶
Overview ¶
Package controller contains code for syncing cloud instances with minion registry
Index ¶
- Variables
- type NodeController
- func (nc *NodeController) GetCloudNodesWithSpec() (*api.NodeList, error)
- func (nc *NodeController) GetStaticNodesWithSpec() (*api.NodeList, error)
- func (nc *NodeController) MonitorNodeStatus() error
- func (nc *NodeController) PopulateAddresses(nodes *api.NodeList) (*api.NodeList, error)
- func (nc *NodeController) RegisterNodes(nodes *api.NodeList, retryCount int, retryInterval time.Duration) error
- func (nc *NodeController) Run(period time.Duration, syncNodeList bool)
- func (nc *NodeController) SyncCloudNodes() error
- type NodeStatusData
Constants ¶
This section is empty.
Variables ¶
Functions ¶
This section is empty.
Types ¶
type NodeController ¶
type NodeController struct {
// contains filtered or unexported fields
}
func NewNodeController ¶
func NewNodeController( cloud cloudprovider.Interface, matchRE string, nodes []string, staticResources *api.NodeResources, kubeClient client.Interface, kubeletClient client.KubeletClient, registerRetryCount int, podEvictionTimeout time.Duration, deletingPodsRateLimiter util.RateLimiter, nodeMonitorGracePeriod time.Duration, nodeStartupGracePeriod time.Duration, nodeMonitorPeriod time.Duration) *NodeController
NewNodeController returns a new node controller to sync instances from cloudprovider.
func (*NodeController) GetCloudNodesWithSpec ¶
func (nc *NodeController) GetCloudNodesWithSpec() (*api.NodeList, error)
GetCloudNodesWithSpec constructs and returns api.NodeList from cloudprovider. If error occurs, an empty NodeList will be returned with a non-nil error info. The method only constructs spec fields for nodes.
func (*NodeController) GetStaticNodesWithSpec ¶
func (nc *NodeController) GetStaticNodesWithSpec() (*api.NodeList, error)
GetStaticNodesWithSpec constructs and returns api.NodeList for static nodes. If error occurs, an empty NodeList will be returned with a non-nil error info. The method only constructs spec fields for nodes.
func (*NodeController) MonitorNodeStatus ¶
func (nc *NodeController) MonitorNodeStatus() error
MonitorNodeStatus verifies node status are constantly updated by kubelet, and if not, post "NodeReady==ConditionUnknown". It also evicts all pods if node is not ready or not reachable for a long period of time.
func (*NodeController) PopulateAddresses ¶
PopulateAddresses queries Address for given list of nodes.
func (*NodeController) RegisterNodes ¶
func (nc *NodeController) RegisterNodes(nodes *api.NodeList, retryCount int, retryInterval time.Duration) error
RegisterNodes registers the given list of nodes, it keeps retrying for `retryCount` times.
func (*NodeController) Run ¶
func (nc *NodeController) Run(period time.Duration, syncNodeList bool)
Run creates initial node list and start syncing instances from cloudprovider, if any. It also starts syncing or monitoring cluster node status.
- RegisterNodes() is called only once to register all initial nodes (from cloudprovider or from command line flag). To make cluster bootstrap faster, node controller populates node addresses.
- SyncCloudNodes() is called periodically (if enabled) to sync instances from cloudprovider. Node created here will only have specs.
- MonitorNodeStatus() is called periodically to incorporate the results of node status pushed from kubelet to master.
func (*NodeController) SyncCloudNodes ¶
func (nc *NodeController) SyncCloudNodes() error
SyncCloudNodes synchronizes the list of instances from cloudprovider to master server.
type NodeStatusData ¶
type NodeStatusData struct {
// contains filtered or unexported fields
}