国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

服務器之家 - 數據庫 - Redis - Redis 6.X Cluster 集群搭建

Redis 6.X Cluster 集群搭建

2021-04-07 00:46碼哥字節MageByte Redis

碼哥帶大家完成在 CentOS 7 中安裝 Redis 6.x 教程。在學習 Redis Cluster 集群之前,我們需要先搭建一套集群環境。機器有限,實現目標是一臺機器上搭建 6 個節點,構成一個三主三從集群模式。

Redis 6.X Cluster 集群搭建

 Part1Redis 6.X Cluster 集群搭建

 

碼哥帶大家完成在 CentOS 7 中安裝 Redis 6.x 教程。在學習 Redis Cluster 集群之前,我們需要先搭建一套集群環境。機器有限,實現目標是一臺機器上搭建 6 個節點,構成一個三主三從集群模式。

1下載解壓

 

可直接到 Redis 官網下載最新穩定包,地址:https://redis.io/download。或者使用 命令:sudo wget http://download.redis.io/releases/redis-6.0.9.tar.gz 下載安裝包.。

碼哥統一把軟件包放在 /opt/soft 目錄下,并創建目錄 mkdir redisCluster用于放置集群配置文件。在 redisCluster 目錄下執行 mkdir 7000 7001 7002 7003 7004 7005 創建 6 個目錄分別對應每個節點 redis.conf 配置模板。

tar -zxf redis-6.0.9.tar.gz -C redisCluster 解壓到 redisCluster 目錄中。

2make 編譯

 

在編譯之前我們需要確認 gcc 版本,自 redis 6.0.0 之后,編譯 redis 需要支持 C11 特性,C11 特性在 4.9 中被引入。Centos 7 默認 gcc 版本為 4.8.5,所以需要升級gcc版本。

編譯錯誤

 

