docker应用系列|构建consul集群(代码片段)

hutao722 hutao722     2023-01-01     218

关键词:

本示例基于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

 

使用docker-compose搭建consul集群环境(代码片段)

DosckerCompose1.概述Compose是用于定义和运行多容器Docker应用程序的工具。通过Compose,您可以使用YML文件来配置应用程序需要的所有服务。然后,使用一个命令,就可以从YML文件配置中创建并启动所有服务2.docker-compose常... 查看详情

使用docker-compose搭建consul集群环境(代码片段)

DosckerCompose1.概述Compose是用于定义和运行多容器Docker应用程序的工具。通过Compose,您可以使用YML文件来配置应用程序需要的所有服务。然后,使用一个命令,就可以从YML文件配置中创建并启动所有服务2.docker-compose常... 查看详情

docker-容器部署consul集群(代码片段)

原文:Docker-容器部署Consul集群目录说明简介了解ConsulConsul使用场景Consul优势Consul中的概念安装准备Consul镜像安装单个Consul组装集群Consul总结引用和附件说明本文主要介绍怎么使用Docker在Linux环境部署Consul集群,如果你对Docker不了... 查看详情

部署consul建立docker集群(代码片段)

部署Consul建立Docker集群架构图1、什么是consul2、consul-template说明3、registrator的作用4、部署②、容器服务自动加入nginx集群③、服务端Consul下安装consul-template④、在宿主机上部署nginx⑤、部署多个Consul服务端主机架构图1、什么是cons... 查看详情

轻松构建docker服务发现机制(代码片段)

目录前言一、环境二、部署步骤1.Docker01操作2.docker02、docker03加入consul集群三、验证前言服务发现在SOA(Service-OrientedArchitecture)架构中是一个很重要的概念,是支撑大规模SOA的核心服务,在应用Docker容器集群的实践中也是非... 查看详情

docker上搭建consul集群全流程(代码片段)

原文:docker上搭建consul集群全流程consul简介:consul是提供服务发现、简单配置管理、分区部署的服务注册发现解决方案。主要特性:服务发现\\健康检查\\基于Key-Value的配置\\支持TLS安全通讯\\支持多数据中心部署consul的实例叫agenta... 查看详情

docker-compose启动consul集群(代码片段)

version:‘2.0‘services:consul-server1:image:consul:latesthostname:"consul-server1"ports:-"8501:8500"volumes:-./consul/data1:/consul/datacommand:"agent-server-bootstrap-expect3-ui-disable-host-node-id-c 查看详情

docker安装consul以及部署consul集群(代码片段)

1.拉取镜像 dockerpullconsul:latest2.启动第一个consul节点dockerrun--nameconsul1-d-p8500:8500-p8300:8300-p8301:8301-p8302:8302-p8600:8600consulagent-server-bootstrap-expect2-ui-bind=0.0.0.0-client=0.0.0.03.查看 查看详情

使用docker-compose搭建consul集群环境!!!(代码片段)

使用Docker-Compose搭建consul集群环境一.Composeconsul的概述1.什么是Compose2.DockerCompose容器编排3.DockerCompose配置常用字段字段描述4.DockerCompose常用命令二.Consul的概述1.什么是consul2.Consul的特性3.Consul容器服务更新与发现三.Compose的部署1.服... 查看详情

使用docker-compose搭建consul集群环境!!!(代码片段)

使用Docker-Compose搭建consul集群环境一.Composeconsul的概述1.什么是Compose2.DockerCompose容器编排3.DockerCompose配置常用字段字段描述4.DockerCompose常用命令二.Consul的概述1.什么是consul2.Consul的特性3.Consul容器服务更新与发现三.Compose的部署1.服... 查看详情

docker私有仓库部署之compose搭建consul集群(代码片段)

文章目录一、DockerCompose简介1.1DockerCompose概述1.2DockerCompose容器编排1.3DockerCompose常用命令1.4DockerCompose配置常用字段二、Consul简介2.1consul概述2.2Consul容器服务更新与发现三、部署Compose3.1安装docker、设置镜像加速3.2compose部署四、consu... 查看详情

使用docker-compose搭建consul集群环境!!!(代码片段)

使用Docker-Compose搭建consul集群环境一.Composeconsul的概述1.什么是Compose2.DockerCompose容器编排3.DockerCompose配置常用字段字段描述4.DockerCompose常用命令二.Consul的概述1.什么是consul2.Consul的特性3.Consul容器服务更新与发现三.Compose的部署1.服... 查看详情

consul安装部署(windows单机docker集群)(代码片段)

1.Consul简介??Consul是一个支持多数据中心分布式高可用的服务发现和配置共享的服务软件,由HashiCorp公司用Go语言开发,基于MozillaPublicLicense2.0的协议进行开源。Consul支持健康检查,并允许HTTP和DNS协议调用API存储键值对。??命令行... 查看详情

docker------dockerconsul集群部署(代码片段)

目录一.服务注册与发现概述二.Consul的概念三.Consul的部署环境准备1.建立Consul服务(192.168.121.22)①安装consul服务②查看集群信息③通过httpapi获取集群信息2.registrator服务器(192.168.121.33)①安装Gliderlabs/Registrator②... 查看详情

docker------dockerconsul集群部署(代码片段)

目录一.服务注册与发现概述二.Consul的概念三.Consul的部署环境准备1.建立Consul服务(192.168.121.22)①安装consul服务②查看集群信息③通过httpapi获取集群信息2.registrator服务器(192.168.121.33)①安装Gliderlabs/Registrator②... 查看详情

docker基础之docker-compose搭建consul集群(代码片段)

一、Docker-compose1.1、docker-compose简介Docker-Compose项目是Docker官方的开源项目,负责实现对Docker容器集群的快速编排。Docker-Compose将所管理的容器分为三层,分别是工程(project),服务(service)以及容器(container)。Docker-Compose运... 查看详情

docker基础之docker-compose搭建consul集群(代码片段)

一、Docker-compose1.1、docker-compose简介Docker-Compose项目是Docker官方的开源项目,负责实现对Docker容器集群的快速编排。Docker-Compose将所管理的容器分为三层,分别是工程(project),服务(service)以及容器(container)。Docker-Compose运... 查看详情

使用docker-compose搭建consul集群环境(代码片段)

...档文章目录一、Composeconsul的概述1、Compose是什么?2、DockerCompose容器编排3、DockerCompose配置常用字段4、DockerCompose常用命令二、Consul的概述1、consul是什么2、Consul容器服务更新与发现三、部署Com 查看详情