Bagaimana untuk mengkonfigurasi mod tuan-hamba kelompok Redis
1. Mengapakah kluster diperlukan?
Dalam pembangunan sebenar kami, tidak mungkin untuk menggunakan hanya satu Redis dalam projek kejuruteraan atas sebab-sebab berikut:
( 1) Dari segi struktur, pelayan Redis tunggal mempunyai risiko satu titik kegagalan, dan satu pelayan perlu menanggung beban semua permintaan, yang agak menekan
( 2) Dari segi kapasiti, kapasiti memori pelayan Redis tunggal adalah terhad Walaupun kapasiti memori pelayan Redis adalah 256G, semua memori tidak boleh digunakan sebagai memori simpanan Redis Secara umumnya, memori maksimum yang digunakan oleh satu pelayan Redis tidak boleh melebihi 20G.
(3) Prestasi membaca dan menulis pelayan Redis tunggal adalah terhad, dan keupayaan membaca dan menulis boleh dipertingkatkan dengan menggunakan kluster.
2. Mod Master-slave
Pengenalan
Pada masa ini, Redis mempunyai tiga mod cluster, iaitu: master-slave mod , Mod Sentinel, Mod kluster-hamba adalah yang paling mudah daripada tiga mod Dalam replikasi induk-hamba, ia merujuk kepada menyalin data satu pelayan Redis ke pelayan Redis yang lain. Yang pertama dipanggil nod induk (tuan/pemimpin), manakala yang kedua dipanggil nod hamba (hamba/pengikut).
Nota:
(1) Replikasi data adalah sehala, hanya dari nod induk kepada hamba nod nod. Guru terutamanya untuk menulis, dan Hamba terutamanya untuk membaca.
(2) Secara lalai, setiap pelayan Redis ialah nod induk;
(3) Nod induk boleh mempunyai berbilang nod hamba (atau tiada nod hamba), tetapi nod hamba hanya boleh mempunyai satu nod induk .
Fungsi
1 Lewahan data: Replikasi master-hamba merealisasikan lebihan data Hot. sandaran ialah kaedah redundansi data selain daripada kegigihan.
2. Pemulihan kegagalan: Apabila masalah berlaku pada nod induk, nod hamba boleh menyediakan perkhidmatan untuk mencapai pemulihan kegagalan yang cepat, ia sebenarnya sejenis redundansi perkhidmatan.
3. Batu asas ketersediaan tinggi (kluster) : Replikasi tuan-hamba juga merupakan asas untuk pelaksanaan sentinel dan kelompok Oleh itu, replikasi tuan-hamba adalah asas ketersediaan tinggi Redis.
4. Pengimbangan beban: Berdasarkan replikasi tuan-hamba, digabungkan dengan pemisahan baca-tulis, nod induk boleh menyediakan perkhidmatan tulis dan nod hamba boleh menyediakan perkhidmatan baca (iaitu, semasa menulis Redis data, aplikasi bersambung ke Nod induk, apabila membaca data Redis, gunakan nod hamba sambungan) untuk berkongsi beban pelayan terutamanya dalam senario di mana terdapat kurang penulisan dan lebih banyak bacaan, berkongsi beban baca melalui berbilang nod hamba boleh meningkat dengan ketara; keselarasan pelayan Redis.
Sebagai contoh, anda boleh temui di laman web e-dagang kami bahawa produk hanya perlu dimuat naik sekali, tetapi ia boleh dilihat beberapa kali oleh pengguna , iaitu, " menulis Baca kurang dan baca lagi " Dalam kes ini, kita boleh menggunakan replikasi tuan-hamba untuk memisahkan bacaan dan tulisan , untuk mengurangkan tekanan pada pelayan :
3.1 >
1. Salin Tiga fail konfigurasi (nama asal: redis.conf) telah dinamakan semula kepada: redis79.conf, redis80.conf, redis81.conf.
2 Ubah suai fail konfigurasi
(1) Ubah suai redis79.conf >
Ubah suai nombor port
port 6379
Tetapkan untuk dijalankan di latar belakang
daemonize:yes
Tetapkan nama fail log
logfile “6379.log"
Tetapkan nama fail db
dbfilename dump6379.rdb
(2) Ubah suai redis80.conf
Ubah suai nombor port
port 6380
Tetapkan untuk dijalankan di latar belakang
daemonize:yes
Tetapkan nama fail Id proses rakaman
pidfile /var/run/redis_6380.pid
Tetapkan nama fail log
logfile “6380.log"
Tetapkan nama fail db
dbfilename dump6380.rdb
(3) Ubah suai redis81.conf
Ubah suai nombor port
port 6381
Tetapkan untuk dijalankan di latar belakang
daemonize:yes
Tetapkan rakaman nama fail Id proses
pidfile /var/run/redis_6381.pid
Tetapkan nama fail log
logfile “6381.log"
Tetapkan nama fail db
dbfilename dump6381.rdb
Fungsi atribut ini adalah seperti berikut:
pid (port ID): ID proses direkodkan dan fail mempunyai kunci. Menghalang program daripada dimulakan beberapa kali. fail log: kosongkan lokasi fail log
dbfilename: dumpxxx.file #persistent file locationport: nombor port yang diduduki oleh proses
3.2、搭建一主二从
启动Redis服务器
注意:默认情况下,每台Reids服务器都是主节点,而我们要搭建主从只需要在从机那本搭建即可。
现在分别启动redis79,redis80,redis81服务器。
redis-server redis79.conf redis-server redis80.conf redis-server redis81.conf
使用以下命令,查看是否启动成功:
ps -ef|grep redis
打开三个客户端窗口,分别对应操作三个Redis服务器。
输入命令:
注意要指定端口,才知道我们要打开哪一个Redis。
窗口一:
redis-cli -p 6379
窗口二:
redis-cli -p 6380
窗口三:
redis-cli -p 6381
设置主从关系
我们将redis79设置为主节点,而将redis80和redis81设置为从结点。
配置主机的IP地址和端口号,相当于想认其为自己的老大。
redis80:
#SLAVEOF IP地址 端口 127.0.0.1:6380> slaveof 127.0.0.1 6379 OK
redis81:
#SLAVEOF IP地址 端口 127.0.0.1:6381> slaveof 127.0.0.1 6379 OK
这个时候,我们在从机使用INFO命令就可以查看主从关系了:
info replication
而此时我们去主机redis79中使用同样的命令进行查看:
现在我们的一主二从的关系就成功搭建好了!
提示:如果要将从机变成主机,我们只需要在从机执行以下命令,即可让自己变为主机。
SLAVEOF no one
四、知识讲解
知识一
主机可以进行读写操作,而从机只能读操作。
注意:主机中的所有信息和数据,都会自动被从机保存。
主机:
127.0.0.1:6379> set key1 v1 OK 127.0.0.1:6379> get key1 "v1"
从机:
127.0.0.1:6380> get key1 "v1" 127.0.0.1:6380> set key2 v2 #进行写操作就会报错,提示从机只能进行读操作 (error) READONLY You can't write against a read only replica.
知识二
主机如果宕机了,从机依旧可以读取到主机宕机前的数据,但仍然没有写操作,如果主机恢复过来了,从机依旧可以获取到主机写的数据。
(1)停止主机进程(演示主机宕机了)
停止进程的命令:
kill -9 pid #pid为redis进程号
(2)从机获取宕机前主机写入的数据
可以发现,能够顺利拿到,但仍然是无法进行写操作的。
(3)恢复主机
redis-server redis79.conf
(4)主机重新写入数据,从机获取最新数据。
主机写入数据:
127.0.0.1:6379> set k2 yixin OK
从机读取最新数据:
127.0.0.1:6380> get k2 "yixin"
知识三
两种配置方式下的从机断开情况
a、命令行设置主从关系
从机断开了,其重新连接后变为主机,能拿到断开之前的数据,但拿不到主机新写入的值,如果重新设置主从关系,就可以拿到主机全部的数据了。
(1)停止从机进程。
(2)主机写入新数据。
127.0.0.1:6379> set k3 new OK
(3)重新启动从机服务器。
redis-server redis80.conf
(4)尝试获取从机宕机前主机写入的数据,发现可以拿到。
127.0.0.1:6380> get k1 "v1"
(5)尝试获取从机宕机期间主机写入的数据,发现无法拿到了。
127.0.0.1:6380> get k3 (nil)
此次我们可以进行查看主从关系,由于是命令行配置的,所以重启之后又变回主机了。
127.0.0.1:6380> info replication # Replication role:master connected_slaves:0
(6)如果要拿到主机的所有数据,只要执行以下命令重新配置主从关系就可以了。
slaveof 127.0.0.1 6379
b、配置文件设置的主从关系
从机断开后,重新连接,也是可以拿到主机的全部数据的。
(1)修改配置文件redis80.conf,添加主从关系。
#指定主机的ip与port slaveof 127.0.0.1 6379
(2)主机添加新数据
127.0.0.1:6379> set k5 hello OK
(3)重新启动redis80服务器。
redis-server redis80.conf
(4)获取从机宕机期间主机新写入的数据,发现现在可以顺利拿到了。
127.0.0.1:6380> get k5 "hello"
我们来查看6380的主从关系,可以发现在重启的时候就已经设置好主从关系了。
五、复制原理
(1)Slave 启动成功连接到 Master 后会发送一个sync同步命令
(2)Master 接到命令,启动后台的存盘进程,同时收集所有接收到的用于修改数据集命令,在后台进程执行完毕之后,master将传送整个数据文件到slave,并完成一次完全同步。
(3)全量复制:而slave服务在接收到数据库文件数据后,将其存盘并加载到内存中。
(4)增量复制:Master 继续将新的所有收集到的修改命令依次传给slave,完成同步。
注意:只要是重新连接master,一次完全同步(全量复制)将被自动执行! 我们的数据一定可以在从机中看到。
六、主从模式的优缺点
优点
(1)同一个Master可以同步多个Slaves。
(2)Slave同样可以接受其它Slaves的连接和同步请求,这样可以有效的分载Master的同步压力。因此我们可以将Redis的Replication架构视为图结构。
(3)Master Server是以非阻塞的方式为Slaves提供服务。所以在Master-Slave同步期间,客户端仍然可以提交查询或修改请求。
(4)Slave Server同样是以非阻塞的方式完成数据同步。在同步期间,如果有客户端提交查询请求,Redis则返回同步之前的数据。
(5)为了分载Master的读操作压力,Slave服务器可以为客户端提供只读操作的服务,写服务仍然必须由Master来完成。即便如此,系统的伸缩性还是得到了很大的提高。
(6)Master可以将数据保存操作交给Slaves完成,从而避免了在Master中要有独立的进程来完成此操作。
(7)支持主从复制,主机会自动将数据同步到从机,可以进行读写分离。
缺点
(1) Redis 主从模式不具备自动容错和恢复功能,如果主节点宕机,Redis 集群将无法工作,此时需要人为干预,将从节点提升为主节点。
(2) 如果主机宕机前有一部分数据未能及时同步到从机,即使切换主机后也会造成数据不一致的问题,从而降低了系统的可用性。
(3) 因为只有一个主节点,所以其写入能力和存储能力都受到一定程度地限制。
(4) 在进行数据全量同步时,若同步的数据量较大可能会造卡顿的现象。
Atas ialah kandungan terperinci Bagaimana untuk mengkonfigurasi mod tuan-hamba kelompok Redis. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

