欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Redis集群水平擴展、集群中添加以及刪除節(jié)點的操作

 更新時間:2021年03月25日 15:20:56   作者:只管努力,剩下的交給時間  
這篇文章主要介紹了Redis集群水平擴展、集群中添加以及刪除節(jié)點的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

Redis集群搭建中,我們搭建了下圖所示的Redis集群,接下來我們就來看看如何為我們的Redis集群進行水平擴容。

[root@localhost redis-5.0.3]# src/redis-server redis-cluster/8001/redis.conf 
[root@localhost redis-5.0.3]# src/redis-server redis-cluster/8004/redis.conf
[root@localhost redis-5.0.3]# src/redis-server redis-cluster/8002/redis.conf 
[root@localhost redis-5.0.3]# src/redis-server redis-cluster/8005/redis.conf 
[root@localhost redis-5.0.3]# src/redis-server redis-cluster/8003/redis.conf 
[root@localhost redis-5.0.3]# src/redis-server redis-cluster/8006/redis.conf 

首先,先啟動我們的集群(在上一篇博客中,我們已經將集群環(huán)境搭好了,只需要重啟啟動redis服務即可)

查看集群中的信息:

為集群水平擴容

接下來,我們將在集群得基礎上再添加一主一從,增加后集群如下圖所示:

1. 增加8007和8008倆個redis實例

在/usr/local/software/redis-5.0.3/redis-cluster下創(chuàng)建8007和8008文件夾,并拷貝8001文件夾下的redis.conf文件到8007和8008這兩個文件夾下,進行修改

mkdir 8007 8008
cd 8001
cp redis.conf /usr/local/software/redis-5.0.3/redis-cluster/8007/
cp redis.conf /usr/local/software/redis-5.0.3/redis-cluster/8008/

# 修改8007文件夾下的redis.conf配置文件
vim /usr/local/software/redis-5.0.3/redis-cluster/8007/redis.conf
# 修改如下內容:
port 8007
dir /usr/local/software/redis-5.0.3/redis-cluster/8007
cluster-config-file nodes-8007.conf

# 修改8008文件夾下的redis.conf配置文件
vim /usr/local/software/redis-5.0.3/redis-cluster/8008/redis.conf
修改內容如下:
port 8008
dir /usr/local/software/redis-5.0.3/redis-cluster/8008
cluster-config-file nodes-8008.conf

# 啟動8007和8008倆個服務并查看服務狀態(tài)
src/redis-server /usr/local/software/redis-5.0.3/redis-cluster/8007/redis.conf
src/redis-server /usr/local/software/redis-5.0.3/redis-cluster/8008/redis.conf
ps -el | grep redis

2. 將8007和8008加入集群中

查看redis集群得幫助命令:

1.create:創(chuàng)建一個集群環(huán)境host1:port1 … hostN:portN

2.call:可以執(zhí)行redis命令

3.add-node:將一個節(jié)點添加到集群里,第一個參數為新節(jié)點的ip:port,第二個參數為集群中任意一個已經存在的節(jié)點的ip:port

4.del-node:移除一個節(jié)點

5.reshard:重新分片

6.check:檢查集群狀態(tài)

添加8007和8008節(jié)點到集群中

[root@localhost redis-5.0.3]# src/redis-cli --cluster add-node 192.168.243.133:8007 192.168.243.133:8001
[root@localhost redis-5.0.3]# src/redis-cli --cluster add-node 192.168.243.133:8008 192.168.243.133:8001

3. 查看集群狀態(tài)

我們發(fā)現(xiàn)對于新加入的節(jié)點默認都是master節(jié)點,最重要的是,他們都沒有分配slots槽位,所以根據Redis集群分片的原理,這些剛加入集群的節(jié)點實際上是不能讀寫數據的。

4. 為新加入的節(jié)點分配槽位

使用集群中的任意一個主節(jié)點,對其進行重新分片工作

[root@localhost redis-5.0.3]# src/redis-cli --cluster reshard 192.168.243.133:8001

輸入命令后,會進入一個交互式的操作:

1. How many slots do you want to move (from 1 to 16384)? 600

你想移動多少個槽位? 這里移動600個

2. What is the receiving node ID? 7cbcddaea49560b2847327b1465e8db7082655d2

要將槽位分配給拿給節(jié)點? 指定節(jié)點的ID

3. 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

要從哪幾個節(jié)點抽取槽位,all:從所有的節(jié)點中,各自抽取一部分槽位給8007。輸入all后會有一個抽取槽位的計劃

4.Do you want to proceed with the proposed reshard plan (yes/no)? yes開始執(zhí)行

是否執(zhí)行該reshard計劃。

查看集群的最新狀態(tài):

我們可以看到8007已經有hash槽位了,此時我們就能往8007進行讀寫操作了

5. 將8008配置為8007的從節(jié)點

我們可以通過replicate命令指定當前節(jié)點成為哪一個節(jié)點的從節(jié)點。

