Jadual Kandungan
1 >Apabila kapasiti tampung tekanan projek terlalu tinggi, anda perlu menambah nod untuk meningkatkan beban Apabila tekanan projek tidak terlalu tinggi, anda juga berharap untuk mengecilkan kluster dan menggunakannya untuk projek lain. Ini memerlukan pengecutan kluster
2.1 Kira bilangan slot yang perlu diperuntukkan kepada setiap nod
Anda hanya perlu mengisi ID nod 6380 192.168.81.210 untuk Apakah ID nod penerima, yang merujuk kepada siapa slot yang diperuntukkan akan diberikan.
2.4.分配1365个槽位给192.168.81.230的6380节点
2.5.查看当前集群槽位分配
3.验证数据迁移过程是否导致数据异常
4.将下线的主节点从集群中删除
4.1.删除节点
4.2.调整主从交叉复制
4.3.当节点存在数据无法删除
5.将下线主机清空集群信息
Rumah pangkalan data Redis Contoh terperinci kluster Redis yang mengecut nod induk dan hamba

Contoh terperinci kluster Redis yang mengecut nod induk dan hamba

Apr 21, 2022 pm 06:23 PM
redis

Artikel ini membawa anda pengetahuan yang berkaitan tentang Redis, yang terutamanya memperkenalkan isu yang berkaitan dengan kelompok Redis Cluster yang mengecilkan nod induk dan hamba, termasuk konsep pengecutan gugusan Kluster, dan menukar 6390 nod induk daripada Saya harap ia akan membantu untuk mengecilkan kluster dan mengesahkan sama ada proses pemindahan data menyebabkan anomali data.

Contoh terperinci kluster Redis yang mengecut nod induk dan hamba

Pembelajaran yang disyorkan: Tutorial video Redis

1 >Apabila kapasiti tampung tekanan projek terlalu tinggi, anda perlu menambah nod untuk meningkatkan beban Apabila tekanan projek tidak terlalu tinggi, anda juga berharap untuk mengecilkan kluster dan menggunakannya untuk projek lain. Ini memerlukan pengecutan kluster

Operasi pengecutan kluster adalah sama seperti operasi pengembangan kluster, anda hanya perlu membalikkan arah.

Semasa pengembangan, anda boleh melaksanakan perintah itu sekali untuk mencapai penghijrahan slot yang berjaya Apabila mengecil, anda perlu melaksanakannya seberapa kerap kerana terdapat beberapa nod induk Sebagai contoh, tidak termasuk nod untuk berada di luar talian masih 3 nod induk Kemudian ia perlu dilaksanakan tiga kali, dan bilangan slot migrasi perlu dibahagikan dengan 3, dan setiap nod perlu diagihkan secara sama rata.

Apabila mengecut, anda mesti terlebih dahulu mengisi bilangan slot yang akan diperuntukkan, kemudian isikan kepada siapa untuk diperuntukkan, dan akhir sekali isi tempat untuk memperuntukkan slot Secara amnya, bilangan slot yang akan diperuntukkan bergantung pada hos untuk berada di luar talian, berapa banyak slot yang ada pada hos, dan kemudian bahagikannya dengan bilangan nod induk kluster, supaya slot yang ditetapkan kepada setiap hos adalah sama ID nod induk pertama untuk kali pertama Isikan ID nod induk kedua untuk kali kedua, dan akhir sekali isikan ID nod yang menyediakan slot, iaitu nombor ID nod luar talian.

Penggunaan data tidak akan terjejas apabila kluster mengecut atau mengembangkan slot.

Hujung sumber pengecutan kluster ialah nod induk yang sedang di luar talian, dan hujung sasaran ialah nod induk dalam talian (nod yang diberikan kepadanya).

Kita perlu jelas bahawa hanya nod induk mempunyai slot, jadi slot nod induk perlu diperuntukkan kepada nod induk yang lain Apabila slot dikosongkan, nod hos boleh pergi ke luar talian.


