使用Docker镜像部署etcd集群

使用Docker镜像部署etcd集群

 

参考:

官方参考

https://github.com/coreos/etcd/blob/master/Documentation/op-guide/container.md#docker

etcd使用

http://blog.csdn.net/u010424605/article/details/44592533

docker网络配置

http://www.infoq.com/cn/articles/docker-network-and-pipework-open-source-explanation-practice/

 

etcd版本,当前最新版v3.1.0

Docker启动脚本

启动三个容器,指定每个容器的IP

本样例是将三个容器放在同一台物理机上进行实验,实际应用中需要部署到各自不同的物理机上(可使用--net=host标记让容器使用宿主机网络)。

使用docker inspect命令查看物理机上docker0的网关,然后配置三个ip地址HOST_1~3

使用三个容器别名etcd1~3

 

 

# For each machine

ETCD_VERSION=v3.1.0

TOKEN=my-etcd-token

CLUSTER_STATE=new

NAME_1=etcd-node-0

NAME_2=etcd-node-1

NAME_3=etcd-node-2

HOST_1=172.17.0.2

HOST_2=172.17.0.3

HOST_3=172.17.0.4

CLUSTER=${NAME_1}=http://${HOST_1}:2380,${NAME_2}=http://${HOST_2}:2380,${NAME_3}=http://${HOST_3}:2380

 

# For node 1

THIS_NAME=${NAME_1}

THIS_IP=${HOST_1}

docker run -d --name etcd1 quay.io/coreos/etcd:${ETCD_VERSION} \

    /usr/local/bin/etcd \

    --data-dir=data.etcd --name ${THIS_NAME} \

    --initial-advertise-peer-urls http://${THIS_IP}:2380 --listen-peer-urls http://${THIS_IP}:2380 \

    --advertise-client-urls http://${THIS_IP}:2379 --listen-client-urls http://${THIS_IP}:2379 \

    --initial-cluster ${CLUSTER} \

    --initial-cluster-state ${CLUSTER_STATE} --initial-cluster-token ${TOKEN}

 

# For node 2

THIS_NAME=${NAME_2}

THIS_IP=${HOST_2}

docker run -d --name etcd2 quay.io/coreos/etcd:${ETCD_VERSION} \

    /usr/local/bin/etcd \

    --data-dir=data.etcd --name ${THIS_NAME} \

    --initial-advertise-peer-urls http://${THIS_IP}:2380 --listen-peer-urls http://${THIS_IP}:2380 \

    --advertise-client-urls http://${THIS_IP}:2379 --listen-client-urls http://${THIS_IP}:2379 \

    --initial-cluster ${CLUSTER} \

    --initial-cluster-state ${CLUSTER_STATE} --initial-cluster-token ${TOKEN}

 

# For node 3

THIS_NAME=${NAME_3}

THIS_IP=${HOST_3}

docker run -d --name etcd3 quay.io/coreos/etcd:${ETCD_VERSION} \

    /usr/local/bin/etcd \

    --data-dir=data.etcd --name ${THIS_NAME} \

    --initial-advertise-peer-urls http://${THIS_IP}:2380 --listen-peer-urls http://${THIS_IP}:2380 \

    --advertise-client-urls http://${THIS_IP}:2379 --listen-client-urls http://${THIS_IP}:2379 \

    --initial-cluster ${CLUSTER} \

    --initial-cluster-state ${CLUSTER_STATE} --initial-cluster-token ${TOKEN}

    

 

通过HTTP接口访问etcd接口

 

查看版本

curl -L http://172.17.0.2:2379/version

*设置一个key的value

curl http://172.17.0.2:2379/v2/keys/message -XPUT -d value="Hello world"

*获取一个key的value

curl http://172.17.0.2:2379/v2/keys/message

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值