日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) >

【Redis】配置redis主从复制

發(fā)布時(shí)間:2025/7/14 65 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【Redis】配置redis主从复制 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

閱讀目錄

  • 簡(jiǎn)單介紹
  • 章節(jié)1:下載安裝
  • 章節(jié)2:修改配置文件
  • 章節(jié)3:開啟主從redis服務(wù)
  • 章節(jié)4:客戶端連接-測(cè)試同步
  • 章節(jié)5:應(yīng)用場(chǎng)景
  • 章節(jié)6:參考鏈接

簡(jiǎn)單介紹

redis的作用,可網(wǎng)上自行搜索,下面將介紹redis的主從復(fù)制。配置redis主從IP和port:
master and slaveipport
master127.0.0.16379
slave1127.0.0.1
6380
slave2127.0.0.1
6381

回到頂部

一、下載安裝

  • 下載文件:
  • wget http://download.redis.io/releases/redis-3.2.1.tar.gz


    • 解壓縮:
  • tar zxvf redis-3.2.1.tar.gz
  • mv redis-3.2.1 redis-3.2.1.master
  • tar zxvf redis-3.2.1.tar.gz
  • mv redis-3.2.1 redis-3.2.1.slave-1
  • tar zxvf redis-3.2.1.tar.gz
  • mv redis-3.2.1 redis-3.2.1.slave-2


    • 執(zhí)行make和make test
    分別進(jìn)入文件夾:redis-3.2.1.master、redis-3.2.1.slave-1和redis-3.2.1.slave的src目錄,執(zhí)行命令:
  • cd redis-3.2.1.master/src
  • make
  • make test
  • //其他兩個(gè)目錄執(zhí)行相同的操作
  • 執(zhí)行成功后會(huì)提示:
    回到頂部

    二、修改配置文件:redis.conf

    配置文件位于:(需要修改3個(gè)配置文件)
    主要修改4個(gè)參數(shù):
  • port;
  • logfile;
  • slaveof;
  • pidfile;
  • daemonize(配置以daemon方式運(yùn)行)

    • 修改master文件:redis.conf:
    配置文件的其他部分不要改動(dòng),修改如下內(nèi)容:
  • port 6379
  • pidfile /var/run/redis_6379.pid
  • # slaveof <masterip> <masterport>
  • logfile "/data/logs/redis.master.log"
  • daemonize yes

    • 修改slave1的配置文件:
  • port 6380
  • pidfile /var/run/redis_6380.pid
  • slaveof 127.0.0.1 6379
  • logfile "/data/logs/redis.slave1.log"
  • daemonize yes

    • 修改slave2的配置文件:
  • port 6381
  • pidfile /var/run/redis_6381.pid
  • slaveof 127.0.0.1 6379
  • logfile "/data/logs/redis.slave-6381.log"
  • daemonize yes


  • 回到頂部

    三、開啟master和slave1、slave2

    • 開啟master (salve的開啟方式與此類似)
    轉(zhuǎn)到目錄:redis-3.2.1.master 下(slave則轉(zhuǎn)到相應(yīng)的目錄),執(zhí)行:
  • ./src/redis-server redis.conf
  • 運(yùn)行成功后,查看logfile可以看到如下界面:
    • 開啟slave1
    可以看到slave1開啟的情況,如下圖:同時(shí)看到master的日志如下:


    • 開啟slave2
    可以看到slave2開啟的情況,如下圖:
    同時(shí)看到master的日志如下:

    • 查看運(yùn)行情況


    回到頂部

    四、客戶端連接-測(cè)試同步

    • 連接master客戶端,并創(chuàng)建數(shù)據(jù)
  • redis-cli -h 127.0.0.1 -p 6379


    • 連接slave,并查看數(shù)據(jù)同步情況:

    下面是另一個(gè)slave:

    Slave不可以寫,只可以讀

    當(dāng)連接上redis的slave時(shí),只可以讀數(shù)據(jù),不可以寫數(shù)據(jù):

    回到頂部

    五、應(yīng)用場(chǎng)景

    • 取最新N個(gè)數(shù)據(jù)的操作
    比如典型的取你網(wǎng)站的最新文章,通過(guò)下面方式,我們可以將最新的5000條評(píng)論的ID放在Redis的List集合中,并將超出集合部分從數(shù)據(jù)庫(kù)獲取使用LPUSH latest.comments<ID>命令,向list集合中插入數(shù)據(jù) 插入完成后再用LTRIM latest.comments 0 5000命令使其永遠(yuǎn)只保存最近5000個(gè)ID 然后我們?cè)诳蛻舳双@取某一頁(yè)評(píng)論時(shí)可以用下面的邏輯(偽代碼)
  • FUNCTION get_latest_comments(start,num_items):
  • ?? id_list = redis.lrange("latest.comments",start,start+num_items-1)
  • ?? IF id_list.length < num_items
  • ?? id_list = SQL_DB("SELECT ... ORDER BY time LIMIT ...")
  • ?? END
  • RETURN id_list
  • END
  • 如果你還有不同的篩選維度,比如某個(gè)分類的最新N條,那么你可以再建一個(gè)按此分類的List,只存ID的話,Redis是非常高效的

    • 排行榜應(yīng)用,取TOP N操作
    這個(gè)需求與上面需求的不同之處在于,前面操作以時(shí)間為權(quán)重,這個(gè)是以某個(gè)條件為權(quán)重,比如按頂?shù)拇螖?shù)排序,這時(shí)候就需要我們的sorted set出馬了,將你要排序的值設(shè)置成sorted set的score,將具體的數(shù)據(jù)設(shè)置成相應(yīng)的value,每次只需要執(zhí)行一條ZADD命令即可。

    • 需要精準(zhǔn)設(shè)定過(guò)期時(shí)間的應(yīng)用
    比如你可以把上面說(shuō)到的sorted set的score值設(shè)置成過(guò)期時(shí)間的時(shí)間戳,那么就可以簡(jiǎn)單地通過(guò)過(guò)期時(shí)間排序,定時(shí)清除過(guò)期數(shù)據(jù)了,不僅是清除Redis中的過(guò)期數(shù)據(jù),你完全可以把Redis里這個(gè)過(guò)期時(shí)間當(dāng)成是對(duì)數(shù)據(jù)庫(kù)中數(shù)據(jù)的索引,用Redis來(lái)找出哪些數(shù)據(jù)需要過(guò)期刪除,然后再精準(zhǔn)地從數(shù)據(jù)庫(kù)中刪除相應(yīng)的記錄。

    • 計(jì)數(shù)器應(yīng)用
    Redis的命令都是原子性的,你可以輕松地利用INCR,DECR命令來(lái)構(gòu)建計(jì)數(shù)器系統(tǒng)。

    • Uniq操作,獲取某段時(shí)間所有數(shù)據(jù)排重值
    這個(gè)使用Redis的set數(shù)據(jù)結(jié)構(gòu)最合適了,只需要不斷地將數(shù)據(jù)往set中扔就行了,set意為集合,所以會(huì)自動(dòng)排重。

    • Pub/Sub構(gòu)建實(shí)時(shí)消息系統(tǒng)
    Redis的Pub/Sub系統(tǒng)可以構(gòu)建實(shí)時(shí)的消息系統(tǒng),比如很多用Pub/Sub構(gòu)建的實(shí)時(shí)聊天系統(tǒng)的例子。

    • 構(gòu)建隊(duì)列系統(tǒng)
    使用list可以構(gòu)建隊(duì)列系統(tǒng),使用sorted set甚至可以構(gòu)建有優(yōu)先級(jí)的隊(duì)列系統(tǒng)。

    • 緩存


    回到頂部

    六、參考鏈接

    《Configuring Redis High Availability》http://www.veritas.com/community/blogs/configuring-redis-high-availability?《Windows下Redis Sentinel部署》http://bbs.redis.cn/forum.php?mod=viewthread&tid=715?




    來(lái)自為知筆記(Wiz)

    總結(jié)

    以上是生活随笔為你收集整理的【Redis】配置redis主从复制的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。