Perbandingan sebelum dan selepas mengecutkan klusterContoh terperinci kluster Redis yang mengecut nod induk dan hamba

Contoh terperinci kluster Redis yang mengecut nod induk dan hambaLangkah operasi mengecut kluster:

1. Jalankan perintah reshard untuk menyuraikan slot nod induk yang perlu di luar talian.

2. Jika anda mempunyai beberapa nod induk, anda perlu melaksanakan perintah reshard beberapa kali, mula-mula isikan bilangan slot yang akan dibahagikan, kemudian isikan dengan siapa untuk membahagikannya, dan akhirnya isikan dari mana untuk membahagikan mereka.

3 Apabila penyebaran slot selesai dan nod induk di luar talian tidak mempunyai sebarang data, padamkan nod daripada gugusan.

Maklumat kluster

Kluster semasa mempunyai empat tuan dan empat hamba, sejumlah 8 nod Kita perlu menukar kluster kepada tiga tuan dan tiga hamba, mengecut dua nod untuk kegunaan program lain.


2. Kecilkan nod induk 6390 daripada kelompok Contoh terperinci kluster Redis yang mengecut nod induk dan hamba

2.1 Kira bilangan slot yang perlu diperuntukkan kepada setiap nod

2.2. Peruntukkan 1365 slot kepada 6380 nod di 192.168.81.210
Contoh terperinci kluster Redis yang mengecut nod induk dan hamba

Kita perlu bahagikan 6390 nod kepada 46.890. Slot diberikan kepada 6380 nod di 192.168.81.210.

Anda hanya perlu mengisi ID nod 6380 192.168.81.210 untuk Apakah ID nod penerima, yang merujuk kepada siapa slot yang diperuntukkan akan diberikan.

Kemudian nod sumber mengisi ID nod 6390 192.168.81.240 Ini merujuk kepada nod mana slot 1365 diperuntukkan selepas mengisi ID, anda akan digesa dari nod mana untuk diperuntukkan selepas menekan Enter, kerana hanya 6390 slot yang perlu diperuntukkan, jadi isikan dilakukan di sini, menunjukkan bahawa hanya nod ini telah memperuntukkan 1365 slot ke nod lain.

Berikut ialah tangkapan skrin proses pengecutan nod.

Proses pemindahan data.
[root@redis-1 /data/redis_cluster/redis-3.2.9/src]# ./redis-trib.rb reshard 192.168.81.210:6380
How many slots do you want to move (from 1 to 16384)? 1365				#分配出多少个槽位

What is the receiving node ID? 80e256579658eb256c5b710a3f82c439665794ba				#将槽位分给那个节点

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:6bee155f136f40e28e1f60c8ddec3b158cd8f8e8					#从哪个节点分出槽位
Source node #2:done

Do you want to proceed with the proposed reshard plan (yes/no)? yes			#输入yes继续
Salin selepas log masuk


Penghijrahan slot telah berjaya. Contoh terperinci kluster Redis yang mengecut nod induk dan hamba

Contoh terperinci kluster Redis yang mengecut nod induk dan hamba
2.3. Peruntukkan 1365 slot kepada 6380 nod pada 192.168.81.220
Contoh terperinci kluster Redis yang mengecut nod induk dan hamba

Tangkapan skrin yang menunjukkan proses pengecutan.

Contoh terperinci kluster Redis yang mengecut nod induk dan hamba
Contoh terperinci kluster Redis yang mengecut nod induk dan hamba
Contoh terperinci kluster Redis yang mengecut nod induk dan hamba

2.4.分配1365个槽位给192.168.81.230的6380节点

[root@redis-1 /data/redis_cluster/redis-3.2.9/src]# ./redis-trib.rb reshard 192.168.81.210:6380
How many slots do you want to move (from 1 to 16384)? 1366				#分配出多少个槽位