1. Mulakan menu [Start], masukkan [cmd], klik kanan [Command Prompt], dan pilih Run as [Administrator]. 2. Masukkan arahan berikut mengikut turutan (salin dan tampal dengan teliti): SCconfigwuauservstart=auto, tekan Enter SCconfigbitsstart=auto, tekan Enter SCconfigcryptsvcstart=auto, tekan Enter SCconfigtrustedinstallerstart=auto, tekan Enter SCconfigwuauservtype=share, tekan Enter netstopwuauserv , tekan enter netstopcryptS

Kesesakan fungsi PHP membawa kepada prestasi rendah, yang boleh diselesaikan melalui langkah berikut: cari fungsi kesesakan dan gunakan alat analisis prestasi. Keputusan cache untuk mengurangkan pengiraan semula. Memproses tugas secara selari untuk meningkatkan kecekapan pelaksanaan. Optimumkan penggabungan rentetan, sebaliknya gunakan fungsi terbina dalam. Gunakan fungsi terbina dalam dan bukannya fungsi tersuai.

Strategi caching dalam GolangAPI boleh meningkatkan prestasi dan mengurangkan beban pelayan Strategi yang biasa digunakan ialah: LRU, LFU, FIFO dan TTL. Teknik pengoptimuman termasuk memilih storan cache yang sesuai, caching hierarki, pengurusan ketidaksahihan dan pemantauan dan penalaan. Dalam kes praktikal, cache LRU digunakan untuk mengoptimumkan API untuk mendapatkan maklumat pengguna daripada pangkalan data Data boleh diambil dengan cepat daripada cache Jika tidak, cache boleh dikemas kini selepas mendapatkannya daripada pangkalan data.

