佳木斯湛栽影视文化发展公司

主頁 > 知識(shí)庫 > Shell腳本實(shí)現(xiàn)自動(dòng)安裝zookeeper

Shell腳本實(shí)現(xiàn)自動(dòng)安裝zookeeper

熱門標(biāo)簽:地方門戶網(wǎng)站 服務(wù)外包 鐵路電話系統(tǒng) Linux服務(wù)器 呼叫中心市場需求 百度競價(jià)排名 網(wǎng)站排名優(yōu)化 AI電銷

A:本腳本運(yùn)行的機(jī)器,Linux RHEL6
B,C,D,...:待安裝zookeeper cluster的機(jī)器, Linux RHEL6

首先在腳本運(yùn)行的機(jī)器A上確定可以ssh無密碼登錄到待安裝zk的機(jī)器B,C,D,...上,然后就可以在A上運(yùn)行本腳本:

復(fù)制代碼 代碼如下:

$ ./install_zookeeper 

前提:

B, C, D機(jī)器必須配置好repo,本腳本使用的是cdh5的repo, 下面的內(nèi)容保存到:/etc/yum.repos.d/cloudera-cdh5.repo:

復(fù)制代碼 代碼如下:

[cloudera-cdh5] 
# Packages for Cloudera's Distribution for Hadoop, Version 5, on RedHat or CentOS 6 x86_64 
name=Cloudera's Distribution for Hadoop, Version 5 
baseurl=http://archive.cloudera.com/cdh5/redhat/6/x86_64/cdh/5/ 
gpgkey = http://archive.cloudera.com/cdh5/redhat/6/x86_64/cdh/RPM-GPG-KEY-cloudera     
gpgcheck = 1 
enabled  = 1 

自動(dòng)安裝腳本將自動(dòng)在B,C,D機(jī)器上安裝好zookeeper, 配置好相關(guān)配置文件。但沒有啟動(dòng)它們。支持1,3,5,7個(gè)服務(wù)器。

復(fù)制代碼 代碼如下:

#!/bin/bash 

# @file 
#   install_zookeeper.sh 

# @date 
#   2014-12-21 

# @author 
#   cheungmine@hgdb.net 

# @version 
#   0.0.1pre 

# @usage 
#   ./install_zookeeper.sh 
################################################################################ 
 
