Redis高可用集群
Redis 的集群主從模型是一種高可用的集群架構。本章主要內容有:高可用集群的搭建,Jedis連接集群,新增集群節點,刪除集群節點,其他配置補充說明。
高可用集群搭建
集群(cluster)技術是一種較新的技術,通過集群技術,可以在付出較低成本的情況下獲得在性能、可靠性、靈活性方面的相對較高的收益,其任務調度則是集群系統中的核心技術。
Redis 3.0 之後便支持集群。Redis 集群中內置了 16384 個哈希槽。Redis 會根據節點數量大致均等的將哈希槽映射到不同的節點。
所有節點之間彼此互聯(PING-PONG機制),當超過半數的主機認為某臺主機掛了,則該主機就是真的掛掉了,整個集群就不可用了。
搭建前的準備工作
搭建ruby環境
redis集群管理工具 redis-trib.rb 是依賴 ruby 環境。
[root@itdragon ~]# yum install ruby
[root@itdragon ~]# yum install rubygems
[root@itdragon ~]# gem install redis
[root@itdragon ~]# cd redis-4.0.2/src/
[root@itdragon src]# cp redis-trib.rb /usr/local/redis-4/bin/
第一步:安裝 ruby 環境
第二步:安裝 gem 軟件包(gem是用來擴展或修改Ruby應用程序的)。
第三步:在redis解壓目錄中找到 redis-trib.rb 文件,將其拷貝到啟動redis服務的目錄下,方便管理。
可能存在的問題
1 redis requires Ruby version >= 2.2.2,解決方法如下
2 沒有/usr/local/rvm/scripts/rvm 這個目錄.可能是上一步執行失敗
[root@itdragon ~]# ruby --version
ruby 1.8.7 (2013-06-27 patchlevel 374) [x86_64-linux]
[root@itdragon ~]# yum install curl[root@itdragon ~]# curl -L get.rvm.io | bash -s stable
[root@itdragon ~]# source /usr/local/rvm/scripts/rvm
[root@itdragon ~]# rvm list known
[root@itdragon ~]# rvm install 2.3.3
[root@itdragon ~]# rvm use 2.3.3
[root@itdragon ~]# gem install redis
準備六臺redis服務器
和上一章節主從復制邏輯一樣,將redis.conf文件拷貝6次,端口從6000~6005
[root@itdragon bin]# cp redis.conf redis6000.conf
[root@itdragon bin]# vim redis6000.conf
port xxxx #修改端口
cluster-enabled yes #打開註釋,開啟集群模式
cluster-config-file nodes-xxxx.conf #集群的配置文件
pidfile /var/run/redis_xxxx.pid #pidfile文件
logfile "xxxx.log" #日誌文件
dbfilename dump_xxxx.rdb #rdb持久化文件
cluster-node-timeout 5000 #請求超時,單位毫秒
appendonly yes #開啟aof持久化方式
[root@itdragon bin]# vim start-all.sh
./redis-server redis6000.conf
./redis-server redis6001.conf
./redis-server redis6002.conf
./redis-server redis6003.conf
./redis-server redis6004.conf
./redis-server redis6005.conf
[root@itdragon bin]# chmod u+x start-all.sh
[root@itdragon bin]# ./start-all.sh
[root@itdragon bin]# ps aux | grep redis
root 28001 0.0 0.9 145964 9696 ? Ssl 17:45 0:00 ./redis-server 112.74.83.71:6000 [cluster]
root 28003 0.0 0.9 145964 9696 ? Ssl 17:45 0:00 ./redis-server 112.74.83.71:6001 [cluster]
root 28008 0.0 0.9 145964 9656 ? Ssl 17:45 0:00 ./redis-server 112.74.83.71:6002 [cluster]
root 28013 0.0 0.9 145964 9656 ? Ssl 17:45 0:00 ./redis-server 112.74.83.71:6003 [cluster]
root 28018 0.1 0.9 145964 9652 ? Ssl 17:45 0:00 ./redis-server 112.74.83.71:6004 [cluster]
root 28023 0.0 0.9 145964 9656 ? Ssl 17:45 0:00 ./redis-server 112.74.83.71:6005 [cluster]
第一步:復制六個redis.conf 並修改相關配置,如果覺得麻煩可以用我配置的文件:https://github.com/ITDragonBlog/daydayup/tree/master/Redis/reids.conf
第二步:新增批量開啟redis服務程序,並增加執行權限
第三步:查看六臺redis服務是否啟動成功
主從集群搭建
集群創建命令: ./redis-trib.rb create 創建集群,--replicas 1 給每個主機分配一個從機,後面其他參數都是redis服務的ip:port。最後輸入yes來接受建議的配置
第一步:搭建集群 ./redis-trib.rb create ,選擇yes接受建議的配置
第二步:進入集群客戶端 ./redis-cli -h 任意主機host -p 任意主機port -c,-c表示以集群方式連接redis
第三步:保存數據
第四步:cluster info 查詢集群狀態信息
第五步:cluster nodes 查詢集群結點信息,這裏有一個坑,後面會介紹
可能存在的問題
Sorry, the cluster configuration file nodes.conf is already used by a different Redis Cluster node. Please make sure that different nodes use different cluster configuration files.
說的很明確,修改cluster-config-file nodes.conf 文件避免重名,或者刪除該文件重新創建集群。
cluster nodes 查詢集群節點信息
這是很重要的命令,我們需要關心的信息有:
第一個參數:節點ID
第二個參數:IP:PORT@TCP 這裏一個坑,jedis-2.9.0之前的版本解析@出錯
第三個參數:標誌(Master,Slave,Myself,Fail...)
第四個參數:如果是從機則是主機的節點ID
最後兩個參數:連接的狀態和槽的位置。
Jedis 連接集群
首先要配置防火墻
[root@itdragon ~]# vim /etc/sysconfig/iptables
-A INPUT -p tcp -m tcp --dport 6000 -j ACCEPT
-A INPUT -p tcp -m tcp --dport 6001 -j ACCEPT
-A INPUT -p tcp -m tcp --dport 6002 -j ACCEPT
-A INPUT -p tcp -m tcp --dport 6003 -j ACCEPT
-A INPUT -p tcp -m tcp --dport 6004 -j ACCEPT
-A INPUT -p tcp -m tcp --dport 6005 -j ACCEPT
[root@itdragon ~]# service iptables restart
最後是整合Spring
單元測試
可能存在的問題
java.lang.NumberFormatException: For input string: "6002@16002"
若redis 的版本在4.0.0之上,建議使用jedis-2.9.0以上。
集群節點操作
添加主節點
[root@itdragon bin]# cp redis6005.conf redis6006.conf
[root@itdragon bin]# ./redis-server redis6006.conf
[root@itdragon bin]# ./redis-trib.rb add-node 112.74.83.71:6006 112.74.83.71:6000
[root@itdragon bin]# ./redis-cli -h 112.74.83.71 -p 6000 cluster nodes
916d26e9638dc51e168f32969da11e19c875f48f 112.74.83.71:6006@16006 master - 0 1512115612162 0 connected # 沒有分配槽
[root@itdragon bin]# ./redis-trib.rb reshard 112.74.83.71:6000
How many slots do you want to move (from 1 to 16384)? 500
What is the receiving node ID? 916d26e9638dc51e168f32969da11e19c875f48f
Please enter all the source node IDs.
Type ‘all‘ to use all the nodes as source nodes for the hash slots.
Type ‘done‘ once you entered all the source nodes IDs.
Source node #1:all
Do you want to proceed with the proposed reshard plan (yes/no)? yes
[root@itdragon bin]# ./redis-cli -h 112.74.83.71 -p 6000 cluster nodes
> 916d26e9638dc51e168f32969da11e19c875f48f 112.74.83.71:6006@16006 master - 0 1512116047897 7 connected 0-165 5461-5627 10923-11088
第一步:創建 redis6006.conf 的新主機,並啟動Redis服務
第二步:新增主機節點,若打印"[OK] New node added correctly." 表示添加成功
第三步:查詢集群節點信息,發現6006端口的主機雖然已經添加,但連接狀態後面沒有內容,即沒分配槽
第四步:給6006端口主機分配槽,
第一個參數:需要移動槽的個數,
第二個參數:接受槽的節點ID,
第三個參數:輸入"all"表示從所有原節點中獲取槽,
第四個參數:輸入"yes"開始移動槽到目標結點id
第五步:查詢集群節點信息,發現6006端口的主機已經分配了槽
核心命令:
./redis-trib.rb add-node 新增主機ip:port 集群任意節點ip:port
./redis-trib.rb reshard 集群任意節點ip:port
可能存在的問題
[ERR] Sorry, can‘t connect to node 112.74.83.71:6006
說明:新增的主機必須要是啟動狀態。
添加從節點
第一步:創建 redis6007.conf 的新主機,並啟動Redis服務
第二步:新增從機節點,在原來的命令上多了 --slave --master-id 主節點ID
第三步:查詢集群節點信息
刪除結點
刪除節點前,要確保該節點沒有值,否則提示:is not empty! Reshard data away and try again. 若該節點有值,則需要把槽分配出去
./redis-trib.rb del-node 112.74.83.71:6006 916d26e9638dc51e168f32969da11e19c875f48f
配置文件補充
前幾章Redis教程中介紹了以下配置
1 開啟Redis 的守護進程 :daemonize yes
2 指定pid文件寫入文件名 :pidfile /var/run/redis.pid
3 指定Redis 端口:port 6379
4 綁定的主機地址 :bind 127.0.0.1
5 Redis持久化默認開啟壓縮數據:rdbcompression yes
6 指定rdb文件名:dbfilename dump.rdb
7 指定rdb文件位置:dir ./
8 從機啟動時,它會自動從master進行數據同步:slaveof < masterip> < masterport>
9 開啟aof持久化方式:appendonly yes
10 指定aof文件名:appendfilename appendonly.aof
11 觸發aof快照機制:appendfsync everysec (no/always)
本章節是Redis教程中的最後一章,把剩下的配置也一起說了吧
1 設置客戶端連接超時時間,0表示關閉 :timeout 300
2 設置Redis日誌級別,debug、verbose(默認)、notice、warning:loglevel verbose
3 設置數據庫的數量:databases 16
4 設置Redis連接密碼:requirepass foobared
5 設置同一時間最大客戶端連接數,默認無限制:maxclients 128
6 指定Redis最大內存限制:maxmemory < bytes>
7 指定是否啟用虛擬內存機制:vm-enabled no
8 指定虛擬內存文件路徑:vm-swap-file /tmp/redis.swap
9 指定包含其它的配置文件:include /path/to/local.conf
到這裏Redis 的教程就結束了,還有其他知識可以訪問官網學習。有什麽不對的地方請指正。謝謝!
Redis高可用集群