我的站点

一个系统软件工程师的随手涂鸦

Date: 七月 1, 2016

Docker Swarm代码分析笔记(16)——Node结构体

Docker Swarmscheduler会选择符合要求的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

2016年6月简讯

工作方面:
几乎所有的精力都放在学习Docker Swarm上面,目前基本流程已经理清,也贡献了几个小patch。总结一下,这一个月通过学习Docker Swarm带来了下面几个收获:
(1)Docker Swarm代码分析笔记系列
(2)对自己以前完全不懂的HTTP开始有了了解;
(3)写了两篇个人觉得质量还不错的文章:
a)Deploy Docker Swarm cluster on one host:被Docker官方社交媒体转发;
b)A brief intro of TCP keep-alive in Go’s HTTP implementation:被Go Newsletter收录。

业余项目:
(1)继续进行Golang 101 Hacks项目;
(2)尝试使用FreeBSD,自然地,FreeBSD-101-Hacks应运而生;
(3)Unix微信公众号不再使用图片形式发布消息。因为图片看起来感觉还是不舒服,以后一律采用图文消息发布。

生活方面:
(1)去学校办了点事情,尽管已经离开8年,发现这里还是自己感觉最熟悉,最亲切的地方;
(2)在博客上发布了希望去新加坡工作的求职信息,希望可以有公司/个人联系我,呵呵。

Powered by WordPress & Theme by Anders Norén