aboutsummaryrefslogtreecommitdiff
path: root/zookeeper/init/on-change.sh
blob: bb9a5049e401b0d224a2bb9f0e131627fe75fed6 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
#! /bin/bash

# Copyright 2016 The Kubernetes Authors All rights reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

# This script configures zookeeper cluster member ship for version of zookeeper
# < 3.5.0. It should not be used with the on-start.sh script in this example.
# As of April-2016 is 3.4.8 is the latest stable.

CFG=/opt/zookeeper/conf/zoo.cfg
CFG_BAK=/opt/zookeeper/conf/zoo.cfg.bak
MY_ID=/tmp/zookeeper/myid

# write myid
IFS='-' read -ra ADDR <<< "$(hostname)"
echo $(expr "1" + "${ADDR[1]}") > "${MY_ID}"

# TODO: This is a dumb way to reconfigure zookeeper because it allows dynamic
# reconfig, but it's simple.
i=0
echo "
tickTime=2000
initLimit=10
syncLimit=5
dataDir=/tmp/zookeeper
clientPort=2181
" > "${CFG_BAK}"

while read -ra LINE; do
    let i=i+1
    echo "server.${i}=${LINE}:2888:3888" >> "${CFG_BAK}"
done
cp ${CFG_BAK} ${CFG}

# TODO: Typically one needs to first add a new member as an "observer" then
# promote it to "participant", but that requirement is relaxed if we never
# start > 1 at a time.
/opt/zookeeper/bin/zkServer.sh restart