两台服务器搭建三个节点

前情提要:

我们需要搭建redis/nacos/es/rabbitmq/mongodb等中间件服务。提出计划是要三台机器进行搭建。众所周知,为了防止脑裂,大部分中间件最少需要三个节点。

但是甲方只给出了两台机器。两台机器构建三个节点,势必会让一个服务来构建两个节点。我们的安装程序是sudo rpm -ivh xxx-aarch64.rpm 直接进行安装的,不是解压安装包的方式,需要修改配置文件让支持两个节点运行。备用方案:单节点部署

服务器是涉密服务器,不允许我们操作,对方人在机房操作,机房不能拿手机,有问题需要抄写到纸上,再出来给我们打电话沟通问题。我按照网上的方式给出了修改配置文件的方法,但是行与不行我自己也没有底,所以需要自己构建服务器进行演练,验证一下配置更改是否能够正常运行。

docker 构建基础的运行环境

没有提供服务器,只提供了服务器的型号。"基于通用机+麒麟V10SP3+ARM部署包实施"

复制代码
# 提前备份记录好当前docker环境的镜像,容器信息
docker ps -a >> docker_ps_-a.txt
docker images >> docker_images.txt


# 尝试检索麒麟镜像
docker search kylin
# 执行失败, 去轩辕官网检索麒麟镜像https://xuanyuan.cloud/

#docker 镜像拉取
docker pull macrosan/kylin:v10-sp3
# 查看进行是否下载成功
docker images |grep kylin

# 根据镜像kylin创建容器, 为了保证项目存活,每20秒打印一次日志。
# 非麒麟镜像,记得替换macrosan/kylin:v10-sp3 为你自己的镜像名称。
docker run -d --name demo-container   macrosan/kylin:v10-sp3   /bin/bash -c "echo '容器启动时间: $(date)'; while true; do echo \"\$(date '+%Y-%m-%d %H:%M:%S') - Kylin日志打印\"; sleep 20; done"

# 验证项目启动成功
docker ps -a |grep kylin
# 此时看到日期打印说明容器启动成功
docker logs -f demo-container


# 停止容器
docker stop demo-container
# 删除容器
docker rm demo-container

至此解决了服务器的问题,因为要验证是两个服务器部署三个节点。能保证服务间通讯是正常的,我要验证的点是一个服务部署两个节点,配置文件的更改是否有效,是否能启动,为了减少环境搭建的困难,我也可以一个服务部署三个节点进行验证。

基础容器缺少很多命令,先进行安装,方便使用,以下命令都是需要进入容器之后进行安装。

复制代码
# 进入容器(docker exec -it demo-container bash)

# 安装vim
yum install vim

# 安装zip解压软件
yum install zip

# 添加ll命令
echo "alias ll='ls -alF'" >> ~/.bashrc
# 查看文件最后几行,应该包含ll='ls -alF'
tail -5 ~/.bashrc
# 是配置文件生效
source ~/.bashrc

# 添加systemd, 更改机器名称使用
yum install systemd

# 安装ping命令
yum install -y iputils

------------------------此处是分割线,未完待续---------

mongoDB集群安装

复制代码
# 进入容器
docker exec -it demo-container bash

redis集群安装

复制代码
# 进入容器
docker exec -it demo-container bash

ElasticSearch集群安装

复制代码
# copy准备好的文件到容器内。
docker cp elasticsearch-xxx  demo-container:/
# 进入容器
docker exec -it demo-container bash

nacos集群安装

复制代码
# 进入容器
docker exec -it demo-container bash

rabbitmq集群安装

复制代码
# 进入容器
docker exec -it demo-container bash
相关推荐
CAFEBABE 348 小时前
linux离线安装docker并启动
linux·docker·eureka
Hernon12 小时前
微服务架构设计 - 可降级设计
微服务·云原生·架构
测试人社区—小叶子17 小时前
测试开发面试高频“灵魂八问”深度解析与应答策略
网络·人工智能·测试工具·云原生·容器·面试·职场和发展
Henry Zhu12318 小时前
VPP中ACL实战配置指南与VPP的API使用初探
运维·服务器·网络·计算机网络·云原生
炸裂狸花猫1 天前
开源日志收集体系ELK
elk·elasticsearch·云原生·kubernetes·metricbeat
DeepFlow 零侵扰全栈可观测1 天前
助力金融信创与云原生转型,DeepFlow 排障智能体和可观测性建设实践
云原生·金融
拾忆,想起1 天前
Dubbo通信协议全景指南:如何为你的微服务选择最佳通信方案?
微服务·云原生·性能优化·架构·dubbo·safari
哦你看看1 天前
k8s-持久化存储
云原生·容器·kubernetes
qianshuaiblog.cn1 天前
Kubernetes安装部署
云原生·容器·kubernetes
hour_go1 天前
微服务架构的故障演练数字化:方法解析与实践优势
微服务·云原生·架构