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实例就运行起来了。

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