CentOS7上安装部署Consul服务(小白版)

文章目录

  • 1.Consul服务介绍
  • 2.Consul服务下载安装
  • 3.Consul服务配置
    • 3.1.创建Consul服务的运行用户
    • 3.2.下载服务配置生成脚本
    • 3.3.配置执行脚本需要的临时变量
    • 3.4.生成配置文件
    • 3.5.启动测试
    • 3.6.开机自启配置

1.Consul服务介绍

Consul 是一种开源的服务网格解决方案,由 HashiCorp 公司开发。它为微服务架构提供了服务发现、健康检查、键值存储等功能。Consul 的主要特性包括:

  • 服务发现与注册:Consul 提供了服务发现机制,允许服务实例注册自己,并通过 DNS 或 HTTP 接口查询可用的服务。这使得在动态环境中自动发现服务成为可能。
  • 健康检查:Consul 具有内置的健康检查功能,可以定期检查服务实例的健康状态。如果服务实例出现故障或不可用,Consul 将自动将其标记为不健康,从服务发现中删除或引入故障转移。
  • 分布式一致性:Consul 使用 Raft 协议来实现强一致性,确保数据在整个集群中的一致性。这使得 Consul 能够在多个节点之间实现高可用性和可扩展性。
  • 键值存储:Consul 提供了一个分布式键值存储系统,可以用于共享配置信息、服务元数据等。这使得应用程序可以方便地在不同的服务之间共享配置和状态信息。
  • 安全性:Consul 提供了安全功能,包括 ACL(访问控制列表)和 TLS 加密,用于保护集群中的通信和数据。
  • 多数据中心支持:Consul 支持多数据中心部署,可以在不同的数据中心之间进行服务发现和通信。这使得在全球范围内构建分布式系统变得更加容易。

总的来说,Consul 提供了一套完整的解决方案,用于构建和管理微服务架构中的服务发现、配置管理和健康检查等功能,使得在分布式系统中部署和管理服务变得更加简单和可靠。

2.Consul服务下载安装

consul官方网站:https://www.consul.io/
在这里插入图片描述
下载地址:https://developer.hashicorp.com/consul/install?product_intent=consul
在这里插入图片描述

我这里安装的最新的1.18.1版本, 提供了很多安装版本, 我这里选择的时二进制安装文件安装。
在这里插入图片描述
下载安装包到本地, 然后上传到服务器,进行解压安装
在这里插入图片描述
解压安装

tar -zxf consul_1.18.1_linux_amd64.zip

然后移动到/usr/bin目录下

mv consul /usr/bin/

之后验证consul是否安装成功

consul version

输出如下图所示, 说明安装成功。
在这里插入图片描述

3.Consul服务配置

下面开始进行Consul服务的配置

3.1.创建Consul服务的运行用户

useradd consul

3.2.下载服务配置生成脚本

GitHub上提供了一个虚拟机上Cosul服务配置的脚本项目,地址如下:
https://github.com/hashicorp-education/learn-consul-get-started-vms
在这里插入图片描述

具体的脚本地址如下:
https://github.com/hashicorp-education/learn-consul-get-started-vms/tree/main/self-managed/ops/scenarios/99_supporting_scripts
在这里插入图片描述
下载脚本文件, 然后上传到服务器的/home/software/consul-1.18.1/目录下,你希望脚本生成在那个目录, 就上传到那个目录。

3.3.配置执行脚本需要的临时变量

执行如下命令:

export CONSUL_DATACENTER="dc1"; \
export CONSUL_DOMAIN="consul"; \
#这里的生成目标目录自行修改, 需要注意目录需要赋予账号可读可写权限
export OUTPUT_FOLDER="/home/software/consul-1.18.1/assets/scenario/conf/"; 
export CONSUL_RETRY_JOIN="127.0.0.1"

3.4.生成配置文件

执行如下命令
找到你刚才上传脚本的目录, 进入到如下目录中进行命令执行
在这里插入图片描述
脚本生成中
在这里插入图片描述
到目标配置文件生成目录找到生成的配置文件
在这里插入图片描述在这里插入图片描述

测试配置文件是否有效

#修改成你自己设置的配置文件保存地址进行验证
consul validate /home/software/consul-1.18.1/assets/scenario/conf/consul-server-0

如下图,说明配置文件有效
在这里插入图片描述
接下来将生成的配置拷贝到/etc/consul.d/目录下,如果没有/etc/consul.d/目录, 先执行如下命令创建目录

mkdir -p /etc/consul.d

复制配置文件

cd /home/software/consul-1.18.1/assets/scenario/conf/consul-server-0

cp * /etc/consul.d

增加系统域名配置

vim /etc/hosts

在最后追加如下内容:
在这里插入图片描述
保存退出

修改consul服务端配置/etc/consul.d/consul.hcl

# -----------------------------+
# consul.hcl                   |
# -----------------------------+
# 服务绑定地址(根据自己的主机进行修改)
bind_addr = "10.10.3.14"

