当前位置: 首页 > news >正文

使用Xshell7控制多台服务同时安装ZK最新版集群服务

一: 环境准备:

      主机名称         主机IP    节点    (集群内通讯端口|选举leader|cline端提供服务)端口
       docker0   192.168.1.100
node-0  
           2888      |      3888      |       2181 
       docker1   192.168.1.101
node-1
           2888      |      3888      |       2181
       docker2   192.168.1.102
node-1 
           2888      |      3888      |       2181

1.1 下载zookeeper安装包

集群为大于等于3个基数,如 3、5、7…,不宜太多,集群机器多了选举和数据同步耗时时长长,不稳定。目前觉得,三台选举+N台observe很不错

Index of /dist/zookeeper/zookeeper-3.9.0  最新版下载

[root@www tools]# wget https://archive.apache.org/dist/zookeeper/zookeeper-3.9.0/apache-zookeeper-3.9.0-bin.tar.gz
查看是否已经下载:

1.2: 将安装包拷贝到其他服务器上:

在docker0节点上,分发该包到各个服务器上的:/usr/local/tools目录,然后创建/usr/local/zookeeper目录,准备再docker0节点同时安装其他两台服务器的ZK;

[root@www tools]# mkdir -p /usr/local/zookeeper

首先,使其他两台服务(docker1,docker2)处于docker0控制的状态,如下图所示:

(可以参考:Centos7卸载|安装JDK1.8|Xshell7批量控制多个终端)

[root@www tools]# sudo yum install rsync -y
rsync和scp区别:用rsync做文件的复制要比scp的速度快,rsync只对差异文件做更新。scp是把所有文件都复制过去

在主目录创建bin目录:

[root@www tools]# mkdir ~/bin

创建分发脚本文件:xsync   脚本内容

[root@www tools]#  cat ~/bin/xsync 

#!/bin/bash
#1. 判断参数个数
if [ $# -lt 1 ]
then
    echo Not Enough Arguement!
    exit;
fi

#2. 遍历集群所有机器
for host in docker0  docker1 docker2
do
    echo ====================  $host  ====================
    
    #3. 遍历所有目录,挨个发送
    for file in $@
    do
        #4. 判断文件是否存在
        if [ -e $file ]
            then
                #5. 获取父目录
                pdir=$(cd -P $(dirname $file); pwd)
                #6. 获取当前文件的名称
                fname=$(basename $file)
                ssh $host "mkdir -p $pdir"
                rsync -av $pdir/$fname $host:$pdir
            else
                echo $file does not exists!
        fi
    done
done

节点docker0上执行解压命令:  由于其他两台机器docker1,docker2与docker0主机直接相互处于Xshell控制状态,在任何一个节点的相关命令都会同步到其他机器上

下面我们来看看docker0上的节点上的 ~/bin/xsync

[root@www bin]# ll
总用量 4
-rwxr-xr-x 1 root root 736 8月  21 20:53 xsync

1.3 将jdk分发到docker1,docker2服务器上

[root@www bin]# ./xsync  /usr/local/tools/jdk-8u371-linux-x64.tar.gz  
==================== docker0 ====================
sending incremental file list

sent 66 bytes  received 12 bytes  156.00 bytes/sec
total size is 139,219,380  speedup is 1,784,863.85
==================== docker1 ====================
sending incremental file list
jdk-8u371-linux-x64.tar.gz

sent 139,253,473 bytes  received 35 bytes  39,786,716.57 bytes/sec
total size is 139,219,380  speedup is 1.00
==================== docker2 ====================
sending incremental file list
jdk-8u371-linux-x64.tar.gz

sent 139,253,473 bytes  received 35 bytes  39,786,716.57 bytes/sec
total size is 139,219,380  speedup is 1.00

1.4 验证docker1与docker2的/usr/local/tools下该文件是否拷贝过去


 该脚本已生效:


二: 在节点docker0上解压zk安装包:

[root@www zookeeper]#

tar -zxvf /usr/local/tools/apache-zookeeper-3.9.0-bin.tar.gz -C /usr/local/zookeeper/


cd ~/bin/

[root@www bin]# ./xsync /usr/local/zookeeper/

将解压后的zookeeper文件全拷贝到docker1|docker2机器:

[root@www bin]# ./xsync /usr/local/zookeeper/
==================== docker0 ====================
sending incremental file list

sent 61,605 bytes  received 227 bytes  123,664.00 bytes/sec
total size is 390,744,347  speedup is 6,319.45
==================== docker1 ====================
sending incremental file list

sent 61,613 bytes  received 235 bytes  123,696.00 bytes/sec
total size is 390,744,347  speedup is 6,317.82
==================== docker2 ====================
sending incremental file list

sent 61,613 bytes  received 235 bytes  123,696.00 bytes/sec
total size is 390,744,347  speedup is 6,317.82
 


1.5 验证下是否已经拷贝过去:

 


后续补充完整............. 


 

http://www.lryc.cn/news/138066.html

相关文章:

  • python numpy array dtype和astype类型转换的区别
  • 浮动属性样式
  • keepalived双机热备 (四十五)
  • SpringBoot整合阿里云OSS,实现图片上传
  • Dynaminc Programming相关
  • 使用 Elasticsearch 轻松进行中文文本分类
  • MNN学习笔记(八):使用MNN推理Mediapipe模型
  • 主力吸筹指标及其分析和使用说明
  • Python高光谱遥感数据处理与高光谱遥感机器学习方法教程
  • 【洛谷】P1678 烦恼的高考志愿
  • 开机自启CPU设置定频
  • 嵌入式Linux开发实操(十二):PWM接口开发
  • 消息中间件介绍
  • [Unity] 基础的编程思想, 组件式开发
  • SVN 项目管理笔记
  • Android获取手机已安装应用列表JAVA实现
  • 【校招VIP】有一个比赛获奖项目和参与的开源小项目,秋招项目竞争力够不够?三个标准,自己都可以估算
  • 量化开发学习入门-概念篇
  • 【草稿】关于文本句子分割(中文+英文)以及向量处理
  • 【瑞吉外卖】所遇问题及解决方法
  • 【Hugo入门】基础用法
  • Java实现一个简单的图书管理系统(内有源码)
  • 网络安全等级保护2.0
  • 【sql】MongoDB 增删改查 高级用法
  • 怎么做才能有效更新和优化产品手册文档
  • #P0867. 小武老师的烤全羊
  • 视频汇聚/视频云存储/视频监控管理平台EasyCVR提升网络稳定小tips来啦!
  • C 语言学习
  • TCP网络连接异常情况的处理
  • 单片机之从C语言基础到专家编程 - 4 C语言基础 - 4.10语句