自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

使用Redis的五個(gè)注意事項(xiàng)

數(shù)據(jù)庫(kù) 其他數(shù)據(jù)庫(kù) Redis
下面內(nèi)容來(lái)源于Quora上的一個(gè)提問(wèn),問(wèn)題是使用Redis需要避免的五個(gè)問(wèn)題。而回答中超出了五個(gè)問(wèn)題的范疇,描述了五個(gè)使用Redis的注意事項(xiàng)。如果你在使用或者考慮使用Redis,可能你可以學(xué)習(xí)一下下面的一些建議,避免一下提到的問(wèn)題。

下面內(nèi)容來(lái)源于Quora上的一個(gè)提問(wèn),問(wèn)題是使用Redis需要避免的五個(gè)問(wèn)題。而回答中超出了五個(gè)問(wèn)題的范疇,描述了五個(gè)使用Redis的注意事項(xiàng)。如果你在使用或者考慮使用Redis,可能你可以學(xué)習(xí)一下下面的一些建議,避免一下提到的問(wèn)題。

1.使用key值前綴來(lái)作命名空間

雖然說(shuō)Redis支持多個(gè)數(shù)據(jù)庫(kù)(默認(rèn)32個(gè),可以配置更多),但是除了默認(rèn)的0號(hào)庫(kù)以外,其它的都需要通過(guò)一個(gè)額外請(qǐng)求才能使用。所以用前綴作為命名空間可能會(huì)更明智一點(diǎn)。

另外,在使用前綴作為命名空間區(qū)隔不同key的時(shí)候,***在程序中使用全局配置來(lái)實(shí)現(xiàn),直接在代碼里寫(xiě)前綴的做法要嚴(yán)格避免,這樣可維護(hù)性實(shí)在太差了。

2.創(chuàng)建一個(gè)類(lèi)似 ”registry” 的key用于標(biāo)記key使用情況

為了更好的管理你的key值的使用,比如哪一類(lèi)key值是屬于哪個(gè)業(yè)務(wù)的,你通常會(huì)在內(nèi)部wiki或者什么地方創(chuàng)建一個(gè)文檔,通過(guò)查詢(xún)這個(gè)文檔,我們能夠知道Redis中的key都是什么作用。

與之結(jié)合,一個(gè)推薦的做法是,在Redis里面保存一個(gè)registry值,這個(gè)值的名字可以類(lèi)似于 __key_registry__ 這樣的,這個(gè)key對(duì)應(yīng)的value就是你文檔的位置,這樣我們?cè)谑褂肦edis的時(shí)候,就能通過(guò)直接查詢(xún)這個(gè)值獲取到當(dāng)前Redis的使用情況了。

3.注意垃圾回收

Redis是一個(gè)提供持久化功能的內(nèi)存數(shù)據(jù)庫(kù),如果你不指定上面值的過(guò)期時(shí)間,并且也不進(jìn)行定期的清理工作,那么你的Redis內(nèi)存占用會(huì)越來(lái)越大,當(dāng)有一天它超過(guò)了系統(tǒng)可用內(nèi)存,那么swap上場(chǎng),離性能陡降的時(shí)間就不遠(yuǎn)了。所以在Redis中保存數(shù)據(jù)時(shí),一定要預(yù)先考慮好數(shù)據(jù)的生命周期,這有很多方法可以實(shí)現(xiàn)。

比如你可以采用Redis自帶的過(guò)期時(shí)間為你的數(shù)據(jù)設(shè)定過(guò)期時(shí)間。但是自動(dòng)過(guò)期有一個(gè)問(wèn)題,很有可能導(dǎo)致你還有大量?jī)?nèi)存可用時(shí),就讓key過(guò)期去釋放內(nèi)存,或者是內(nèi)存已經(jīng)不足了key還沒(méi)有過(guò)期。

如果你想更精準(zhǔn)的控制你的數(shù)據(jù)過(guò)期,你可以用一個(gè)ZSET來(lái)維護(hù)你的數(shù)據(jù)更新程度,你可以用時(shí)間戳作為score值,每次更新操作時(shí)更新一下score,這樣你就得到了一個(gè)按更新時(shí)間排序序列串,你可以輕松地找到最老的數(shù)據(jù),并且從最老的數(shù)據(jù)開(kāi)始進(jìn)行刪除,一直刪除到你的空間足夠?yàn)橹埂?/p>

4.設(shè)計(jì)好你的Sharding機(jī)制

Redis目前并不支持Sharding,但是當(dāng)你的數(shù)據(jù)量超過(guò)單機(jī)內(nèi)存時(shí),你不得不考慮Sharding的事(注意:Slave不是用來(lái)做Sharding操作的,只是數(shù)據(jù)的一個(gè)備份和讀寫(xiě)分離而已)。

所以你可能需要考慮好數(shù)據(jù)量大了后的分片問(wèn)題,比如你可以在只有一臺(tái)機(jī)器的時(shí)候就在程序上設(shè)定一致性hash機(jī)制,雖然剛開(kāi)始所有數(shù)據(jù)都hash到一臺(tái)機(jī)器,但是當(dāng)你機(jī)器越加越多的時(shí)候,你就只需要遷移少量的數(shù)據(jù)就能完成了。

5.不要有個(gè)錘子看哪都是釘子

當(dāng)你使用Redis構(gòu)建你的服務(wù)的時(shí)候,一定要記住,你只是找了一個(gè)合適的工具來(lái)實(shí)現(xiàn)你需要的功能。而不是說(shuō)你在用Redis構(gòu)建一個(gè)服務(wù),這是很不同的,你把Redis當(dāng)作你很多工具中的一個(gè),只在合適使用的時(shí)候再使用它,在不合適的時(shí)候選擇其它的方法。

英文連接:http://www.quora.com/Redis/What-are-5-mistakes-to-avoid-when-using-Redis

原文鏈接:http://blog.nosqlfan.com/html/3705.html

【編輯推薦】

  1. 論NoSQL的數(shù)據(jù)模型
  2. 利用Java進(jìn)行MySql數(shù)據(jù)庫(kù)的導(dǎo)入和導(dǎo)出
  3. 20個(gè)數(shù)據(jù)庫(kù)設(shè)計(jì)***實(shí)踐
  4. 如何定義NoSQL
  5. MoreSQL(NewSQL)挑戰(zhàn) NoSQL?
責(zé)任編輯:林師授 來(lái)源: nosqlfan
相關(guān)推薦

2024-11-15 10:00:00

Python爬蟲(chóng)開(kāi)發(fā)

2024-03-19 17:35:49

商務(wù)辦公

2010-11-26 16:27:01

MySQL使用變量

2023-09-05 06:44:41

2023-04-28 15:05:25

React軟件項(xiàng)目可維護(hù)性

2024-10-10 17:00:30

2011-07-28 17:29:22

HBaseShell

2010-01-21 11:30:10

2011-05-26 11:22:04

SEO

2023-09-12 08:33:45

Redis@CacheEvic

2014-01-10 10:36:39

Hypervisor

2011-07-19 10:16:58

噴墨打印機(jī)注意事項(xiàng)

2010-01-18 14:25:19

使用C++Builde

2010-10-26 17:28:15

創(chuàng)建Oracle索引

2011-07-26 18:43:34

HBase Shell

2009-08-27 10:40:56

Java路徑

2013-09-25 10:15:51

閃存存儲(chǔ)優(yōu)勢(shì)注意事項(xiàng)

2010-07-20 13:02:03

SQL Server索

2011-08-02 13:08:06

Oracle索引

2021-10-08 11:45:33

內(nèi)存HeapByteBuf堆內(nèi)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)