.net core微服务之基于Docker+Consul+Registrator服务注册服务发现

1、Docker部分:html

先拉最新的asp.net core的镜像:node

docker pull microsoft/aspnetcore

 将下载下来的镜像重命名,为何要重命名?等会讲Registrator的时候再解释。执行下面的命令:linux

docker tag microsoft/aspnetcore qkawebserver

运行docker, 挂载本地目录/apps/QkaWebServer到容器中的/apps/dotnet/,将容器中的两个端口映射出来,其中80端口是网站的端口,8800端口是thrift服务端口,执行以下命令:web

docker run  -ti  -d --restart=always --privileged -v /apps/QkaWebServer:/apps/dotnet/ -v /etc/hosts:/etc/hosts -p:80 -p:8800 qkawebserver /usr/sbin/init

查看全部容器,执行命令:docker

docker ps -a

 运行.net core程序及怎么配置守护程序supervisor,请查看以前的一篇博文http://www.cnblogs.com/focus-lei/p/6868324.html,再也不赘述vim

2、Consul部分:api

 下载consul:app

wget https://releases.hashicorp.com/consul/1.0.7/consul_1.0.7_linux_amd64.zip

 解压:asp.net

unzip consul_1.0.7_linux_amd64.zip

运行:tcp

./consul agent -dev -ui -node=consul-dev -client=192.168.0.124

这里没作集群了,生产环境再作考虑。访问一下http://192.168.0.124:8500,能够访问说明安装成功。

3、Registrator部分

 Docker服务中进程间通讯经过/var/run/docker.sock实现,默认服务不提供监听端口,所以使用docker remote api 须要手动绑定端口。

vim /etc/systemd/system/docker.service

修改
ExecStart=/usr/bin/dockerd -H tcp://0.0.0.0:2375 -H unix:///var/run/docker.sock   

 以上红色部分为新增的。修改后重启一下docker服务。

 拉取Registrator的镜像:

docker pull gliderlabs/registrator:latest

运行:

docker run -d --name=registrator   --net=host --volume=/var/run/docker.sock:/tmp/docker.sock gliderlabs/registrator:latest consul://192.168.0.124:8500

再访问http://192.168.0.124:8500,能够看到services中已经有了docker中所有的服务地址。服务的命名规则是运行的容器的image的名字+“-”+端口,因此在每次运行镜像以前最好对镜像重命名一个与业务相关的名字。

相关文章
相关标签/搜索