#*********************************************************** 
# split_to_array 
#   split string into array 
#*********************************************************** 
function split_to_array() { 
    OLD_IFS="$IFS" 
    IFS="$2" 
    array=($1) 
    IFS="$OLD_IFS" 

 
 
#*********************************************************** 
# install_zookeeper 
#   install zookeeper on 1, 3 or 5 servers 

# Parameters: 
#   clientPort - the port at which the clients will connect to 
#   servers - varying arguments: 1, 3, 5, up to 7 
#     "zkServer:serverPort:appPort" 
#     zkServer - ipaddr of zookeeper server 
#     serverPort - communication port for zookeeper servers 
#     appPort - communication port between zookeeper with other applications 

# Example: 
#   1) install_zookeeper 2181 zk1 zk2 zk3 
#   2) install_zookeeper 2181 192.168.122.201 192.168.122.202 192.168.122.203 
#   3) install_zookeeper "2181" "192.168.122.201:2888:3888" "192.168.122.202:2888:3888" "192.168.122.203:2888:3888" 
#   4) install_zookeeper "2181:/var/lib/zookeeper" "192.168.122.201:2888:3888" "192.168.122.202:2888:3888" "192.168.122.203:2888:3888" 
#*********************************************************** 
ERR_INVALID_ZK_SERVERS=1001 
 
function install_zookeeper() { 
    echo -e "INFO> install zookeeper on cluster ..." 
    #chk_root 
 
    local ret clientPort dataDir len i ZOO_CFG server serverPort appPort destip destlogin 
 
    serverPort=2888 
    appPort=3888 
 
    # parse the first argument 
    split_to_array $1 ":" 
 
    # the port at which the clients will connect 
    clientPort=${array[0]} 
 
    # the directory where the snapshot is stored 
    dataDir="/var/lib/zookeeper" 
    if [ ${#array[*]} -eq 2 ]; then 
        dataDir=${array[1]} 
    fi 
 
    echo -e "INFO> clientPort: $clientPort" 
    echo -e "INFO> dataDir: $dataDir" 
 
    # zookeeper configure file 
    ZOO_CFG="/usr/lib/zookeeper/conf/zoo.cfg" 
 
    # get list of servers: args 
    shift 
    local argc=$# 
 
    if [ $argc -eq 1 -o $argc -eq 3 -o $argc -eq 5 -o $argc -eq 7 ]; then 
        echo -e "INFO> zookeeper servers in cluster: [$argc]" 
    else 
        echo -e "ERROR> invalid zookeeper servers: [$argc]" 
        exit $ERR_INVALID_ZK_SERVERS; 
    fi 
 
    local argv="$@" 
 
    OLD_IFS="$IFS" 
    IFS=" " 
    local args=($argv) 
    IFS="$OLD_IFS" 
 
    # array variable 
    local ipaddrs=() 
    local servers=() 
 
    local sid=0 
    for a in ${args[@]} 
    do 
        let sid++ 
 
        # check if server format is either of: 
        #   serverIP 
        # or: 
        #   serverIP:serverPort:appPort 
        split_to_array $a ":" 
        serverIP=${array[0]} 
 
        if [ ${#array[*]} -ne 3 ]; then 
            a="$serverIP:$serverPort:$appPort"; 
        fi 
 
        local server="server.$sid=$a" 
        servers[sid-1]=$server 
        echo $server 
 
        ipaddrs[sid-1]=$serverIP 
    done 
 
    # output array to one line string: echo ${servers[@]} 
    # get length of array 
    len=${#servers[*]} 
    i=0 
    while [ $i -lt $len ] 
    do 
        let sid=i+1 
        destip=${ipaddrs[$i]} 
        destlogin=root@$destip 
        echo -e "INFO> configuring server.$sid: $destip ...\c" 
 
        ret=`ssh $destlogin "yum install -y zookeeper zookeeper-server service zookeeper-server init --myid=$sid"` 
 
        ret=`ssh $destlogin "echo '#!{{install_zookeeper@hgdb.net==>' >> $ZOO_CFG"` 
 
        for s in ${servers[*]} 
        do 
            ret=`ssh $destlogin "echo '$s' >> $ZOO_CFG"` 
        done 
 
        ret=`ssh $destlogin "echo '#!==install_zookeeper@hgdb.net}}' >> $ZOO_CFG"` 
 
        echo -e "OK." 
 
        let i++ 
    done 
 
    echo "INFO> zookeeper cluster installation completed successfully!" 

 
#======================================================================= 
install_zookeeper "2181" "192.168.122.201" "192.168.122.202" "192.168.122.203" 

根據(jù)配置修改最后一行:

復(fù)制代碼 代碼如下:

install_zookeeper "2181" "192.168.122.201" "192.168.122.202" "192.168.122.203"

注意:需要把zk-cluster的每臺(tái)機(jī)器上的防火墻停掉,再啟動(dòng)zookeeper:

復(fù)制代碼 代碼如下:

$ /usr/lib/zookeeper/bin/zkServer.sh start-foreground

您可能感興趣的文章:
  • centos7下搭建ZooKeeper3.4中間件常用命令小結(jié)
  • 基于Zookeeper的使用詳解
  • 理解zookeeper選舉機(jī)制
  • 為zookeeper配置相應(yīng)的acl權(quán)限
  • 深入淺析ZooKeeper的工作原理
  • Docker搭建Zookeeper&Kafka集群的實(shí)現(xiàn)
  • centos6使用docker部署redis主從數(shù)據(jù)庫操作示例
  • centos6使用docker部署kafka項(xiàng)目的方法分析
  • CentOS8上用Docker部署開源項(xiàng)目Tcloud的教程
  • centos6使用docker部署zookeeper操作示例

標(biāo)簽:湘潭 蘭州 仙桃 衡水 崇左 黃山 湖南 銅川

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Shell腳本實(shí)現(xiàn)自動(dòng)安裝zookeeper》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    义马市| 乌鲁木齐市| 陵川县| 岑溪市| 壤塘县| 呼图壁县| 千阳县| 胶州市| 阜平县| 兰坪| 新野县| 宁晋县| 普安县| 邹城市| 射洪县| 沈阳市| 南昌市| 太康县| 杂多县| 客服| 邯郸市| 顺平县| 甘泉县| 黄平县| 察哈| 庆云县| 宁武县| 合阳县| 云浮市| 平湖市| 西宁市| 苍山县| 喀喇| 临沂市| 台南市| 资源县| 新竹县| 高阳县| 博客| 白银市| 读书|