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

相关文章

Python实现快速扫描目标主机的开放端口和服务

《Python实现快速扫描目标主机的开放端口和服务》这篇文章主要为大家详细介绍了如何使用Python编写一个功能强大的端口扫描器脚本,实现快速扫描目标主机的开放端口和服务,感兴趣的小伙伴可以了解下... 目录功能介绍场景应用1. 网络安全审计2. 系统管理维护3. 网络故障排查4. 合规性检查报错处理1.

JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)

《JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)》:本文主要介绍如何在IntelliJIDEA2020.1中创建和部署一个JavaWeb项目,包括创建项目、配置Tomcat服务... 目录简介:一、创建项目二、tomcat部署1、将tomcat解压在一个自己找得到路径2、在idea中添加

Python + Streamlit项目部署方案超详细教程(非Docker版)

《Python+Streamlit项目部署方案超详细教程(非Docker版)》Streamlit是一款强大的Python框架,专为机器学习及数据可视化打造,:本文主要介绍Python+St... 目录一、针对 Alibaba Cloud linux/Centos 系统的完整部署方案1. 服务器基础配置(阿里

nacos服务无法注册到nacos服务中心问题及解决

《nacos服务无法注册到nacos服务中心问题及解决》本文详细描述了在Linux服务器上使用Tomcat启动Java程序时,服务无法注册到Nacos的排查过程,通过一系列排查步骤,发现问题出在Tom... 目录简介依赖异常情况排查断点调试原因解决NacosRegisterOnWar结果总结简介1、程序在

2025最新版Android Studio安装及组件配置教程(SDK、JDK、Gradle)

《2025最新版AndroidStudio安装及组件配置教程(SDK、JDK、Gradle)》:本文主要介绍2025最新版AndroidStudio安装及组件配置(SDK、JDK、Gradle... 目录原生 android 简介Android Studio必备组件一、Android Studio安装二、A

前端Visual Studio Code安装配置教程之下载、汉化、常用组件及基本操作

《前端VisualStudioCode安装配置教程之下载、汉化、常用组件及基本操作》VisualStudioCode是微软推出的一个强大的代码编辑器,功能强大,操作简单便捷,还有着良好的用户界面,... 目录一、Visual Studio Code下载二、汉化三、常用组件1、Auto Rename Tag2

Linux(centos7)虚拟机没有IP问题及解决方案

《Linux(centos7)虚拟机没有IP问题及解决方案》文章介绍了在CentOS7中配置虚拟机网络并使用Xshell连接虚拟机的步骤,首先,检查并配置网卡ens33的ONBOOT属性为yes,然后... 目录输入查看ZFhrxIP命令:ip addr查看,没有虚拟机IP修改ens33配置文件重启网络Xh

MongoDB搭建过程及单机版部署方法

《MongoDB搭建过程及单机版部署方法》MongoDB是一个灵活、高性能的NoSQL数据库,特别适合快速开发和大规模分布式系统,本文给大家介绍MongoDB搭建过程及单机版部署方法,感兴趣的朋友跟随... 目录前言1️⃣ 核心特点1、文档存储2、无模式(Schema-less)3、高性能4、水平扩展(Sh

Docker + Redis 部署集群的实现步骤

《Docker+Redis部署集群的实现步骤》本文详细介绍了在三台服务器上部署高可用Redis集群的完整流程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录一、环境准备1. 服务器规划(3 台服务器)2. 防火墙配置(三台服务器均执行)3. 安装 docke

win10安装及配置Gradle全过程

《win10安装及配置Gradle全过程》本文详细介绍了Gradle的下载、安装、环境变量配置以及如何修改本地仓库位置,通过这些步骤,用户可以成功安装并配置Gradle,以便进行项目构建... 目录一、Gradle下载1.1、Gradle下载地址1.2、Gradle下载步骤二、Gradle安装步骤2.1、安