如何正確的使用redis

如何正確的使用redis

ID:34757802

大?。?15.16 KB

頁數(shù):24頁

時(shí)間:2019-03-10

如何正確的使用redis_第1頁
如何正確的使用redis_第2頁
如何正確的使用redis_第3頁
如何正確的使用redis_第4頁
如何正確的使用redis_第5頁
資源描述:

《如何正確的使用redis》由會員上傳分享,免費(fèi)在線閱讀,更多相關(guān)內(nèi)容在工程資料-天天文庫。

1、如何正確地使用Redis1.Redis特性介紹1.1Redis概述Redis是一款依據(jù)BSD開源協(xié)議發(fā)行的高性能,使用ANSIC語言編寫、支持網(wǎng)絡(luò)、可基于內(nèi)存亦可持久化的日志型、Key-Value存儲系統(tǒng)(cacheandstore),并提供多種語言的API。它起步較晚,發(fā)展迅速,目前已被許多大型機(jī)構(gòu)采用。它通常被稱為數(shù)據(jù)結(jié)構(gòu)服務(wù)器,因?yàn)橹担╲alue)可以是字符串(String),哈希(hashes),列表(list),集合(sets)和有序集合(sortedsets)等類型。1.性能極高–Redis能支持超過100K每秒的讀寫頻率。

2、2.豐富的數(shù)據(jù)類型–Redis支持二進(jìn)制案例的Strings,Lists,Hashes,Sets及SortedSets數(shù)據(jù)類型操作。3.原子–Redis的所有操作都是原子性的,同時(shí)Redis還支持對幾個(gè)操作全并后的原子性執(zhí)行,我們能非常方便得實(shí)現(xiàn)事務(wù)。4.Redis支持publish/subscribe,通知,key過期等重要特性。5.Redis內(nèi)存中的數(shù)據(jù)支持實(shí)時(shí)持久化,非常安全。6.新版本Redis支持集群。Redis在最近發(fā)布了3.0.6穩(wěn)定版,我把最新的3.0.6穩(wěn)定版的配置翻譯了一遍,獲益匪淺,基本上對這個(gè)版本的Redis的很

3、多細(xì)節(jié)清晰了很多,下面針對一些重要配置介紹下Redis的相關(guān)特性。1.2Redis配置花了三天時(shí)間,把REDIS3.0.6英文版大部分都翻譯過來了,地址:http://q.fireflyclub.org/?/article/191.3內(nèi)存快照某個(gè)時(shí)間點(diǎn)Redis服務(wù)器內(nèi)存中的內(nèi)容我們稱之為快照,Redis會自動快照保存到磁盤,調(diào)用BGSAVE能手動觸發(fā)快照保存,保存快照的動作是后臺進(jìn)程完成的,保存快照期間其他客戶端仍然和可以讀寫REDIS服務(wù)器。后臺保存快照到磁盤會占用大量內(nèi)存。如果調(diào)用SAVE命令保存內(nèi)存中的數(shù)據(jù)到磁盤,將阻塞客戶端請

4、求,直到保存完畢。調(diào)用SHUTDOWN命令,Redis服務(wù)器會先調(diào)用SAVE,所有數(shù)據(jù)持久化到磁盤之后才會真正退出。在Redis的配置文件中可以配置內(nèi)存數(shù)據(jù)持久化的觸發(fā)條件#save<時(shí)間><變更次數(shù)>#兩個(gè)條件同時(shí)滿足,發(fā)生一次落地本地磁盤動作,下面三個(gè)配置是或的關(guān)系#如果不想落地內(nèi)存中的數(shù)據(jù),直接注釋掉下面三個(gè)配置即可#如果配置成save"",之前落地的數(shù)據(jù)都可能被刪除save9001save30010save60100001.1主從同步用slaveof的配置來設(shè)置本機(jī)的Redis作為從實(shí)例,實(shí)時(shí)從主實(shí)例讀取數(shù)據(jù),成為其鏡像。主要是

