zoukankan      html  css  js  c++  java
  • Docker学习(二)-Docker搭建Consul集群

    1.环境准备

    Linux机器三台 网络互通配置可以参考 https://www.cnblogs.com/woxpp/p/11858257.html

    192.168.50.21

    192.168.50.22

    192.168.50.23

     关闭三台机器防火墙,如果是一台机器则没有关系,多台机器需要关闭。

    systemctl stop firewalld.service            #停止firewall
    systemctl disable firewalld.service        #禁止firewall开机启动
    

    2.安装Docker

    每台机器上安装下Docker,如果镜像比较慢可以开启阿里云的docker镜像下载器。参考https://www.cnblogs.com/atuotuo/p/6264800.html

    1. 安装docker:

    yum install -y docker

    2. 启动docker: 

    service docker start

    3. 验证docker是否安装成功:

    docker version

    2.安装Consul镜像

     1. 在三台机器上安装consul镜像(默认安装最新版本)

    docker pull consul

     2. 验证安装

    docker images

     

    3.启动Consul

    1.启动参数详解

    –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, 加入到已有的集群中
    

    2.端口详解 

    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 端口,用于已注册的服务发现;

    3. 启动consul服务,192.168.50.21

    如果是一台机器可以在以下代码中加入 -p 替换默认端口,-p 8501:8500

    docker run -d --name consul21 -h=consul21 --net=host -e CONSUL_BIND_INTERFACE=ens33 consul agent -server=true -client=0.0.0.0 -bind=192.168.50.21 -ui -bootstrap-expect=3

    4.启动consul服务,192.168.50.22,加入21

    docker run -d --name consul22 -h=consul22 --net=host -e CONSUL_BIND_INTERFACE=ens33 consul agent -server=true -client=0.0.0.0 -join=192.168.50.21 -ui

    5.启动consul服务,192.168.50.23,加入21

    docker run -d --name consul22 -h=consul22 --net=host -e CONSUL_BIND_INTERFACE=ens33 consul agent -server=true -client=0.0.0.0 -join=192.168.50.21 -ui

    6.检查每台机器的consul运行状态

    docker ps

     如果出现  Exited 9 seconds ago,则关闭所有机器防火墙后试试

    docker rm -f consul22  #删除容器

    systemctl stop firewalld.service            #停止firewall
    systemctl disable firewalld.service        #禁止firewall开机启动

     

    7.查看consul运行日志

    docker logs consul22

    日志中出现 

    2019/11/15 05:58:44 [WARN] raft: no known peers, aborting election
    2019/11/15 05:58:46 [ERR] agent: failed to sync remote state: No cluster leader

    三台机器重启好后,则不会报错,与启动时参数 -bootstrap-expect=3 数据中心中预期的服务器数 有关

     

    浏览

    http://192.168.50.21:8500/ui/ 

    http://192.168.50.22:8500/ui/

    http://192.168.50.23:8500/ui/

    踩坑点:防火墙。。。

  • 相关阅读:
    每日一题力扣520 判断大小写
    每日一题力扣434
    每日一题力扣557
    每日一题力扣344 反转字符串
    每日一题力扣125 回文字符串
    每日一题力扣541
    每日一题力扣58
    【20211015】项目成本粗略分析
    【20211013】连岳摘抄
    【20211014】自己就是解决问题的起点
  • 原文地址:https://www.cnblogs.com/woxpp/p/11849002.html
Copyright © 2011-2022 走看看