前情提要:
我们需要搭建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