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

相关文章

Nginx分布式部署流程分析

《Nginx分布式部署流程分析》文章介绍Nginx在分布式部署中的反向代理和负载均衡作用,用于分发请求、减轻服务器压力及解决session共享问题,涵盖配置方法、策略及Java项目应用,并提及分布式事... 目录分布式部署NginxJava中的代理代理分为正向代理和反向代理正向代理反向代理Nginx应用场景

Linux创建服务使用systemctl管理详解

《Linux创建服务使用systemctl管理详解》文章指导在Linux中创建systemd服务,设置文件权限为所有者读写、其他只读,重新加载配置,启动服务并检查状态,确保服务正常运行,关键步骤包括权... 目录创建服务 /usr/lib/systemd/system/设置服务文件权限:所有者读写js,其他

Java服务实现开启Debug远程调试

《Java服务实现开启Debug远程调试》文章介绍如何通过JVM参数开启Java服务远程调试,便于在线上排查问题,在IDEA中配置客户端连接,实现无需频繁部署的调试,提升效率... 目录一、背景二、相关图示说明三、具体操作步骤1、服务端配置2、客户端配置总结一、背景日常项目中,通常我们的代码都是部署到远程

python依赖管理工具UV的安装和使用教程

《python依赖管理工具UV的安装和使用教程》UV是一个用Rust编写的Python包安装和依赖管理工具,比传统工具(如pip)有着更快、更高效的体验,:本文主要介绍python依赖管理工具UV... 目录前言一、命令安装uv二、手动编译安装2.1在archlinux安装uv的依赖工具2.2从github

JDK8(Java Development kit)的安装与配置全过程

《JDK8(JavaDevelopmentkit)的安装与配置全过程》文章简要介绍了Java的核心特点(如跨平台、JVM机制)及JDK/JRE的区别,重点讲解了如何通过配置环境变量(PATH和JA... 目录Java特点JDKJREJDK的下载,安装配置环境变量总结Java特点说起 Java,大家肯定都

linux部署NFS和autofs自动挂载实现过程

《linux部署NFS和autofs自动挂载实现过程》文章介绍了NFS(网络文件系统)和Autofs的原理与配置,NFS通过RPC实现跨系统文件共享,需配置/etc/exports和nfs.conf,... 目录(一)NFS1. 什么是NFS2.NFS守护进程3.RPC服务4. 原理5. 部署5.1安装NF

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践

Nginx部署HTTP/3的实现步骤

《Nginx部署HTTP/3的实现步骤》本文介绍了在Nginx中部署HTTP/3的详细步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录前提条件第一步:安装必要的依赖库第二步:获取并构建 BoringSSL第三步:获取 Nginx

RabbitMQ 延时队列插件安装与使用示例详解(基于 Delayed Message Plugin)

《RabbitMQ延时队列插件安装与使用示例详解(基于DelayedMessagePlugin)》本文详解RabbitMQ通过安装rabbitmq_delayed_message_exchan... 目录 一、什么是 RabbitMQ 延时队列? 二、安装前准备✅ RabbitMQ 环境要求 三、安装延时队

sysmain服务可以禁用吗? 电脑sysmain服务关闭后的影响与操作指南

《sysmain服务可以禁用吗?电脑sysmain服务关闭后的影响与操作指南》在Windows系统中,SysMain服务(原名Superfetch)作为一个旨在提升系统性能的关键组件,一直备受用户关... 在使用 Windows 系统时,有时候真有点像在「开盲盒」。全新安装系统后的「默认设置」,往往并不尽编