這是一個建立於 的文章,其中的資訊可能已經有所發展或是發生改變。
Docker Swarm的scheduler會選擇符合要求的node來建立container:
candidates, err := s.selectNodesForContainer(nodes, config, true)
node定義在scheduler/node/node.go:
// Node is an abstract type used by the scheduler.type Node struct { ID string IP string Addr string Name string Labels map[string]string Containers cluster.Containers Images []*cluster.Image UsedMemory int64 UsedCpus int64 TotalMemory int64 TotalCpus int64 HealthIndicator int64}
Cluster.listNodes方法實現如下:
// listNodes returns all validated engines in the cluster, excluding pendingEngines.func (c *Cluster) listNodes() []*node.Node { c.RLock() defer c.RUnlock() out := make([]*node.Node, 0, len(c.engines)) for _, e := range c.engines { node := node.NewNode(e) for _, pc := range c.pendingContainers { if pc.Engine.ID == e.ID && node.Container(pc.Config.SwarmID()) == nil { node.AddContainer(pc.ToContainer()) } } out = append(out, node) } return out}
其實就是從Cluster.engines構建node列表(因為Cluster.pendingEngines還處在待定狀態)。後續scheduler就會從這個node列表中選擇合適的node。