Consul安装部署(Windows单机、Docker集群)
1. Consul简介
Consul 是一个支持多数据中心分布式高可用的服务发现和配置共享的服务软件,由 HashiCorp 公司用 Go 语言开发,基于 Mozilla Public License 2.0 的协议进行开源。Consul 支持健康检查,并允许 HTTP 和 DNS 协议调用 API 存储键值对。
命令行非常好用的虚拟机管理软件 vgrant 也是 HashiCorp 公司开发的产品。
一致性协议采用 Raft 算法,用来保证服务的高可用。使用 GOSSIP 协议管理成员和广播消息, 并且支持 ACL 访问控制。
官网:https://www.consul.io/
2. Windows安装
- 下载安装包
Download Consul - 解压
- 配置环境变量
将解压后consul.exe所在的目录添加到环境变量Path中(不包含consul.exe,例如:d:\consul)。 - 运行CMD
#查看环境变量是否添加成功
consul
#启动
consul agent -dev
#浏览器访问
http://localhost:8500
#查看成员
consul members
#查看成员及元数据
consul members -detailed
#查看节点
curl localhost:8500/v1/catalog/nodes
至此,Windows单机安装Consul已经完成。
3. Docker部署Consul集群
- 安装Docker
Docker 安装并部署Tomcat、Mysql8、Redis - 拉取镜像,并单机部署
查看DockerHub中Consul的lastest的具体版本:Docker Hub Consul
#拉取镜像(若指定具体版本,执行docker pull consul:1.6.2)
docker pull consul
#查看镜像
docker images
#运行
#agent : 表示启动 Agent 进程
#-server:表示启动 Consul Server 模式
#-client:表示启动 Consul Cilent 模式
#-bootstrap:表示这个节点是 Server-Leader ,每个数据中心只能运行一台服务器。技术角度上讲 Leader 是通过 Raft 算法选举的,但是集群第一次启动时需要一个引导 Leader,在引导群集后,建议不要使用此标志
#-ui:表示启动 Web UI 管理器,默认开放端口 8500,所以使用 Docker -p命令对外开放 8500 端口
#-node:节点的名称,集群中必须是唯一的
#-client:表示 Consul 将绑定客户端接口的地址,0.0.0.0 表示所有地址都可以访问
#-join:表示加入到某一个集群中去, 如:-json=192.168.1.100
docker run --name=consul-server-1 --privileged=true -p 8500:8500 -v /usr/local/consul/data:/consul/data -e CONSUL_BIND_INTERFACE=eth0 -d consul:1.6.2 agent -server -client=0.0.0.0 -bootstrap -ui -node=1
#若出现iptables: No chain/target/match by that name,是因为docker network没有权限对container进行网络配置,有两中解决办法
#方法一:关闭网关
systemctl stop firewalld
systemctl stop iptables
#方法二:重启docker
service docker restart
#查看容器信息
docker ps -a
#删除刚才创建的容器
docker rm -f [CONTAINER ID]
#重新执行
docker run --name=consul-server-1 --privileged=true -p 8500:8500 -v /usr/local/consul/data:/consul/data -e CONSUL_BIND_INTERFACE=eth0 -d consul:1.6.2 agent -server -client=0.0.0.0 -bootstrap -ui -node=1
#查看Consul容器运行状态,若为Up状态,则证明部署成功
docker ps -a
#浏览器访问
http://[ip]:8500
#查看成员(记录Address,集群部署时需要)
docker exec consul-server-1 consul members
#查看节点信息
curl http://[ip]:8500/v1/catalog/nodes
- 集群部署
Server 模式在集群中建议是三个以上,这样更好的避免因为 Server 宕机导致整个集群挂掉的风险。
在上边单机部署上添加两个Server节点到Consul集群中。
#查看成员(记录Address)
docker exec consul-server-1 consul members
#添加两个Server节点,名称为-node=2,-node=3
docker run --name=consul-server-2 -e CONSUL_BIND_INTERFACE=eth0 -d consul:1.6.2 agent -server -node=2 -join='172.17.0.3'
docker run --name=consul-server-3 -e CONSUL_BIND_INTERFACE=eth0 -d consul:1.6.2 agent -server -node=3 -join='172.17.0.3'
#查看Consul三个容器运行状态,若为Up状态,则证明部署成功
docker ps -a
#浏览器访问
http://[ip]:8500
#查看成员(记录Address,集群部署时需要)
docker exec consul-server-1 consul members
#查看节点信息
curl http://[ip]:8500/v1/catalog/nodes
至此,使用Docker部署Consul集群已经完成。
4. 剔除无效服务和节点
- 剔除无效服务
curl -X PUT http://[ip]:8500/v1/agent/service/deregister/[service_id]
- 剔除无效节点
curl -X PUT http://[ip]:8500/v1/agent/force-leave/[node_id]
Consul安装部署(Windows单机、Docker集群)的更多相关文章
- 最新二进制安装部署kubernetes1.15.6集群---超详细教程
00.组件版本和配置策略 00-01.组件版本 Kubernetes 1.15.6 Docker docker-ce-18.06.1.ce-3.el7 Etcd v3.3.13 Flanneld v0 ...
- consul部署多台Docker集群
Consul 最近在学习Ocelot,发现里面集成Consul,所有部署一下多机版集群,后来发现网上都是在一台虚拟机中的Docker部署,而且大同小异,没有真正解释清楚. 前提准备 4台Centos虚 ...
- 基于Containerd安装部署高可用Kubernetes集群
转载自:https://blog.weiyigeek.top/2021/7-30-623.html 简述 Kubernetes(后续简称k8s)是 Google(2014年6月) 开源的一个容器编排引 ...
- ZooKeeper 的安装和配置---单机和集群
如题本文介绍的是ZooKeeper 的安装和配置过程,此过程非常简单,关键是如何应用(将放在下节及相关节中介绍). 单机安装.配置: 安装非常简单,只要获取到 Zookeeper 的压缩包并解压到某个 ...
- zookeeper安装和配置(单机+伪集群+集群)
#单机模式 解压到合适目录. 进入zookeeper目录下的conf子目录, 复制zoo_sample.cfg-->zoo.cfg(如果没有data和logs就新建):tickTime=2000 ...
- 在ubuntu上部署Kubernetes管理docker集群示例, vxlan,gre
http://www.chenshake.com/openstack-folsom-guide-for-ubuntu-12-04/ http://www.cnblogs.com/sammyliu/p/ ...
- Spark Tachyon编译部署(含单机和集群模式安装)
Tachyon编译部署 编译Tachyon 单机部署Tachyon 集群模式部署Tachyon 1.Tachyon编译部署 Tachyon目前的最新发布版为0.7.1,其官方网址为http://tac ...
- Spring Eureka 本地Docker集群部署
故事背景 最近因为产线使用的服务与发现服务,使用的是Spring Cloud Eureka集群部署,为了以后调试产线的问题,想在本地搭建和产线一样的环境.产线的所有服务都是基于K8s和Docker部署 ...
- Docker集群部署SpringCloud应用
整体架构 docker环境准备 # linux下的安装,自行百度 # windows docker toolbox下载地址 https://download.docker.com/win/stable ...
随机推荐
- C++ const的自我理解
C++学习笔记–const const 是 constant 的缩写,本意是不变的,不易改变的意思.在 C++ 中是用来修饰内置类型变量,自定义对象,成员函数,返回值,函数参数. C++ const ...
- DockerInstall
1.安装Tomcat 2.安装mysql [1].pull [root@pluto tomcat7logs]# docker pull mysql:5.6 [root@pluto tomcat7log ...
- MySQL 的常用引擎
1. InnoDB InnoDB 的存储文件有两个,后缀名分别是 .frm 和 .idb,其中 .frm 是表的定义文件,而 idb 是数据文件. InnoDB 中存在表锁和行锁,不过行锁是在命中索引 ...
- 精尽 MyBatis 源码分析 - MyBatis 初始化(一)之加载 mybatis-config.xml
该系列文档是本人在学习 Mybatis 的源码过程中总结下来的,可能对读者不太友好,请结合我的源码注释(Mybatis源码分析 GitHub 地址.Mybatis-Spring 源码分析 GitHub ...
- Let's Do 本地开发智能合约
上篇文章我们发了个币,有人抱怨在线(remix)写代码不爽,好吧,那就来看下怎么在本地开发智能合约? 一.安装开发环境 1.安装Node,Node v8.9.4或更高版本 我安装的是: 2.集成开发框 ...
- 【不尽如人意的redisTemplete封装】
线下项目里对spring redisTemplete进行了简单的封装,但是项目里关于其序列化的配置真的有点一言难尽: 可以看到这里用了JdkSerializationRedisSerializer去对 ...
- Spring Boot 集成 MQTT
本文代码有些许问题,处理方案见:解决 spring-integration-mqtt 频繁报 Lost connection 错误 一.添加配置 spring: mqtt: client: usern ...
- 注册dll命令
向系统中注册dll的方法,如下(直接回车即可注册): regsvr32
- Vue3教程:Vue 3.x 快在哪里?
人云亦云,并不会让你变得有多优秀,而会让你越来越随大流. 当你和别的开发在聊到 Vue 3.0 版本发布,有哪些亮点时,你的答案之一肯定有"它变得更快了,性能上快了 1.2 - 2倍&quo ...
- Moviepy音视频开发:视频转gif动画或jpg图片exe图形化工具开发案例
☞ ░ 前往老猿Python博文目录 ░ 一.引言 老猿之所以学习和研究Moviepy的使用,是因为需要一个将视频转成动画的工具,当时在网上到处搜索查找免费使用工具,结果找了很多自称免费的工具,但转完 ...