• 使用Docker容器来源码编译etcd


    背景

      etcd是CoreOS公司开发的分布式键值对存储库。在Kubernetes中,我们需要使用etcd作为所有REST API对象的持久化存储。
      不幸的是,在github的release中,CoreOS将etcd的二进制可执行文件都放在了亚马逊的S3存储上,在国内访问非常慢。因此,我们只能通过源码编译etcd。

    过程

      1. 下载etcd源码。

    $ git clone https://github.com/coreos/etcd.git
    $ cd etcd
    

      2. 根据实际情况,选择合适的版本。如我这里使用的是2.2.1版本。

    $ git checkout -b v2.2.1
    

      3. 编译源码。运行该目录的build可执行文件。

    $ ./build
    

      但是,运行该命令出错,提示找不到context。

    $ ./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。

    $ 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环境,而且不会影响原来的环境,是一种新的思路。

  • 相关阅读:
    12月14日总结观影数据集之大数据分析who
    12月09日总结python对json 数据转换
    12月12日总结观影数据集之大数据分析when
    阅读笔记
    12月11日总结观影数据集之大数据分析what
    12月13日总结where
    12月15日总结观影数据集之大数据分析how
    12月10日总结python数据备份
    12月16日观影大数据分析 how much
    可能的加分项
  • 原文地址:https://www.cnblogs.com/styshoo/p/6624986.html
Copyright © 2020-2023  润新知