Redis---最小高可用性クラスタ配置
6410 ワード
Redisの配置は
オペレーティングシステム: サーバ: ポート: バージョン番号:
実行スクリプト
3台のサーバに6つのノードを配置した後、クラスタ構成の実行を開始します.CentOS 7がyumを使用するインストールのrubyは2.0.0バージョンであり、redisの要件に合致しないため、rvmを使用して更新バージョンをインストールする.
sudo: ruby: command not found: sudo env "PATH=$PATH"ruby no such file to load -- zlib make: *** No rule to make target
Redis---単一インスタンスクラスタモード Redisクラスタモード配置
6
台のサーバーが望ましいが、業務量が足りないため、資源を節約するために、私たちは3
台のサーバーだけを使用して、1台のサーバーに2つのノードを配置しても、高可用性を実現することができるが、Redisの主従配置が合理的かどうかを常に監視し、3つの主節がそれぞれ3台のサーバーにあることを保証し、いずれか2つの主節が同じサーバーに分布している場合、調整が必要である.環境の例
CentOS 7.2
192.168.58.201, 192.168.58.203, 192.168.58.205
6379,6380
4.0.11
Redisサーバのインストール
wget http://download.redis.io/releases/redis-4.0.11.tar.gz
tar xzf redis-4.0.11.tar.gz
cd redis-4.0.11
make
sudo make install
導入インスタンス(サーバごとに2つのインスタンス)
実行スクリプト
./setup.sh
、スクリプトの内容は次のとおりです.#!/usr/bin/env bash
set -x
## configuration
port1=6379
port2=6380
version=4.0.11
basepath=$(cd `dirname $0`; pwd)
## config two redis
cd ${basepath}
mkdir redis-${port1} redis-${port2}
cp redis-4.0.11/redis.conf ./
sed -i 's/^bind 127.0.0.1$/# bind 127.0.0.1/g' redis.conf
sed -i 's/^daemonize no$/daemonize yes/g' redis.conf
sed -i "s/^pidfile \/var\/run\/redis_${port1}.pid$/pidfile redis.pid/g" redis.conf
sed -i 's/^# cluster-enabled yes$/cluster-enabled yes/g' redis.conf
sed -i 's/^# cluster-config-file nodes-${port1}.conf$/cluster-config-file nodes.conf/g' redis.conf
sed -i 's/^protected-mode yes$/protected-mode no/g' redis.conf
sed -i 's/^logfile ""$/logfile "redis.log"/g' redis.conf
sed "s/^port 6379$/port ${port1}/g" redis.conf > redis-${port1}/redis.conf
sed "s/^port 6379$/port ${port2}/g" redis.conf > redis-${port2}/redis.conf
sed -i "s|^dir .\/$|dir ${basepath}/redis-${port1}|g" redis-${port1}/redis.conf
sed -i "s|^dir .\/$|dir ${basepath}/redis-${port2}|g" redis-${port2}/redis.conf
## clean
rm redis.conf
## start
redis-server redis-${port1}/redis.conf
redis-server redis-${port2}/redis.conf
クラスタ構成
3台のサーバに6つのノードを配置した後、クラスタ構成の実行を開始します.CentOS 7がyumを使用するインストールのrubyは2.0.0バージョンであり、redisの要件に合致しないため、rvmを使用して更新バージョンをインストールする.
RVMのインストール
$ gpg --keyserver hkp://keys.gnupg.net --recv-keys 409B6B1796C275462A1703113804BB82D39DC0E3 7D2BAF1CF37B13E2069D6956105BD0E739499BDB
$ \curl -sSL https://get.rvm.io | bash -s stable
* To start using RVM you need to run `source /home/user/.rvm/scripts/rvm`
in all your open shell windows, in rare cases you need to reopen all shell windows.
$ source /home/user/.rvm/scripts/rvm
インストールruby
現在ruby 2を使用する.5.1
# ruby
rvm install 2.5.1
#
rvm use 2.5.1
#
ruby --version
インストールgem
tar xzf rubygems-2.7.7.tgz
cd rubygems-2.7.7
sudo ruby setup.rb
# :sudo: ruby: command not found,
sudo env "PATH=$PATH" ruby setup.rb
redis gemのインストール
# gem
gem install redis
# gem
wget https://rubygems.org/downloads/redis-4.0.2.gem
sudo gem install --force --local redis-4.0.2.gem
# :sudo: gem: command not found,
sudo env "PATH=$PATH" gem install --force --local redis-4.0.2.gem
コンフィギュレーション
$ redis-4.0.11/src/redis-trib.rb create --replicas 1 192.168.58.201:6379 192.168.58.201:6380
>>> Creating cluster
>>> Performing hash slots allocation on 6 nodes...
Using 3 masters:
192.168.58.201:6379
192.168.58.203:6379
192.168.58.205:6379
Adding replica 192.168.58.203:6380 to 192.168.58.201:6379
Adding replica 192.168.58.205:6380 to 192.168.58.203:6379
Adding replica 192.168.58.201:6380 to 192.168.58.205:6379
M: ae78bc405cfedda5905bd0574ac2250a86cb363c 192.168.58.201:6379
slots:0-5460 (5461 slots) master
S: ee1b2d1e064dd82bea1adba3bda988fcfa02d613 192.168.58.201:6380
replicates 3f90145d7e97e9c3c8ce508aebe343f4181ddea3
M: eb289f0ea74a04bc7e743a461fd845e7d6c82549 192.168.58.203:6379
slots:5461-10922 (5462 slots) master
S: 83fff732d029621d71d3b8e30773d6ce1043d389 192.168.58.203:6380
replicates ae78bc405cfedda5905bd0574ac2250a86cb363c
M: 3f90145d7e97e9c3c8ce508aebe343f4181ddea3 192.168.58.205:6379
slots:10923-16383 (5461 slots) master
S: 2b962ca992c64a40e57edde4ac4d51d0ec201f62 192.168.58.205:6380
replicates eb289f0ea74a04bc7e743a461fd845e7d6c82549
Can I set the above configuration? (type 'yes' to accept): yes
>>> Nodes configuration updated
>>> Assign a different config epoch to each node
>>> Sending CLUSTER MEET messages to join the cluster
Waiting for the cluster to join.....
>>> Performing Cluster Check (using node 192.168.58.201:6379)
M: ae78bc405cfedda5905bd0574ac2250a86cb363c 192.168.58.201:6379
slots:0-5460 (5461 slots) master
1 additional replica(s)
M: eb289f0ea74a04bc7e743a461fd845e7d6c82549 192.168.58.203:6379
slots:5461-10922 (5462 slots) master
1 additional replica(s)
S: 83fff732d029621d71d3b8e30773d6ce1043d389 192.168.58.203:6380
slots: (0 slots) slave
replicates ae78bc405cfedda5905bd0574ac2250a86cb363c
S: ee1b2d1e064dd82bea1adba3bda988fcfa02d613 192.168.58.201:6380
slots: (0 slots) slave
replicates 3f90145d7e97e9c3c8ce508aebe343f4181ddea3
S: 2b962ca992c64a40e57edde4ac4d51d0ec201f62 192.168.58.205:6380
slots: (0 slots) slave
replicates eb289f0ea74a04bc7e743a461fd845e7d6c82549
M: 3f90145d7e97e9c3c8ce508aebe343f4181ddea3 192.168.58.205:6379
slots:10923-16383 (5461 slots) master
1 additional replica(s)
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All 16384 slots covered.192.168.58.203:6379 192.168.58.203:6380 192.168.58.205:6379 192.168.58.205:6380
よくある質問
yum -y install zlib-devel
# ruby , ruby zlib
cd ruby-2.5.1/ext/zlib
ruby ./extconf.rb
make
make install
/include/ruby.h', needed by
zlib.o' vim Makefile
#zlib.o: $(top_srcdir)/include/ruby.h #
zlib.o: ../../include/ruby.h