docker 搭建簡(jiǎn)單的Redis 主從復(fù)制(slaveof)并且連接Laravel

拉取redis基礎(chǔ)鏡像

docker search redis --搜索鏡像
docker pull redis -- 拉取鏡像

運(yùn)行三個(gè)容器(在此之前可以自定義個(gè)網(wǎng)絡(luò)咐汞,防止docker容器重啟后集群失效)

生產(chǎn)環(huán)境搭建,建議掛載redis目錄(配置文件、數(shù)據(jù))春塌,權(quán)限驗(yàn)證等,保證集群安全簇捍,以下為了方便測(cè)試只壳,直接裸奔了。
一主二從

docker -d --name m1 -p 6379:6379 redis
docker -d --name s1 -p 6380:6379 redis
docker -d --name s2 -p 6381:6379 redis

獲取指定主機(jī)m1容器內(nèi)地址

docker inspect m1 --我的地址 172.17.0.3

image.png

開始搭建

分別進(jìn)入s1垦写、s2容器內(nèi)

docker exec -it s1 bash
docker exec -it s2 bash

進(jìn)入redis

redis-cli

綁定主機(jī)ip吕世、端口

slaveof 172.17.0.3 6379

image.png

進(jìn)入主機(jī)m1中

docker exec -it m1 bash

查看集群狀態(tài)

info replication

image.png

從主機(jī)寫入數(shù)據(jù)彰触,從機(jī)也會(huì)有相應(yīng)的數(shù)據(jù)

set name zhangsan

image.png

連接Laravel梯投,版本 8.2

這里我選擇的 predis 這個(gè)組件包,版本 ^2.0,根據(jù)自己需求拉取
 "require": {
        "predis/predis": "^2.0"
    },
安裝

composer require predis/predis

書寫配置文件database.php,主要關(guān)注 redis 這個(gè)數(shù)組
'redis' => [
        'client' => env('REDIS_CLIENT', 'phpredis'),
        'cluster' => false,
        // 集群配置
        'clusters' => [
        // 連接的集群名稱
            'cluster1' => [
                // 配置寫入節(jié)點(diǎn)
                'write' => [
                    [
                        'host' => '127.0.0.1',
                        'password' => '',
                        'port' => 6379,
                        'database' => 0,
                    ]
                // 更多的主節(jié)點(diǎn)
                ],
                //  配置讀取節(jié)點(diǎn)
                'read' => [
                    [
                        'host' => '127.0.0.1',
                        'port' => 6380,
                        'database' => 0,
                    ],
                    [
                        'host' => '127.0.0.1',
                        'port' => 6381,
                        'database' => 0,
                    ]
              // .... 更多的子節(jié)點(diǎn)
                ],
            ],
        ],

        'options' => [
            'cluster' => env('REDIS_CLUSTER', 'predis'),
            'prefix' => env('REDIS_PREFIX', ''),
        ]
    ]

寫入測(cè)試方法

<?php
namespace App\Http\Controllers;

use Illuminate\Support\Facades\Redis;

class IndexController extends Controller {
    public function index()
    {
        // 連接到 cluster1 集群
        $redis = Redis::connection('cluster1');
        for ($i = 0; $i < 5; $i++){
            $redis->set('age-'.$i,$i);
        }
    }
}
訪問該方法分蓖,最終寫入數(shù)據(jù)
image.png

該主從模式的優(yōu)缺點(diǎn)

優(yōu)點(diǎn)
  • 數(shù)據(jù)冗余和備份:主從復(fù)制模式提供了數(shù)據(jù)的冗余備份尔艇。主節(jié)點(diǎn)的數(shù)據(jù)會(huì)被復(fù)制到一個(gè)或多個(gè)從節(jié)點(diǎn)上,從節(jié)點(diǎn)可以充當(dāng)主節(jié)點(diǎn)的備份么鹤,確保數(shù)據(jù)的可用性和持久性终娃。
  • 擴(kuò)展讀取能力:從節(jié)點(diǎn)可以處理讀取請(qǐng)求,從而分擔(dān)主節(jié)點(diǎn)的讀取壓力蒸甜。通過將讀取請(qǐng)求分布到多個(gè)從節(jié)點(diǎn)上棠耕,可以提高系統(tǒng)的整體讀取吞吐量。
  • 數(shù)據(jù)分析和備份:從節(jié)點(diǎn)可以用于數(shù)據(jù)分析柠新、報(bào)表生成和數(shù)據(jù)備份等用途窍荧,而不會(huì)對(duì)主節(jié)點(diǎn)造成影響。