What is the receiving node ID? a4381138fdc142f18881b7b6ca8ae5b0d02a3228				#将槽位分给那个节点

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:6bee155f136f40e28e1f60c8ddec3b158cd8f8e8					#从哪个节点分出槽位
Source node #2:done

Do you want to proceed with the proposed reshard plan (yes/no)? yes			#输入yes继续
Salin selepas log masuk

收缩过程截图展示。

Contoh terperinci kluster Redis yang mengecut nod induk dan hamba
Contoh terperinci kluster Redis yang mengecut nod induk dan hamba

当最后一个节点迁移完数据后,6390主节点槽位数变为0。

Contoh terperinci kluster Redis yang mengecut nod induk dan hamba

2.5.查看当前集群槽位分配

槽位及数据已经从6390即将下线的主机迁移完毕,可以看下当前集群三个主节点的槽位数。

可以非常清楚的看到,现在每个主节点的槽位数为5461。

Contoh terperinci kluster Redis yang mengecut nod induk dan hamba

如果觉得槽位重新分配后顺序不太满意,那么在执行一下reshard,把其它节点的槽位都分给192.168.81.210的6380上,这样一来,210的6380拥有的槽位就是0-16383,然后在将210的槽位一个节点分给5461个,分完之后,各节点的顺序就一致了。
Contoh terperinci kluster Redis yang mengecut nod induk dan hamba

3.验证数据迁移过程是否导致数据异常

多开几个窗口,一个执行数据槽位迁移,一个不断创建key,一个查看key的创建进度,一个查看key的数据。
持续测试,发现没有任何数据异常,全部显示ok。
Contoh terperinci kluster Redis yang mengecut nod induk dan hamba

4.将下线的主节点从集群中删除

4.1.删除节点

使用redis-trib删除一个节点,如果这个节点存在复制关系,有节点在复制当前节点或者当前节点复制别的节点的数据,redis-trib会自动处理复制关系,然后将节点删除,节点删除后会把对应的进程也停止运行。

删除节点之前必须确保该节点没有任何槽位和数据,否则会删除失败。

命令:./redis-trib.rb del-node 节点IP:端口 ID

[root@redis-1 /data/redis_cluster/redis-3.2.9/src]# ./redis-trib.rb del-node 192.168.81.240:6390 6bee155f136f40e28e1f60c8ddec3b158cd8f8e8
>>> Removing node 6bee155f136f40e28e1f60c8ddec3b158cd8f8e8 from cluster 192.168.81.240:6390
>>> Sending CLUSTER FORGET messages to the cluster...
>>> SHUTDOWN the node.

[root@redis-1 /data/redis_cluster/redis-3.2.9/src]# ./redis-trib.rb del-node 192.168.81.240:6391 f6b9320dfbc929ad5a31cdb149360b0fd8de2e60
>>> Removing node f6b9320dfbc929ad5a31cdb149360b0fd8de2e60 from cluster 192.168.81.240:6391
>>> Sending CLUSTER FORGET messages to the cluster...
>>> SHUTDOWN the node.
Salin selepas log masuk

Contoh terperinci kluster Redis yang mengecut nod induk dan hamba

4.2.调整主从交叉复制

删掉192.168.81.240服务器上的两个redis节点后,192.168.81.210服务器上的6380就没有了复制关系,我们需要把192.168.81.230的6381节点复制192.168.81.210的6380节点。

[root@redis-1 ~]# redis-cli -h 192.168.81.230 -p 6381
192.168.81.230:6381> CLUSTER REPLICATE 80e256579658eb256c5b710a3f82c439665794ba
OK
Salin selepas log masuk

Contoh terperinci kluster Redis yang mengecut nod induk dan hamba

4.3.当节点存在数据无法删除