# 节点名称(自行修改,但是记得修改之后需要同步更新/etc/hosts)
node_name = "consul-server-0"

# 数据保存地址
data_dir = "/var/lib/consul"

# Logging
log_level = "DEBUG"
enable_syslog = false
# Logging
log_level = "DEBUG"
enable_syslog = false

## Disable script checks
enable_script_checks = false

## Enable local script checks
enable_local_script_checks = true

# 配置远程主机可访问
client_addr = "0.0.0.0"

# 开启UI web界面
ui_config{
    enabled = true
}

# 是否开启服务
server = true

# 期望的节点数量(必须配置)
bootstrap_expect = 1

OK, 基本配置完成, 下面进行启动测试和启动配置

3.5.启动测试

运行以下命令进行启动

consul agent -config-dir=/etc/consul.d/consul.hcl > /tmp/consul-server.log 2>&1 &

检查服务是否正常运行

ps -ef|grep consul

如下图说明服务正常启动
在这里插入图片描述
通过浏览器进行验证, 输入UI访问地址**http://10.10.3.14:8500/ui/dc1/services**,进入如下页面,说明服务启动正常。
在这里插入图片描述

3.6.开机自启配置

首先我们开机自请全使用consul用户配置, 所以之前的所有文件都需要让consul用户有访问权限,请执行以下授权操作。

授权数据存储目录给consul用户

chown -R consul:consul /var/lib/consul

配置文件目录给consul用户

chown -R consul:consul /etc/consul.d

**/usr/lib/systemd/system**目录下新增**consul.service**文件, 内容如下:


[Unit]
Description=Consul Server
Requires=network-online.target
After=network-online.target
ConditionFileNotEmpty=/etc/consul.d/consul.hcl

[Service]
Type=notify
User=consul
Group=consul
ExecStart=/usr/bin/consul agent -config-dir=/etc/consul.d/consul.hcl
ExecReload=/usr/bin/consul reload
KillMode=process
Restart=on-failure
LimitNOFILE=65536
TimeoutSec=900

[Install]
WantedBy=multi-user.target

然后刷新开机自启配置

systemctl daemon-reload

启动consul

systemctl start consul

查看consul状态

systemctl status consul

开启Consul的开机自启

systemctl enable consul

通过浏览器进行验证, 输入UI访问地址**http://10.10.3.14:8500/ui/dc1/services**,进入如下页面,说明服务启动正常。
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/583463.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

pytorch库 01 安装Anaconda、Jupyter,Anaconda虚拟环境连接pycharm