192.168.243.133:8008> cluster replicate 7cbcddaea49560b2847327b1465e8db7082655d2
OK

查看集群的狀態(tài):

發(fā)現(xiàn)8008已經成為8007的從節(jié)點了,至此,Redis水平擴容成功。

刪除集群中的節(jié)點

刪除8008從節(jié)點

用del-node刪除從節(jié)點8008,指定刪除節(jié)點ip和端口,以及節(jié)點id

[root@localhost redis-5.0.3]# src/redis-cli --cluster del-node 192.168.243.133:8008 840340ce7a2dabdfc6ad40fde17e9e0c803b386c

發(fā)現(xiàn)8008已經被移除了。

刪除8007主節(jié)點

刪除8007節(jié)點比刪除8008節(jié)點麻煩一點,因為8007節(jié)點管理一部分slots,在刪除它之前,需要將slots分配給其他可用的master節(jié)點上,否則就會出現(xiàn)數據丟失問題。

1、重新分配8007上的slots

[root@localhost redis-5.0.3]# src/redis-cli --cluster reshard 192.168.243.133:8007

交互流程:

1. How many slots do you want to move (from 1 to 16384)? 600

2. What is the receiving node ID? ec0001bd4282f790017d1e68259c67f2d7037a3c

接收slots的節(jié)點ID(這里是8001的主節(jié)點ID)

3. 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: 7cbcddaea49560b2847327b1465e8db7082655d2
Source node #2: done

數據源ID,這里輸入8007節(jié)點的ID,表示600個slots都由8007提供(8007總共就600個slots)

4. Do you want to proceed with the proposed reshard plan (yes/no)? yes

查看集群節(jié)點狀態(tài):

2、使用del-node命令刪除8007節(jié)點

[root@localhost redis-5.0.3]# src/redis-cli --cluster del-node 192.168.243.133:8007 7cbcddaea49560b2847327b1465e8db7082655d2

再次查看集群狀態(tài):

8007已經被移除

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

相關文章

  • 用Redis實現(xiàn)微博關注關系

    用Redis實現(xiàn)微博關注關系

    在微博中,每一個用戶都會有一個關注列表,一個粉絲列表。用戶可以查看自己的關注,粉絲列表,也可以查看別人的關注,粉絲列表。并且,要展示列表里每個人與當前查看者的關注狀態(tài)。
    2015-09-09
  • Redis緩存過期的實現(xiàn)示例

    Redis緩存過期的實現(xiàn)示例

    Redis緩存的過期策略是保證緩存可靠性和性能的關鍵之一,本文主要介紹了Redis緩存過期的實現(xiàn)示例,具有一定的參考價值,感興趣的可以了解一下
    2023-12-12
  • redis如何后臺啟動的方法

    redis如何后臺啟動的方法

    這篇文章主要介紹了redis如何后臺啟動的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-03-03
  • Redis實現(xiàn)分布式鎖的幾種方法總結

    Redis實現(xiàn)分布式鎖的幾種方法總結

    這篇文章主要介紹了Redis實現(xiàn)分布式鎖的幾種方法總結的相關資料, Redis實現(xiàn)與Zookeeper實現(xiàn)和數據庫實現(xiàn),需要的朋友可以參考下
    2017-07-07
  • Redis分布式鎖與Redlock算法實現(xiàn)

    Redis分布式鎖與Redlock算法實現(xiàn)

    在Redis中,可以使用多種方式實現(xiàn)分布式鎖,如使用SETNX命令或RedLock算法,本文就來介紹一下Redis分布式鎖與Redlock算法實現(xiàn),感興趣的可以了解一下
    2023-12-12
  • Redis數據庫的應用場景介紹

    Redis數據庫的應用場景介紹

    這篇文章主要介紹了Redis數據庫的應用場景介紹,本文講解了MySql+Memcached架構的問題、Redis常用數據類型、Redis數據類型應用和實現(xiàn)方式、Redis實際應用場景等內容,需要的朋友可以參考下
    2015-06-06
  • Redis數據結構之intset整數集合使用學習

    Redis數據結構之intset整數集合使用學習

    這篇文章主要為大家介紹了Redis數據結構之整數集合使用學習,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-07-07
  • 提高redis緩存命中率的方法

    提高redis緩存命中率的方法

    在本篇文章里小編給大家整理了關于怎么提高redis緩存命中率的相關知識點內容,有興趣的朋友們跟著學習下。
    2019-06-06
  • Quarkus集成redis操作Redisson實現(xiàn)數據互通

    Quarkus集成redis操作Redisson實現(xiàn)數據互通

    這篇文章主要為大家介紹了Quarkus集成redis操作Redisson實現(xiàn)數據互通的示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步
    2022-02-02
  • Redis做預定庫存緩存功能設計使用

    Redis做預定庫存緩存功能設計使用

    這篇文章主要為大家介紹了Redis做預定庫存緩存功能設計使用,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步早日升職加薪
    2022-04-04

最新評論