Docker应用系列(三)| 构建Consul集群

本示例基于Centos 7,在阿里云的三台机器上部署consul集群,假设目前使用的账号为release,拥有sudo权限。

由于Docker官方镜像下载较慢,可以开启阿里云的Docker镜像下载加速器,可参考此文进行配置。

假设三台主机的ip分别为:

  • 主机一:192.168.0.1
  • 主机二:192.168.0.2
  • 主机三:192.168.0.3

三台主机的安装步骤相似,以主机一为例:

1. 安装docker服务:

 sudo yum install -y docker

2. 启动docker服务:

sudo service docker start

3. 查找consul镜像:

sudo docker search consul

4. 下载官方consul镜像:

sudo  docker pull docker.io/consul

5. 下载完后可检查镜像:

sudo docker images 

6. 三台主机上建立数据目录和配置目录,目录为空即可:

mkdir -p /data/consul_data/data
mkdir -p /data/consul_data/conf

7. 三台主机依次启动容器:

主机一的命令为:

sudo docker run  --net=host --name consul -v /data/consul_data/data:/consul/data -v /data/consul_data/conf:/consul/config -d docker.io/consul consul agent -server -bind=192.168.0.1 -bootstrap-expect=3 -data-dir /consul/data -config-dir /consul/config

主机二的命令为:

sudo docker run  --net=host --name consul -v /data/consul_data/data:/consul/data -v /data/consul_data/conf:/consul/config -d docker.io/consul consul agent -server -bind=192.168.0.1 -bootstrap-expect=3 -data-dir /consul/data -config-dir /consul/config -join 192.168.0.1

主机三的命令为:

sudo docker run  --net=host --name consul -v /data/consul_data/data:/consul/data -v /data/consul_data/conf:/consul/config -d docker.io/consul consul agent -server -bind=192.168.0.3 -bootstrap-expect=3 -data-dir /consul/data -config-dir /consul/config -join 192.168.0.1

命令说明:

  • --net=host:采用主机网络配置,若采用默认的bridge模式,则会存在容器跨主机间通信失败的问题
  • -v /data/consul_data/data:/consul/data:主机的数据目录挂载到容器的/consul/data下,因为该容器默认的数据写入位置即是/consul/data
  • -v /data/consul_data/conf:/consul/config:主机的配置目录挂载到容器的/consul/conf下,因为该容器默认的数据写入位置即是/consul/conf
  • consul agent -server:consul的server启动模式
  • consul agent -bind=192.168.0.3:consul绑定到主机的ip上
  • consul agent  -bootstrap-expect=3:server要想启动,需要至少3个server
  • consul agent -data-dir /consul/data:consul的数据目录
  • consul agent -config-dir /consul/config:consul的配置目录
  • consul agent -join 192.168.0.1:对于主机二、三来说,需要加入到这个集群里

都启动完成后,可以通过如下命令观察consul日志,了解启动情况:

sudo docker logs 容器id/容器名称

日志情况示例如下:

[[email protected] data]$ sudo docker logs consul
[sudo] password for release:
bootstrap_expect > 0: expecting 3 servers
==> Starting Consul agent...
==> Joining cluster...
    Join completed. Synced with 1 initial agents
==> Consul agent running!
           Version: ‘v1.2.3‘
           Node ID: ‘56e5b37e-b636-3cfa-6a9b-2ce47e0dfbd1‘
         Node name: ‘sh-lbs02‘
        Datacenter: ‘dc1‘ (Segment: ‘<all>‘)
            Server: true (Bootstrap: false)
       Client Addr: [127.0.0.1] (HTTP: 8500, HTTPS: -1, DNS: 8600)
      Cluster Addr: 192.168.0.1 (LAN: 8301, WAN: 8302)
           Encrypt: Gossip: false, TLS-Outgoing: false, TLS-Incoming: false

8. 检查集群状态:

sudo docker exec -it 容器id /bin/sh

通过该命令进入容器,查看集群信息:

[[email protected] data]$ sudo docker exec -it 8a /bin/sh
/ # consul members
Node          Address            Status  Type    Build  Protocol  DC   Segment
lbs02      192.168.0.1:8301   alive   server  1.2.3  2         dc1  <all>
web01      192.168.0.2:8301   alive   server  1.2.3  2         dc1  <all>
web02      192.168.0.3:8301   alive   server  1.2.3  2         dc1  <all>
/ # 

至此,集群已启动完成,consul的端口打开较多,可以在主机上观察其端口情况:

[[email protected] ~]$ sudo netstat -tlnp|grep consul
[sudo] password for release:
tcp        0      0 192.168.0.1:8300        0.0.0.0:*               LISTEN      330/consul
tcp        0      0 192.168.0.1:8301        0.0.0.0:*               LISTEN      330/consul
tcp        0      0 192.168.0.1:8302        0.0.0.0:*               LISTEN      330/consul
tcp        0      0 127.0.0.1:8500          0.0.0.0:*               LISTEN      330/consul
tcp        0      0 127.0.0.1:8600          0.0.0.0:*               LISTEN      330/consul  

9. 如何启动consul客户端?假设consul客户端与服务端在同一个主机上:

首先,建立客户端的配置目录和数据目录:

mkdir -p /data/consul_data_cli/data
mkdir -p /data/consul_data_cli/conf

其次,在配置目录下分配客户端使用的端口,避免与服务端的端口冲突:

cd /data/consul_data_cli/conf
touch basic.json
vi basic.json
#内容如下:
{
        "ports": {
                "http":18501,
                "dns":18601,
                "rpc":18401,
                "serf_lan":18301,
                "serf_wan":18302,
                "server":18300
        }
}

最后,启动客户端:

sudo docker run  --net=host --name consul-cli -v /data/consul_data_cli/data:/consul/data -v /data/consul_data_cli/conf:/consul/config -d docker.io/consul consul agent -bind=192.168.0.2 -data-dir /consul/data -config-dir /consul/config -join 192.168.0.1:8301

原文地址:https://www.cnblogs.com/hutao722/p/9668202.html

时间: 2024-08-30 09:10:41

Docker应用系列(三)| 构建Consul集群的相关文章

Docker compose v3版本构建跨主机容器编排构建wordpress集群

在Docker 1.13版本之后,可以说Docker 对于compose容器调度编排实现了飞跃,可以使得在编排容器的时候可以结合Docker swarm集群和跨主机通讯的概念.在Docker swarm 的基础之上引入stack对service镜像管理和编排.下面我们实战一下用之前构建wordpress集群来测试一下: 环境要求: 1.存在了Docker swarm集群: [[email protected] ~]# docker node ls ID                      

Docker 容器部署 Consul 集群

一.docker安装与启动1.1安装docker[[email protected] /]# yum -y install docker-io 1.2更改配置文件[[email protected] /]# vi /etc/sysconfig/dockerother-args列更改为:other_args="--exec-driver=lxc --selinux-enabled" 1.3启动docker服务[[email protected] /]# service docker st

实战中的asp.net core结合Consul集群&amp;Docker实现服务治理

0.目录 整体架构目录:ASP.NET Core分布式项目实战-目录 一.前言 在写这篇文章之前,我看了很多关于consul的服务治理,但发现基本上都是直接在powershell或者以命令工具的方式在服务器上面直接输入consul agent .... 来搭建启动consul集群,一旦把命令工具关掉,则consul无法再后台启动,尤其是在linux系统中. 如果在window系统中,采用bat文件到时可以做成开机自启,或者在linux中把命令做成一个service 服务文件来启动就可以实现后台运

Docker容器之Compose编排、consul集群、template模板

docker compose容器编排 (1)docker compose的前身Fig,它是一个定义及运行多个docker容器的工具(2)使用docker compose不再需要使用shell脚本启动容器(3)docker compose非常适合组合使用多个容器进行开发的场景 YAML是一种标记语言很直观的数据序列化格式 文件格式及编写注意事项: 不支持制表符tab键缩进,需要使用空格缩进 通常开头缩进2个空格 字符后缩进1个空格,如冒号,逗号,横杆 用井号注释 如果包含特殊字符用单引号引起来 布

Storm 系列(三)Storm 集群部署和配置

Storm 系列(三)Storm 集群部署和配置 本章中主要介绍了 Storm 的部署过程以及相关的配置信息.通过本章内容,帮助读者从零开始搭建一个 Storm 集群.相关的过程和主要的配置选项是 Storm 的运维人员需要重点关注的,对部署和配置选项不感兴趣的读者,可以跳过本章. 在开始 Storm 之旅前,我们先看一下 Storm 部署和配置的相关信息,并提交一个 Topology,了解 Storm 的基本原理.Storm 的部署模式包括单机和集群环境,同时在向 Storm 环境中提交 To

Docker快速构建Redis集群(cluster)

Docker快速构建Redis集群(cluster) 以所有redis实例运行在同一台宿主机上为例子 搭建步骤 redis集群目录清单 . ├── Dockerfile ├── make_master_slave.sh ├── run_master_slave.sh ├── compose_master_slave.sh ├── redis-trib.rb ├── master │?? ├── 7000 │?? │?? ├── data │?? │?? │?? ├── appendonly.ao

[原创]在Docker上部署mongodb分片副本集群。

一.安装docker. 请参考:http://www.cnblogs.com/hehexiaoxia/p/6150584.html 二.编写dockerfile. #在根目录下创建dockerfile. $ vi dockerfile #version 1.0 from ubuntu #maintainer maintainer hdx #install run apt-get clean run apt-get update run apt-get install -y vim run apt

服务发现之美:Consul集群搭建

近几年随着Docker容器技术.微服务等架构的兴起,人们开始意识到服务发现的必要性.微服务架构简单来说,是一种以一些微服务来替代开发单个大而全应用的方法, 每一个小服务运行在自己的进程里,并以轻量级的机制来通信, 通常是 HTTP RESTful API.微服务强调小快灵, 任何一个相对独立的功能服务不再是一个模块, 而是一个独立的服务.那么,当我们需要访问这个服务时,如何确定它的地址呢?这时就需要服务发现了. Consul 是 HashiCorp 公司推出的开源工具,用于实现分布式系统的服务发

8分钟学会Consul集群搭建及微服务概念

原文:8分钟学会Consul集群搭建及微服务概念 Consul介绍: Consul 是由 HashiCorp 公司推出的开源软件,用于实现分布式系统的服务发现与配置.与其他分布式服务注册与发现的方案,Consul 的方案更“一站式”,内置了服务注册与发现框 架.分布一致性协议实现.健康检查.Key/Value 存储.多数据中心方案,不再需要依赖其他工具(比如 ZooKeeper 等),使用起来也较为简单. Consul的如何实现的? Consul 用 Golang 实现,因此具有天然可移植性(支