缺點(diǎn)

  • 寫入限制:從節(jié)點(diǎn)是只讀的恨憎,默認(rèn)不允許直接在從節(jié)點(diǎn)上進(jìn)行寫入操作蕊退。所有寫入操作必須通過主節(jié)點(diǎn)進(jìn)行,從節(jié)點(diǎn)只能接收主節(jié)點(diǎn)的數(shù)據(jù)復(fù)制憔恳∪坷螅可以通過redis.conf配置文件修改,將從節(jié)點(diǎn)的 slave-read-only參數(shù)設(shè)置為no钥组,這會(huì)允許從節(jié)點(diǎn)進(jìn)行寫入操作输硝。
  • 網(wǎng)絡(luò)傳輸開銷:主節(jié)點(diǎn)需要將數(shù)據(jù)復(fù)制到從節(jié)點(diǎn),這會(huì)產(chǎn)生網(wǎng)絡(luò)傳輸?shù)拈_銷程梦。如果網(wǎng)絡(luò)帶寬有限或延遲較高腔丧,可能會(huì)對(duì)數(shù)據(jù)同步的效率和速度產(chǎn)生影響。
  • 單點(diǎn)故障:主節(jié)點(diǎn)是整個(gè)系統(tǒng)的核心作烟,如果主節(jié)點(diǎn)發(fā)生故障愉粤,整個(gè)系統(tǒng)可能會(huì)受到影響。在這種情況下拿撩,需要手動(dòng)進(jìn)行故障轉(zhuǎn)移和主節(jié)點(diǎn)切換來保證系統(tǒng)的可用性衣厘。

下一篇文章會(huì)解決這個(gè)問題,利用哨兵模式 sentinel解決主機(jī)宕機(jī)自動(dòng)切換

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末压恒,一起剝皮案震驚了整個(gè)濱河市影暴,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌探赫,老刑警劉巖型宙,帶你破解...
    沈念sama閱讀 217,406評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異伦吠,居然都是意外死亡妆兑,警方通過查閱死者的電腦和手機(jī)魂拦,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來搁嗓,“玉大人芯勘,你說我怎么就攤上這事∠俟洌” “怎么了荷愕?”我有些...
    開封第一講書人閱讀 163,711評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)棍矛。 經(jīng)常有香客問我安疗,道長(zhǎng),這世上最難降的妖魔是什么够委? 我笑而不...
    開封第一講書人閱讀 58,380評(píng)論 1 293
  • 正文 為了忘掉前任茂契,我火速辦了婚禮,結(jié)果婚禮上慨绳,老公的妹妹穿的比我還像新娘掉冶。我一直安慰自己,他們只是感情好脐雪,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,432評(píng)論 6 392
  • 文/花漫 我一把揭開白布厌小。 她就那樣靜靜地躺著,像睡著了一般战秋。 火紅的嫁衣襯著肌膚如雪璧亚。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,301評(píng)論 1 301
  • 那天脂信,我揣著相機(jī)與錄音癣蟋,去河邊找鬼。 笑死狰闪,一個(gè)胖子當(dāng)著我的面吹牛疯搅,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播埋泵,決...
    沈念sama閱讀 40,145評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼幔欧,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了丽声?” 一聲冷哼從身側(cè)響起礁蔗,我...
    開封第一講書人閱讀 39,008評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎雁社,沒想到半個(gè)月后浴井,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,443評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡霉撵,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,649評(píng)論 3 334
  • 正文 我和宋清朗相戀三年磺浙,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了洪囤。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,795評(píng)論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡屠缭,死狀恐怖箍鼓,靈堂內(nèi)的尸體忽然破棺而出崭参,到底是詐尸還是另有隱情呵曹,我是刑警寧澤,帶...
    沈念sama閱讀 35,501評(píng)論 5 345
  • 正文 年R本政府宣布何暮,位于F島的核電站奄喂,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏海洼。R本人自食惡果不足惜跨新,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,119評(píng)論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望坏逢。 院中可真熱鬧域帐,春花似錦、人聲如沸是整。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,731評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽浮入。三九已至龙优,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間事秀,已是汗流浹背彤断。 一陣腳步聲響...
    開封第一講書人閱讀 32,865評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留易迹,地道東北人宰衙。 一個(gè)月前我還...
    沈念sama閱讀 47,899評(píng)論 2 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像睹欲,于是被迫代替她去往敵國(guó)和親菩浙。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,724評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容