Redis---最小高可用性クラスタ配置

6410 ワード

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
    

    よくある質問

  • sudo: ruby: command not found: sudo env "PATH=$PATH"ruby
  • no such file to load -- zlib
  • yum -y install zlib-devel
    #  ruby     ,  ruby     zlib 
    cd ruby-2.5.1/ext/zlib
    ruby ./extconf.rb
    make
    make install
    
  • make: *** No rule to make target /include/ruby.h', needed by zlib.o'
  • vim Makefile
    #zlib.o: $(top_srcdir)/include/ruby.h #           
    zlib.o: ../../include/ruby.h
    

    Redisシリーズ

  • Redis---単一インスタンスクラスタモード
  • リファレンス

  • Redisクラスタモード配置