基于Docker运行consul

consul的镜像已经做好,并提交到docker hub上,Dockerfile如下:

FROM ubuntu
MAINTAINER chen "xxxx@xx.com"
ENV REFRESHED_AT 2017-10-10

RUN apt-get -qq update
RUN apt-get -qq install curl unzip

ADD https://releases.hashicorp.com/consul/0.6.4/consul_0.6.4_linux_amd64.zip 

 /tmp/consul.zip
RUN cd /usr/sbin && unzip /tmp/consul.zip && chmod +x /usr/sbin/consul && rm /tmp/consul.zip

RUN mkdir -p /webui/
ADD https://releases.hashicorp.com/consul/0.6.4/consul_0.6.4_web_ui.zip 

 /webui/webui.zip
RUN cd /webui && unzip webui.zip && rm webui.zip

ADD consul.json /config/

EXPOSE 53/udp 8300 8301 8301/udp 8302 8302/udp 8400 8500

VOLUME ["/data"]

ENTRYPOINT [ "/usr/sbin/consul", "agent", "-config-dir=/config" ]
CMD []

config文件如下:

{
  "data_dir": "/data",
  "ui_dir": "/webui",
  "client_addr": "0.0.0.0",
  "ports": {
    "dns": 53
  },
  "recursor": "8.8.8.8"
}

构建镜像后,把镜像推到Docker Hub上。

拉取consul镜像并运行

现在基础镜像已经构建好,从Docker Hub上拉取consul的镜像

docker pull chenpeihai/consul

拉取镜像完成后,执行以下命令就可以在外网访问了。

 docker run -p 8500:8500 -p 53:53/udp -h node1 chenpeihai/consul -server -bootstrap

现在来访问ECS的公网IP,看看是否运行起来了,这个多说一句,如果用阿里云ECS,则需要在安全组里面设置开通8500端口,腾讯云则不用。
这里写图片描述
这样一个consul实例就运行起来了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值