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

2024-04-30 07:36

本文主要是介绍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-0cp * /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**,进入如下页面,说明服务启动正常。
在这里插入图片描述

这篇关于CentOS7上安装部署Consul服务(小白版)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/948259

相关文章

ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法

《ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法》本文介绍了Elasticsearch的基本概念,包括文档和字段、索引和映射,还详细描述了如何通过Docker... 目录1、ElasticSearch概念2、ElasticSearch、Kibana和IK分词器部署

部署Vue项目到服务器后404错误的原因及解决方案

《部署Vue项目到服务器后404错误的原因及解决方案》文章介绍了Vue项目部署步骤以及404错误的解决方案,部署步骤包括构建项目、上传文件、配置Web服务器、重启Nginx和访问域名,404错误通常是... 目录一、vue项目部署步骤二、404错误原因及解决方案错误场景原因分析解决方案一、Vue项目部署步骤

Linux流媒体服务器部署流程

《Linux流媒体服务器部署流程》文章详细介绍了流媒体服务器的部署步骤,包括更新系统、安装依赖组件、编译安装Nginx和RTMP模块、配置Nginx和FFmpeg,以及测试流媒体服务器的搭建... 目录流媒体服务器部署部署安装1.更新系统2.安装依赖组件3.解压4.编译安装(添加RTMP和openssl模块

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型的操作流程

《0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeekR1模型的操作流程》DeepSeekR1模型凭借其强大的自然语言处理能力,在未来具有广阔的应用前景,有望在多个领域发... 目录0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型,3步搞定一个应

redis群集简单部署过程

《redis群集简单部署过程》文章介绍了Redis,一个高性能的键值存储系统,其支持多种数据结构和命令,它还讨论了Redis的服务器端架构、数据存储和获取、协议和命令、高可用性方案、缓存机制以及监控和... 目录Redis介绍1. 基本概念2. 服务器端3. 存储和获取数据4. 协议和命令5. 高可用性6.

Python安装时常见报错以及解决方案

《Python安装时常见报错以及解决方案》:本文主要介绍在安装Python、配置环境变量、使用pip以及运行Python脚本时常见的错误及其解决方案,文中介绍的非常详细,需要的朋友可以参考下... 目录一、安装 python 时常见报错及解决方案(一)安装包下载失败(二)权限不足二、配置环境变量时常见报错及

TP-Link PDDNS服将于务6月30日正式停运:用户需转向第三方DDNS服务

《TP-LinkPDDNS服将于务6月30日正式停运:用户需转向第三方DDNS服务》近期,路由器制造巨头普联(TP-Link)在用户群体中引发了一系列重要变动,上个月,公司发出了一则通知,明确要求所... 路由器厂商普联(TP-Link)上个月发布公告要求所有用户必须完成实名认证后才能继续使用普联提供的 D

Deepseek R1模型本地化部署+API接口调用详细教程(释放AI生产力)

《DeepseekR1模型本地化部署+API接口调用详细教程(释放AI生产力)》本文介绍了本地部署DeepSeekR1模型和通过API调用将其集成到VSCode中的过程,作者详细步骤展示了如何下载和... 目录前言一、deepseek R1模型与chatGPT o1系列模型对比二、本地部署步骤1.安装oll

nginx部署https网站的实现步骤(亲测)

《nginx部署https网站的实现步骤(亲测)》本文详细介绍了使用Nginx在保持与http服务兼容的情况下部署HTTPS,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值... 目录步骤 1:安装 Nginx步骤 2:获取 SSL 证书步骤 3:手动配置 Nginx步骤 4:测