目前国内使用coreos的场景还不多,搜索coreos中文资料基本都大同小异。最近几日再和其它攻城狮讨论问题时,有人提出希望看到一篇介绍coreos和安装方面的文章,正好本人最近也在研究coreos,也就共享一些经验。权当抛砖引玉。
首先咱们明确一下coreos是用来做什么的。coreos也是一款os,但它是一款面向云的轻量级OS。coreos是以linux系统为基础,为了建设数据中心的需要,而从linux底层进行了内核裁减。coreos提供了一系列的机制和工具来保证coreos组建的云环境是安全,可靠和最新的。Coreos设计之初就定位于可以提供一种动态缩放和管理集群的能力,可以方便管理类似google 这种庞大数据中心的集群。
目前支持coreos的云平台有: EC2,DigitalOcean, GCE, Rackspace, Azure, Brightbox 。 支持coreos的虚拟化软件有:vagrant, vmware,QEMU,openstack,Eucalyptus, ISO image.
由此也可以看出国际云平台各厂商一致看好coreos,大有席卷互联网之势。
Coreos有三个最重要的工具,etcd,fleet和docker。下面我们分别介绍这三款工具。
ETCD
etcd是一个开源的分布式键值对存储工具。在每个coreos节点上面运行的etcd,共同组建了coreos集群的共享数据总线。etcd可以保证coreos集群的稳定,可靠。当集群网络出现动荡,或者当前master节点出现异常时,etcd可以优雅的进行master节点的选举工作,同时恢复集群中损失的数据。
分布在各个coreos节点中的app,都可以自由的访问到etcd中的数据。最常见的场景就是etcd存储cluster的metadata,cache setting, cluster logging, feature flags等。
etcd有如下的功能:
- 简单可靠,API丰富(支持http,jason)
- 支持客户端通过SSL认证,保证安全性
- 每个实例可以支持每秒1000次写操作