否則在編譯過程中會遇到如下錯誤日志:

  1. In file included from server.c:31:0: 
  2. server.c:4999:59: error: ‘struct redisServer’ has no member named ‘cluster’ 
  3.              (server.cluster_enabled && nodeIsMaster(server.cluster->myself))); 
  4.                                                            ^ 
  5. cluster.h:58:27: note: in definition of macro ‘nodeIsMaster’ 
  6.  #define nodeIsMaster(n) ((n)->flags & CLUSTER_NODE_MASTER) 
  7.                            ^ 
  8. server.c: In function ‘main’: 
  9. server.c:5047:11: error: ‘struct redisServer’ has no member named ‘sentinel_mode’ 
  10.      server.sentinel_mode = checkForSentinelMode(argc,argv); 
  11.            ^ 
  12. server.c:5064:15: error: ‘struct redisServer’ has no member named ‘sentinel_mode’ 
  13.      if (server.sentinel_mode) { 
  14.                ^ 
  15. server.c:5131:19: error: ‘struct redisServer’ has no member named ‘sentinel_mode’ 
  16.          if (server.sentinel_mode && configfile && *configfile == '-') { 
  17.                    ^ 
  18. server.c:5153:168: error: ‘struct redisServer’ has no member named ‘sentinel_mode’ 
  19.          serverLog(LL_WARNING, "Warning: no config file specified, using the default config. In order to specify a config file use %s /path/to/%s.conf", argv[0], server.sentinel_mode ? "sentinel" : "redis"); 
  20.                                                                                                                                                                         ^ 
  21. server.c:5158:11: error: ‘struct redisServer’ has no member named ‘supervised’ 
  22.      server.supervised = redisIsSupervised(server.supervised_mode); 
  23.            ^ 
  24. server.c:5158:49: error: ‘struct redisServer’ has no member named ‘supervised_mode’ 
  25.      server.supervised = redisIsSupervised(server.supervised_mode); 
  26.                                                  ^ 
  27. server.c:5159:28: error: ‘struct redisServer’ has no member named ‘daemonize’ 
  28.      int background = server.daemonize && !server.supervised; 
  29.                             ^ 
  30. server.c:5159:49: error: ‘struct redisServer’ has no member named ‘supervised’ 
  31.      int background = server.daemonize && !server.supervised; 
  32.                                                  ^ 
  33. server.c:5163:29: error: ‘struct redisServer’ has no member named ‘pidfile’ 
  34.      if (background || server.pidfile) createPidFile(); 
  35.                              ^ 
  36. server.c:5168:16: error: ‘struct redisServer’ has no member named ‘sentinel_mode’ 
  37.      if (!server.sentinel_mode) { 
  38.                 ^ 
  39. server.c:5178:19: error: ‘struct redisServer’ has no member named ‘cluster_enabled’ 
  40.          if (server.cluster_enabled) { 
  41.                    ^ 
  42. server.c:5186:19: error: ‘struct redisServer’ has no member named ‘ipfd_count’ 
  43.          if (server.ipfd_count > 0 || server.tlsfd_count > 0) 
  44.                    ^ 
  45. server.c:5186:44: error: ‘struct redisServer’ has no member named ‘tlsfd_count’ 
  46.          if (server.ipfd_count > 0 || server.tlsfd_count > 0) 
  47.                                             ^ 
  48. server.c:5188:19: error: ‘struct redisServer’ has no member named ‘sofd’ 
  49.          if (server.sofd > 0) 
  50.                    ^ 
  51. server.c:5189:94: error: ‘struct redisServer’ has no member named ‘unixsocket’ 
  52.              serverLog(LL_NOTICE,"The server is now ready to accept connections at %s", server.unixsocket); 
  53.                                                                                               ^ 
  54. server.c:5190:19: error: ‘struct redisServer’ has no member named ‘supervised_mode’ 
  55.          if (server.supervised_mode == SUPERVISED_SYSTEMD) { 
  56.                    ^ 
  57. server.c:5191:24: error: ‘struct redisServer’ has no member named ‘masterhost’ 
  58.              if (!server.masterhost) { 
  59.                         ^ 
  60. server.c:5201:19: error: ‘struct redisServer’ has no member named ‘supervised_mode’ 
  61.          if (server.supervised_mode == SUPERVISED_SYSTEMD) { 
  62.                    ^ 
  63. server.c:5208:15: error: ‘struct redisServer’ has no member named ‘maxmemory’ 
  64.      if (server.maxmemory > 0 && server.maxmemory < 1024*1024) { 
  65.                ^ 
  66. server.c:5208:39: error: ‘struct redisServer’ has no member named ‘maxmemory’ 
  67.      if (server.maxmemory > 0 && server.maxmemory < 1024*1024) { 
  68.                                        ^ 
  69. server.c:5209:176: error: ‘struct redisServer’ has no member named ‘maxmemory’ 
  70.          serverLog(LL_WARNING,"WARNING: You specified a maxmemory value that is less than 1MB (current value is %llu bytes). Are you sure this is what you really want?", server.maxmemory); 
  71.                                                                                                                                                                                 ^ 
  72. server.c:5212:31: error: ‘struct redisServer’ has no member named ‘server_cpulist’ 
  73.      redisSetCpuAffinity(server.server_cpulist); 
  74.                                ^ 
  75. server.c: In function ‘hasActiveChildProcess’: 
  76. server.c:1480:1: warning: control reaches end of non-void function [-Wreturn-type] 
  77.  } 
  78.  ^ 
  79. server.c: In function ‘allPersistenceDisabled’: 
  80. server.c:1486:1: warning: control reaches end of non-void function [-Wreturn-type] 
  81.  } 
  82.  ^ 
  83. server.c: In function ‘writeCommandsDeniedByDiskError’: 
  84. server.c:3826:1: warning: control reaches end of non-void function [-Wreturn-type] 
  85.  } 
  86.  ^ 
  87. server.c: In function ‘iAmMaster’: 
  88. server.c:5000:1: warning: control reaches end of non-void function [-Wreturn-type] 
  89.  } 
  90.  ^ 
  91.  .... 

解決方式

 

  1. yum -y install gcc gcc-c++ make tcl 
  2. yum -y install centos-release-scl 
  3. yum -y install devtoolset-9-gcc devtoolset-9-gcc-c++ devtoolset-9-binutils 
  4. scl enable devtoolset-9 bash 

升級之后便可解決 make 報錯問題。

注意:scl命令啟用只是臨時的,退出xshell或者重啟就會恢復到原來的gcc版本。如果要長期生效的話,執行如下 sudo echo "source /opt/rh/devtoolset-9/enable" >>/etc/profile。

cd /opt/soft/redisCluster/redis-6.0.9 切換到目錄執行 make 。

編譯完成使用 make install 對 redis 進行安裝 ,命令:sudo make install。

3修改配置文件

 

cd /opt/soft/redisCluster/redis-6.0.9 將 redis.conf 分別復制到 7000 7001 7002 7003 7004 目錄中。

分別修改 6 個 redis.conf

  1. ## 7000-7005端口 
  2. port 7000 
  3. ## 后臺啟動 
  4. daemonize yes 
  5. ## 如果是在單機模擬集群必須指定bind的IP,如果不修改ip的話使用程序連接集群會報錯 
  6. bind 192.168.221.150 
  7. ## 開啟redis-cluster集群 
  8. cluster-enabled yes 
  9. ## 每個實例還包含存儲此節點配置的文件的路徑,默認情況下為nodes.conf,自動創建 
  10. cluster-config-file nodes_7000.conf 
  11. ## 超時 
  12. cluster-node-timeout 500 
  13. ## 開啟aof 
  14. appendonly yes 
  15.   
  16. #注釋cluster集群下不允許復制。 
  17. #replicaof 127.0.0.1 9000 
  18. #關閉保護模式,如果開啟需要設置密碼,比較繁瑣,可根據自己的需求來 
  19. protected-mode no 

每個配置文件只需要修改 port 和 cluster-config-file 就可以了。

4啟動節點并創建集群

 

啟動節點

進入 redisCluster 目錄,執行指令依次啟動每個節點。redis-6.0.9/src/redis-server 700x/redis.conf 注意指定每個節點配置文件,如果不指定配置文件會默認使用src下的配置。

創建集群

進入任意一個節點,執行以下指令創建集群

指令如下:

  1. redis-6.0.9/src/redis-cli --cluster create 172.16.90.152:7000 172.16.90.152:7001 172.16.90.152:7002 172.16.90.152:7003 172.16.90.152:7004 172.16.90.152:7005 --cluster-replicas 1 

集群參數解釋:

  • cluster-replicas 1:表示希望為集群中的每個主節點創建一個從節點(一主一從)。
  • cluster-replicas 2:表示希望為集群中的每個主節點創建兩個從節點(一主二從)。

控制臺響應:

  1. >>> Performing hash slots allocation on 6 nodes... 
  2. Master[0] -> Slots 0 - 5460 
  3. Master[1] -> Slots 5461 - 10922 
  4. Master[2] -> Slots 10923 - 16383 
  5. Adding replica 172.16.90.152:7004 to 172.16.90.152:7000 
  6. Adding replica 172.16.90.152:7005 to 172.16.90.152:7001 
  7. Adding replica 172.16.90.152:7003 to 172.16.90.152:7002 
  8. >>> Trying to optimize slaves allocation for anti-affinity 
  9. [WARNING] Some slaves are in the same host as their master 
  10. M: 06c56f5a6a4436108fae931be499465985141d39 172.16.90.152:7000 
  11.    slots:[0-5460] (5461 slots) master 
  12. M: 0ab7c9efd97319d94a8ea52452ec58f7708d812d 172.16.90.152:7001 
  13.    slots:[5461-10922] (5462 slots) master 
  14. M: 096f076d99363270c02785a2fb298e2ee65d3f07 172.16.90.152:7002 
  15.    slots:[10923-16383] (5461 slots) master 
  16. S: 69d621060295eb433af3e34e702142df0fd4d73d 172.16.90.152:7003 
  17.    replicates 06c56f5a6a4436108fae931be499465985141d39 
  18. S: 1d37df0aa0e2310aedb5a380f95cc818256003f8 172.16.90.152:7004 
  19.    replicates 0ab7c9efd97319d94a8ea52452ec58f7708d812d 
  20. S: d9204f6da875a4b2522c5fa25d9e6c1f95cf51ea 172.16.90.152:7005 
  21.    replicates 096f076d99363270c02785a2fb298e2ee65d3f07 
  22. Can I set the above configuration? (type 'yes' to accept): 

Can I set the above configuration? (type 'yes' to accept): 詢問是否確認節點 slots 分配方案, 我們輸入 ‘yes’。

  1. >>> Nodes configuration updated 
  2. >>> Assign a different config epoch to each node 
  3. >>> Sending CLUSTER MEET messages to join the cluster 
  4. Waiting for the cluster to join 
  5. >>> Performing Cluster Check (using node 172.16.90.152:7000) 
  6. M: 06c56f5a6a4436108fae931be499465985141d39 172.16.90.152:7000 
  7.    slots:[0-5460] (5461 slots) master 
  8.    1 additional replica(s) 
  9. S: 1d37df0aa0e2310aedb5a380f95cc818256003f8 172.16.90.152:7004 
  10.    slots: (0 slots) slave 
  11.    replicates 0ab7c9efd97319d94a8ea52452ec58f7708d812d 
  12. M: 0ab7c9efd97319d94a8ea52452ec58f7708d812d 172.16.90.152:7001 
  13.    slots:[5461-10922] (5462 slots) master 
  14.    1 additional replica(s) 
  15. S: d9204f6da875a4b2522c5fa25d9e6c1f95cf51ea 172.16.90.152:7005 
  16.    slots: (0 slots) slave 
  17.    replicates 096f076d99363270c02785a2fb298e2ee65d3f07 
  18. S: 69d621060295eb433af3e34e702142df0fd4d73d 172.16.90.152:7003 
  19.    slots: (0 slots) slave 
  20.    replicates 06c56f5a6a4436108fae931be499465985141d39 
  21. M: 096f076d99363270c02785a2fb298e2ee65d3f07 172.16.90.152:7002 
  22.    slots:[10923-16383] (5461 slots) master 
  23.    1 additional replica(s) 
  24. [OK] All nodes agree about slots configuration. 
  25. >>> Check for open slots... 
  26. >>> Check slots coverage... 
  27. [OK] All 16384 slots covered. 

[OK] All 16384 slots covered.

到此完成!

5查看集群狀態

 

redis-6.0.9/src/redis-cli --cluster check 172.16.90.152:7000

6注意事項

 

當使用 redis-6.0.9/src/redis-cli --cluster create 172.16.90.152:7000 172.16.90.152:7001 172.16.90.152:7002 172.16.90.152:7003 172.16.90.152:7004 172.16.90.152:7005 --cluster-replicas 1 創建集群以后,一次創建,永久使用。之后直接啟動每個節點即可構建集群。

結束命令:redis-6.0.9/src/redis-cli -c -h 192.168.124.23 -p 7004 shutdown

進入集群命令 redis-cli -c -h host -p prot 不帶-c 參數進入的不是集群

搭建好集群后,期待下一篇「Redis 高可用篇:Cluster 能支持的數據有多大?」

原文地址:https://mp.weixin.qq.com/s/gmTCxw92Ts0-lJs61DKztA

延伸 · 閱讀

精彩推薦
  • Redis詳解Redis復制原理

    詳解Redis復制原理

    與大多數db一樣,Redis也提供了復制機制,以滿足故障恢復和負載均衡等需求。復制也是Redis高可用的基礎,哨兵和集群都是建立在復制基礎上實現高可用的...

    李留廣10222021-08-09
  • Redisredis實現排行榜功能

    redis實現排行榜功能

    排行榜在很多地方都能使用到,redis的zset可以很方便地用來實現排行榜功能,本文就來簡單的介紹一下如何使用,具有一定的參考價值,感興趣的小伙伴們...

    乘月歸5022021-08-05
  • RedisRedis 事務知識點相關總結

    Redis 事務知識點相關總結

    這篇文章主要介紹了Redis 事務相關總結,幫助大家更好的理解和學習使用Redis,感興趣的朋友可以了解下...

    AsiaYe8232021-07-28
  • RedisRedis如何實現數據庫讀寫分離詳解

    Redis如何實現數據庫讀寫分離詳解

    Redis的主從架構,能幫助我們實現讀多,寫少的情況,下面這篇文章主要給大家介紹了關于Redis如何實現數據庫讀寫分離的相關資料,文中通過示例代碼介紹...

    羅兵漂流記6092019-11-11
  • RedisRedis全量復制與部分復制示例詳解

    Redis全量復制與部分復制示例詳解

    這篇文章主要給大家介紹了關于Redis全量復制與部分復制的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Redis爬蟲具有一定的參考學習...

    豆子先生5052019-11-27
  • Redisredis中如何使用lua腳本讓你的靈活性提高5個逼格詳解

    redis中如何使用lua腳本讓你的靈活性提高5個逼格詳解

    這篇文章主要給大家介紹了關于redis中如何使用lua腳本讓你的靈活性提高5個逼格的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具...

    一線碼農5812019-11-18
  • RedisRedis的配置、啟動、操作和關閉方法

    Redis的配置、啟動、操作和關閉方法

    今天小編就為大家分享一篇Redis的配置、啟動、操作和關閉方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧 ...

    大道化簡5312019-11-14
  • Redisredis 交集、并集、差集的具體使用

    redis 交集、并集、差集的具體使用

    這篇文章主要介紹了redis 交集、并集、差集的具體使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友...

    xiaojin21cen10152021-07-27
主站蜘蛛池模板: 精品中文一区 | 日日爽 | 日韩小视频在线观看 | 精品一区二区三区视频 | 久久久精选 | 一本一道久久久a久久久精品91 | 国产高清一区二区 | 亚洲美腿 欧美 激情 另类 | 一区二区影视 | 精品国偷自产国产一区 | 成人在线观看免费爱爱 | 午夜激情影视 | 欧美另类专区 | 超碰97人人干| 一区二区三区久久 | 精品无人乱码一区二区三区 | 久久久一区二区三区 | 精品成人av一区二区在线播放 | 粉嫩欧美一区二区三区高清影视 | 不卡视频一区 | 亚洲一区二区三区免费 | 黄色国产视频 | 影音先锋在线看片资源 | a成人 | 影音先锋网址 | 91精品国产日韩91久久久久久 | 日韩中文一区二区 | 高清视频一区 | 播放欧美一级片 | 午夜视频一区 | 手机看片在线 | 久热亚洲| 91国产精品 | 成人免费在线 | 成人免费xxx在线观看 | 亚洲精品一区二区三区在线 | 在线免费日韩 | 欧美极品视频 | 成人精品一区二区三区 | www.天天操 | 国产伦精品一区二区三区四区视频 |