背景
etcd是CoreOS公司开发的分布式键值对存储库。在Kubernetes中,我们需要使用etcd作为所有REST API对象的持久化存储。
不幸的是,在github的release中,CoreOS将etcd的二进制可执行文件都放在了亚马逊的S3存储上,在国内访问非常慢。因此,我们只能通过源码编译etcd。
过程
1. 下载etcd源码。
1
2
|
$ git clone https: //github .com /coreos/etcd .git
$ cd etcd
|
2. 根据实际情况,选择合适的版本。如我这里使用的是2.2.1版本。
1
|
$ git checkout -b v2.2.1
|
3. 编译源码。运行该目录的build可执行文件。
1
|
$ . /build
|
但是,运行该命令出错,提示找不到context。
1
2
3
4
5
6
7
|
$ . /build
gopath /src/github .com /coreos/etcd/cmd/vendor/github .com /coreos/etcd/lease/leasehttp/http .go:19:2: cannot find package "context" in any of:
/root/etcd/gopath/src/github .com /coreos/etcd/cmd/vendor/context (vendor tree)
/usr/local/go/src/context (from $GOROOT)
/root/etcd/gopath/src/context (from $GOPATH)
/go/src/context
/go/src/app/_gopath/src/context
|
网上搜索了一番,原来etcd需要在Golang1.7以上的环境才能编译,而我使用的是Ubuntu16.04,默认的Golang版本是1.6的,没有context包。因此,我们需要安装Golang1.7环境。
4. 使用Docker容器编译。因为我的Golang环境还运行着其他的包,为了不影响其他包运行。我这里直接使用Golang1.7的docker容器来编译etcd。
1
2
3
|
$ sudo docker run - v /home/newbee/etcd/ : /opt/etcd -it -- rm golang:1.7.5 bash
# cd /opt/etcd
# ./build
|
在-v参数中,/home/newbee/etcd是我在Docker host中(也就是我服务器的)的etcd目录,而/opt/etcd是我容器中的映射目录。
注意:从Docker hub下载golang镜像需要一定的时间。下载完成后,就进入了容器中,然后cd到/opt/etcd目录,执行编译。
待编译完成后,查看etcd的bin目录下,是否有可执行文件,如果有,就说明编译成功。然后退出容器,服务器的etcd目录中也有对应的可执行文件了。
总结
etcd需要在Golang1.7以上的版本编译。
Docker容器可以很轻松的提供Golang环境,而且不会影响原来的环境,是一种新的思路。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://www.cnblogs.com/styshoo/p/6624986.html