.Net Core微服务入门——Consul集群搭建(一)

前几天一直在本地机器试用Consul,今天特意在服务器上试试,并搭建下集群

一、服务器安装consul

获取镜像

docker pull consul

运行:

docker run --name consul -d -p 8500:8500 --restart=always  consul

查看:

docker 搭建搭建单节点 redis consul docker单机搭建集群_docker


访问:http://192.168.8.25:8500

docker 搭建搭建单节点 redis consul docker单机搭建集群_docker_02

安装成功!

附:

1、Consul 启动参数详解

net=host docker参数, 使得docker容器越过了net namespace的隔离,免去手动指定端口映射的步骤
-server consul支持以server或client的模式运行, server是服务发现模块的核心, client主要用于转发请求
-advertise 将本机私有IP传递到consul
-retry-join 指定要加入的consul节点地址,失败后会重试, 可多次指定不同的地址
-client 指定consul绑定在哪个client地址上,这个地址可提供HTTP、DNS、RPC等服务,默认是>127.0.0.1
-bind 绑定服务器的ip地址;该地址用来在集群内部的通讯,集群内的所有节点到地址必须是可达的,>默认是0.0.0.0
allow_stale 设置为true则表明可从consul集群的任一server节点获取dns信息, false则表明每次请求都会>经过consul的server leader
-bootstrap-expect 数据中心中预期的服务器数。指定后,Consul将等待指定数量的服务器可用,然后>启动群集。允许自动选举leader,但不能与传统-bootstrap标志一起使用, 需要在server模式下运行。
-data-dir 数据存放的位置,用于持久化保存集群状态
-node 群集中此节点的名称,这在群集中必须是唯一的,默认情况下是节点的主机名。
-config-dir 指定配置文件,当这个目录下有 .json 结尾的文件就会被加载,详细可参考https://www.consul.io/docs/agent/options.html#configuration_files
-enable-script-checks 检查服务是否处于活动状态,类似开启心跳
-datacenter 数据中心名称
-ui 开启ui界面
-join 指定ip, 加入到已有的集群中

1、Consul 端口详解

8500 : http 端口,用于 http 接口和 web ui访问;
8300 : server rpc 端口,同一数据中心 consul server 之间通过该端口通信;
8301 : serf lan 端口,同一数据中心 consul client 通过该端口通信; 用于处理当前datacenter中LAN的gossip通信;
8302 : serf wan 端口,不同数据中心 consul server 通过该端口通信; agent Server使用,处理与其他datacenter的gossip通信;
8600 : dns 端口,用于已注册的服务发现;

二、本机Web API 接入 服务器 Consul

1、修改 appsettings 中 ConsulAddress 配置 (服务器地址:http://192.168.8.25:8500/)

"ConsulSetting": {
    //"ConsulAddress": "http://localhost:8500/", //注意,docker容器内部无法使用localhost访问宿主机器,如果是控制台启动的话就用localhost
    //"ConsulAddress": "http://host.docker.internal:8500/", //注意,docker容器内部无法使用localhost访问宿主机器
    "ConsulAddress": "http://192.168.8.25:8500/",
    "ServiceName": "MyApi", //服务名
    "ServiceHealthApi": "/api/health", //心跳检查api
  }

2、发布到Docker私有仓

3、本地机器拉取镜像

docker pull 192.168.8.25:5000/myapi:1.0.1

4、运行容器

docker run -d -p 5001:80 --name myservice1 192.168.8.25:5000/myapi:1.0.1  --ip=192.168.8.61 --port=5001
docker run -d -p 5002:80 --name myservice2 192.168.8.25:5000/myapi:1.0.1  --ip=192.168.8.61 --port=5002

注:这里 ip 必须指定本地机器ip(192.168.8.61),切忌不能用127.0.0.1,否则服务器Consul无法监听到心跳

5、查看结果

docker 搭建搭建单节点 redis consul docker单机搭建集群_服务器_03

docker 搭建搭建单节点 redis consul docker单机搭建集群_docker_04


下一步,将尝试服务器上搭建Consul集群