[root@redis-1 /data/redis_cluster/redis-3.2.9/src]# ./redis-trib.rb del-node 192.168.81.220:6380 10dc7f3f9a753140a8494adbbe5a13d0026451a1
>>> Removing node 10dc7f3f9a753140a8494adbbe5a13d0026451a1 from cluster 192.168.81.220:6380
[ERR] Node 192.168.81.220:6380 is not empty! Reshard data away and try again.
Salin selepas log masuk

Contoh terperinci kluster Redis yang mengecut nod induk dan hamba

5.将下线主机清空集群信息

redis-trib虽然能够将节点在集群中删除,但是无法将其的集群信息清空,如果集群信息还有保留,那么该接地那就无法加入其它集群。

Contoh terperinci kluster Redis yang mengecut nod induk dan hamba

在下线的redis节点上使用cluster reset删除集群信息即可。

192.168.81.240:6390> CLUSTER reset
OK
Salin selepas log masuk

Contoh terperinci kluster Redis yang mengecut nod induk dan hamba

推荐学习:Redis视频教程

Atas ialah kandungan terperinci Contoh terperinci kluster Redis yang mengecut nod induk dan hamba. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Tutorial Java
1662
14
Tutorial PHP
1261
29
Tutorial C#
1234
24
Cara Membina Mod Kluster Redis Cara Membina Mod Kluster Redis Apr 10, 2025 pm 10:15 PM

Mod Redis cluster menyebarkan contoh Redis ke pelbagai pelayan melalui sharding, meningkatkan skalabilitas dan ketersediaan. Langkah -langkah pembinaan adalah seperti berikut: Buat contoh Redis ganjil dengan pelabuhan yang berbeza; Buat 3 contoh sentinel, memantau contoh redis dan failover; Konfigurasi fail konfigurasi sentinel, tambahkan pemantauan maklumat contoh dan tetapan failover; Konfigurasi fail konfigurasi contoh Redis, aktifkan mod kluster dan tentukan laluan fail maklumat kluster; Buat fail nodes.conf, yang mengandungi maklumat setiap contoh Redis; Mulakan kluster, laksanakan perintah Buat untuk membuat kluster dan tentukan bilangan replika; Log masuk ke kluster untuk melaksanakan perintah maklumat kluster untuk mengesahkan status kluster; buat

Cara membersihkan data redis Cara membersihkan data redis Apr 10, 2025 pm 10:06 PM

Cara Mengosongkan Data Redis: Gunakan perintah Flushall untuk membersihkan semua nilai utama. Gunakan perintah flushdb untuk membersihkan nilai utama pangkalan data yang dipilih sekarang. Gunakan Pilih untuk menukar pangkalan data, dan kemudian gunakan FlushDB untuk membersihkan pelbagai pangkalan data. Gunakan perintah DEL untuk memadam kunci tertentu. Gunakan alat REDIS-CLI untuk membersihkan data.

Cara Membaca Gilir Redis Cara Membaca Gilir Redis Apr 10, 2025 pm 10:12 PM

Untuk membaca giliran dari Redis, anda perlu mendapatkan nama giliran, membaca unsur -unsur menggunakan arahan LPOP, dan memproses barisan kosong. Langkah-langkah khusus adalah seperti berikut: Dapatkan nama giliran: Namakannya dengan awalan "giliran:" seperti "giliran: my-queue". Gunakan arahan LPOP: Keluarkan elemen dari kepala barisan dan kembalikan nilainya, seperti LPOP Queue: My-Queue. Memproses Baris kosong: Jika barisan kosong, LPOP mengembalikan nihil, dan anda boleh menyemak sama ada barisan wujud sebelum membaca elemen.

Cara Mengkonfigurasi Masa Pelaksanaan Skrip Lua di Centos Redis Cara Mengkonfigurasi Masa Pelaksanaan Skrip Lua di Centos Redis Apr 14, 2025 pm 02:12 PM