文章目录 一、安装Anaconda1、卸载Anaconda(可选)2、下载并安装Anaconda3、配置环境变量4、桌面快捷方式 二、安装 PyTorch(GPU 版)库1、创建虚拟环境,并安装一些常用包2、GPU 基础3、检查驱动4、安装CUDA(…

Linux搭建局域网私有yum仓库/配置本地光盘镜像仓库/搭建公有yum仓库--7700字详谈

帮助与补全功能 1.补全 yum (options)COMMAND check check-update clean deplist downgrade erase fs fssnapshot groups help history info install list makecache provides reinstall repo-pkgs repolist search shell swap update update-minimal …

每周一算法:单源次短路

题目描述 “您的个人假期”旅行社组织了一次比荷卢经济联盟的巴士之旅。 比荷卢经济联盟有很多公交线路。每天公共汽车都会从一座城市开往另一座城市。沿途汽车可能会在一些城市(零或更多)停靠。 旅行社计划旅途从 S S S 城市出发,到 F …

新书速览|ChatGLM3大模型本地化部署、应用开发与微调

实战文本生成、智能问答、信息抽取、财务预警应用开发,掌握ChatGLM3大模型部署、开发与微调技术 01 本书内容 《ChatGLM3大模型本地化部署、应用开发与微调》作为《PyTorch 2.0深度学习从零开始学》的姊妹篇,专注于大模型的本地化部署、应用开发以及微…

挤压激励注意力 SE | Squeeze-and-Excitation Networks

论文名称:《Squeeze-and-Excitation Networks》 论文地址:https://arxiv.org/pdf/1709.01507.pdf 代码地址: https://github.com/hujie-frank/SENet 卷积神经网络 (CNN) 的核心构建块是卷积运算符,它使网络能够通过在每一层的局…

C++ | Leetcode C++题解之第50题Pow(x,n)

题目: 题解: class Solution { public:double quickMul(double x, long long N) {if (N 0) {return 1.0;}double y quickMul(x, N / 2);return N % 2 0 ? y * y : y * y * x;}double myPow(double x, int n) {long long N n;return N > 0 ? qu…

谷歌CEO谈拥有“最好的”AI、1000 种新云产品和Workspace

谷歌首席执行官桑达尔皮查伊 (Sundar Pichai) 在谷歌财报中发表了大胆言论,其中包括将 Workspace 吹捧为网络安全领域的领导者、谷歌云和 YouTube 到今年年底的总运行额将达到 1000 亿美元,以及为什么需要“强大的合作伙伴计划”来推动人工智能发展。 谷…

70、栈-最小栈

思路: 除了最后一个获取最小值以外,其他都可以使用一个栈来实现,但是如果当前一个最小值被移除了,如果获取第二小的值,这个是需要记录的。所以最好的办法是两个栈。一个作为主栈存放数据,一个作为辅栈&…

C++之类和对象

目录 一:再谈构造函数 1.1 构造函数体赋值 1.2 初始化列表 1.3 explicit关键字 二. static成员 2.2 特性 三. 友元 3.1 友元函数 3.2 友元类 四: 内部类 五:匿名对象 六. 再次理解类和对象 一:再谈构造函数 1.1 构造…

关于discuz论坛网址优化的一些记录(网站地图sitemap提交)

最近网站刚上线,针对SEO做了些操作,为了方便网站网页百度被收录,特此记录下 discuz有免费的sitemap插件可以用,打开后台管理,找到插件栏,然后找到更多插件,进入插件市场。 选择这个免费的sitem…

ios CI/CD 持续集成 组件化专题四-(手动发布私有库-组件化搭建)

一 、创建私有索引库 1.1 、第一步 首先检查本地是否存在需要的私有索引库 pod repo list 例如:dp_base_ios_spec 在本地不存在该私有索引库 1.2 、第二步 在git下下创建一个新的库,这个库用来保存私有库的podspec文件,取名叫xxxSpec用以…

计算机组成实验(5)

一、实验目的和要求 1.1 实验目的 1. 复习二进制加减、乘除的基本法则 2. 掌握补码的基本原理和作用 3. 了解浮点数的表示方法及加法运算法则 4. 进一步了解计算机系统的复杂运算操作 1.2 实验要求 1. 熟悉二进制原码补码的概念,了解二进制加减乘除的原理与操作实现。 …

力扣HOT100 - 207. 课程表

解题思路&#xff1a; class Solution {public boolean canFinish(int numCourses, int[][] prerequisites) {int[] inDegree new int[numCourses];//存每个结点的入度List<List<Integer>> res new ArrayList<>();//存结点之间依赖关系Queue<Integer>…

buuctf——web题目练习

1.极客大挑战2019 easysql 密码或者用户输入万能密码即可 关于万能密码的理解和原理&#xff0c;可以参考这篇BUUCTF[极客大挑战 2019] EasySQL 1_[极客大挑战 2019]easysql 1-CSDN博客 2.极客大挑战2019 have fun 题目源码 需要构造payload 网页传参可参考&#xff1a;…

设计模式 基本认识

文章目录 设计模式的作用设计模式三原则设计模式与类图设计模式的分类 设计模式的作用 设计模式是在软件设计过程中针对常见问题的解决方案的一种通用、可重用的解决方案。设计模式提供了一种经过验证的方法&#xff0c;可以帮助开发人员解决特定类型的问题&#xff0c;并在软…

C++常用的输入输出方法(ACM模式)

文章目录 前言一、输入输出方法1、cin2、getline()3、getchar() 二、算法案例1、一维数组1.1 输入固定长度1.2长度不固定 2、固定二维数组3、以非空格隔开的元素输入3、常见数据结构定义以及输入3.1 链表 前言 C中的输入输出函数有很多&#xff0c;我们本章只针对大部分算法题…

Makefile 快速入门

参考自:Makefile 20分钟入门&#xff0c;简简单单&#xff0c;展示如何使用Makefile管理和编译C代码_哔哩哔哩_bilibili 注: 视频中用的是C&#xff0c;博主这里用C语言实现 喜欢老师的于老师的还请多多点赞&#xff0c;觉得博主写得不错的&#xff0c;也可以点赞、收藏哦 本…

mars3d实现获取线上不同历里程的坐标

mars3d实现获取线上不同历里程的坐标应用效果 线路数据是这样的&#xff0c;由很多段组成的&#xff0c;是不是就只能一段一段去计算看处于哪一段上具体位置 相关说明&#xff1a;想要实现以上效果的话&#xff0c;mars3d实现需要以下两点 1、需要合并线 2、可以利用 http://m…

学习周报:文献阅读+Fluent案例+有限体积法理论学习

目录 摘要 Abstract 文献阅读&#xff1a;基于物理信息神经网络的稀疏数据油藏模拟 文献摘要 文章讨论|结论 各方程和原理简介 PINN简介 域分解 实验设置 单相油藏问题 油水两相问题 Fluent实例&#xff1a;Y型弯管中的流体混合分析 几何建模部分 网格划分 求解器设…

贝叶斯统计实战:Python引领的现代数据分析之旅

贝叶斯统计这个名字取自长老会牧师兼业余数学家托马斯贝叶斯(Thomas Bayes&#xff0c;1702—1761)&#xff0c;他最先推导出了贝叶斯定理&#xff0c;该定理于其逝世后的1763年发表。但真正开发贝叶斯方法的第一人是Pierre-Simon Laplace(1749—1827)&#xff0c;因此将其称为…