基于Docker运行consul
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实例就运行起来了。
更多推荐
已为社区贡献1条内容
所有评论(0)