Pada sistem CentOS, anda boleh mengehadkan masa pelaksanaan skrip LUA dengan mengubah fail konfigurasi REDIS atau menggunakan arahan REDIS untuk mengelakkan skrip jahat daripada memakan terlalu banyak sumber. Kaedah 1: Ubah suai fail konfigurasi Redis dan cari fail konfigurasi Redis: Fail konfigurasi Redis biasanya terletak di /etc/redis/redis.conf. Edit Fail Konfigurasi: Buka fail konfigurasi menggunakan editor teks (seperti Vi atau nano): sudovi/etc/redis/redis.conf Tetapkan had masa pelaksanaan skrip lua: Tambah atau ubah suai baris berikut dalam fail konfigurasi untuk menetapkan masa pelaksanaan maksimum skrip lua (unit: milidor)

Cara menggunakan baris arahan redis Cara menggunakan baris arahan redis Apr 10, 2025 pm 10:18 PM

Gunakan alat baris perintah redis (redis-cli) untuk mengurus dan mengendalikan redis melalui langkah-langkah berikut: Sambungkan ke pelayan, tentukan alamat dan port. Hantar arahan ke pelayan menggunakan nama arahan dan parameter. Gunakan arahan bantuan untuk melihat maklumat bantuan untuk arahan tertentu. Gunakan perintah berhenti untuk keluar dari alat baris arahan.

Cara Melaksanakan Kaunter Redis Cara Melaksanakan Kaunter Redis Apr 10, 2025 pm 10:21 PM

Kaunter Redis adalah satu mekanisme yang menggunakan penyimpanan pasangan nilai utama REDIS untuk melaksanakan operasi pengiraan, termasuk langkah-langkah berikut: mewujudkan kekunci kaunter, meningkatkan tuduhan, mengurangkan tuduhan, menetapkan semula, dan mendapatkan tuduhan. Kelebihan kaunter Redis termasuk kelajuan cepat, konkurensi tinggi, ketahanan dan kesederhanaan dan kemudahan penggunaan. Ia boleh digunakan dalam senario seperti pengiraan akses pengguna, penjejakan metrik masa nyata, skor permainan dan kedudukan, dan pengiraan pemprosesan pesanan.

Cara Mengoptimumkan Prestasi Debian Readdir Cara Mengoptimumkan Prestasi Debian Readdir Apr 13, 2025 am 08:48 AM

Dalam sistem Debian, panggilan sistem Readdir digunakan untuk membaca kandungan direktori. Jika prestasinya tidak baik, cuba strategi pengoptimuman berikut: Memudahkan bilangan fail direktori: Split direktori besar ke dalam pelbagai direktori kecil sebanyak mungkin, mengurangkan bilangan item yang diproses setiap panggilan readdir. Dayakan Caching Kandungan Direktori: Bina mekanisme cache, kemas kini cache secara teratur atau apabila kandungan direktori berubah, dan mengurangkan panggilan kerap ke Readdir. Cafh memori (seperti memcached atau redis) atau cache tempatan (seperti fail atau pangkalan data) boleh dipertimbangkan. Mengamalkan struktur data yang cekap: Sekiranya anda melaksanakan traversal direktori sendiri, pilih struktur data yang lebih cekap (seperti jadual hash dan bukannya carian linear) untuk menyimpan dan mengakses maklumat direktori

Cara Menetapkan Dasar Tamat Redis Cara Menetapkan Dasar Tamat Redis Apr 10, 2025 pm 10:03 PM

Terdapat dua jenis strategi tamat tempoh data REDIS: Penghapusan berkala: Imbasan berkala untuk memadamkan kunci yang telah tamat tempoh, yang boleh ditetapkan melalui parameter-cap-cap-rempah yang telah tamat tempoh dan parameter kelewatan-cap-remove-time-time. Penghapusan Lazy: Periksa kekunci yang telah tamat tempoh hanya apabila kunci dibaca atau ditulis. Mereka boleh ditetapkan melalui parameter lazon-lazy-expire-expire-expire, lazy-lazy-user-del parameter.

See all articles