5、高可用場景需要本功能。以下是Redis主從同步的一些特性:1.同一個(gè)Master可以同步多個(gè)Slaves;2.Slave同樣可以接受其它Slaves的連接和同步請求,這樣可以有效的分載Master的同步壓力。因此我們可以將Redis的Replication架構(gòu)視為圖結(jié)構(gòu);3.MasterServer是以非阻塞的方式為Slaves提供服務(wù)。所以在Master-Slave同步期間,客戶端仍然可以提交查詢或修改請求;4.SlaveServer同樣是以非阻塞的方式完成數(shù)據(jù)同步。在同步期間,如果有客戶端提交查詢請求,Redis則返回同步之前的數(shù)據(jù)

6、;5.為了分載Master的讀操作壓力,Slave服務(wù)器可以為客戶端提供只讀操作的服務(wù),寫服務(wù)仍然必須由Master來完成。即便如此,系統(tǒng)的伸縮性還是得到了很大的提高;6.Master可以將數(shù)據(jù)快照保存操作交給Slaves完成,從而避免了在Master中要有獨(dú)立的進(jìn)程來完成此操作,減輕Master的壓力;7.Redis的數(shù)據(jù)同步是異步進(jìn)行的,你可以配置主實(shí)例在和從實(shí)例斷掉連接的時(shí)候停止接受客戶端發(fā)過來的寫請求,從而保證數(shù)據(jù)的一致性。8.同步是自動完成的,不需要人工干預(yù)。主從之間的網(wǎng)絡(luò)短暫的斷開后,從再次連上主之后,會自動從上次斷開的時(shí)候

7、同步數(shù)據(jù)。9.當(dāng)新的從實(shí)例連入主實(shí)例,或者從實(shí)例斷開連接時(shí)間比較長,再連入主實(shí)例的時(shí)候,為了保證數(shù)據(jù)一致,主實(shí)例會將全量數(shù)據(jù)同步給從實(shí)例。這種主要有兩種模式:文件模式:主實(shí)例創(chuàng)建一個(gè)任務(wù)去寫DB文件到磁盤,文件創(chuàng)建完畢后,主實(shí)例增量方式讀取文件中的數(shù)據(jù)傳輸給從實(shí)例;使用Disk-backed模式同步數(shù)據(jù)有個(gè)好處就是,這個(gè)文件一旦生成,多個(gè)slave實(shí)例過來全量同步,都可以重用這一個(gè)文件;網(wǎng)絡(luò)模式:主實(shí)例創(chuàng)建一個(gè)任務(wù)把全量數(shù)據(jù)直接寫入從實(shí)例的socket連接上,數(shù)據(jù)不落地。;使用Diskless模式同步全量數(shù)據(jù),一旦一個(gè)全量同步行為開始了

8、,其他slave實(shí)例的同步請求過來時(shí),只能先排到隊(duì)列里面去等下一次全量同步開始。使用diskless的數(shù)據(jù)同步時(shí),master實(shí)例會等一會(時(shí)間可配),看看這段時(shí)間內(nèi)是否有多個(gè)slave實(shí)例同時(shí)請求全量同步

當(dāng)前文檔最多預(yù)覽五頁,下載文檔查看全文

此文檔下載收益歸作者所有

當(dāng)前文檔最多預(yù)覽五頁,下載文檔查看全文
溫馨提示:
1. 部分包含數(shù)學(xué)公式或PPT動畫的文件,查看預(yù)覽時(shí)可能會顯示錯亂或異常,文件下載后無此問題,請放心下載。
2. 本文檔由用戶上傳,版權(quán)歸屬用戶,天天文庫負(fù)責(zé)整理代發(fā)布。如果您對本文檔版權(quán)有爭議請及時(shí)聯(lián)系客服。
3. 下載前請仔細(xì)閱讀文檔內(nèi)容,確認(rèn)文檔內(nèi)容符合您的需求后進(jìn)行下載,若出現(xiàn)內(nèi)容與標(biāo)題不符可向本站投訴處理。
4. 下載文檔時(shí)可能由于網(wǎng)絡(luò)波動等原因無法下載或下載錯誤,付費(fèi)完成后未能成功下載的用戶請聯(lián)系客服處理。