Terdapat perbezaan prestasi antara Erlang dan Go. Erlang cemerlang dalam concurrency, manakala Go mempunyai daya pemprosesan yang lebih tinggi dan prestasi rangkaian yang lebih pantas. Erlang sesuai untuk sistem yang memerlukan konkurensi tinggi, manakala Go sesuai untuk sistem yang memerlukan daya pemprosesan tinggi dan kependaman rendah.

Dalam pembangunan PHP, mekanisme caching meningkatkan prestasi dengan menyimpan sementara data yang kerap diakses dalam memori atau cakera, dengan itu mengurangkan bilangan akses pangkalan data. Jenis cache terutamanya termasuk memori, fail dan cache pangkalan data. Caching boleh dilaksanakan dalam PHP menggunakan fungsi terbina dalam atau perpustakaan pihak ketiga, seperti cache_get() dan Memcache. Aplikasi praktikal biasa termasuk caching hasil pertanyaan pangkalan data untuk mengoptimumkan prestasi pertanyaan dan caching halaman output untuk mempercepatkan pemaparan. Mekanisme caching berkesan meningkatkan kelajuan tindak balas laman web, meningkatkan pengalaman pengguna dan mengurangkan beban pelayan.

Menggunakan cache Redis boleh mengoptimumkan prestasi halaman tatasusunan PHP. Ini boleh dicapai melalui langkah berikut: Pasang klien Redis. Sambung ke pelayan Redis. Cipta data cache dan simpan setiap halaman data ke dalam cincangan Redis dengan kunci "halaman:{page_number}". Dapatkan data daripada cache dan elakkan operasi mahal pada tatasusunan besar.

Mula-mula anda perlu menetapkan bahasa sistem kepada paparan Bahasa Cina Mudah dan mulakan semula. Sudah tentu, jika anda telah menukar bahasa paparan kepada Bahasa Cina Ringkas sebelum ini, anda boleh melangkau langkah ini sahaja. Seterusnya, mula mengendalikan pendaftaran, regedit.exe, navigasi terus ke HKEY_LOCAL_MACHINESYSTEMCurrentControlSetControlNlsLanguage dalam bar navigasi kiri atau bar alamat atas, dan kemudian ubah suai nilai kunci InstallLanguage dan nilai kunci Lalai kepada 0804 (jika anda ingin menukarnya ke Bahasa Inggeris en- kami, anda perlu Mula-mula tetapkan bahasa paparan sistem kepada en-us, mulakan semula sistem dan kemudian tukar semuanya kepada 0409) Anda mesti memulakan semula sistem pada ketika ini.

Ya, Navicat boleh menyambung ke Redis, yang membolehkan pengguna mengurus kunci, melihat nilai, melaksanakan arahan, memantau aktiviti dan mendiagnosis masalah. Untuk menyambung ke Redis, pilih jenis sambungan "Redis" dalam Navicat dan masukkan butiran pelayan.
