成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

創(chuàng)新互聯(lián)教你設(shè)置Redis的LRU策略

2023-11-17    分類: 網(wǎng)站建設(shè)

概念

LRU(Least Recently Used)最近最少使用算法是眾多置換算法中的一種。

maxmemory

Redis中有一個(gè)maxmemory概念,主要是為了將使用的內(nèi)存限定在一個(gè)固定的大小。Redis用到的LRU 算法,是一種近似的LRU算法。

設(shè)置maxmemory

127.0.0.1:6379> CONFIG GET maxmemory
1) "maxmemory"
2) "0"
127.0.0.1:6379> CONFIG SET maxmemory 100Mb
OK
127.0.0.1:6379> CONFIG GET maxmemory
1) "maxmemory"
2) "104857600"

注意,在64bit系統(tǒng)下,maxmemory設(shè)置為0表示不限制Redis內(nèi)存使用,在32bit系統(tǒng)下,maxmemory隱式不能超過3Gb。當(dāng)Redis內(nèi)存使用達(dá)到指定的限制時(shí),就需要選擇一個(gè)置換的策略。

置換策略

當(dāng)Redis內(nèi)存使用達(dá)到maxmemory時(shí),需要選擇設(shè)置好的maxmemory-policy進(jìn)行對老數(shù)據(jù)的置換。

下面是可以選擇的置換策略:

  1. noeviction: 不進(jìn)行置換,表示即使內(nèi)存達(dá)到上限也不進(jìn)行置換,所有能引起內(nèi)存增加的命令都會返回error

  2. allkeys-lru: 優(yōu)先刪除掉最近最不經(jīng)常使用的key,用以保存新數(shù)據(jù)

  3. volatile-lru: 只從設(shè)置失效(expire set)的key中選擇最近最不經(jīng)常使用的key進(jìn)行刪除,用以保存新數(shù)據(jù)

  4. allkeys-random: 隨機(jī)從all-keys中選擇一些key進(jìn)行刪除,用以保存新數(shù)據(jù)

  5. volatile-random: 只從設(shè)置失效(expire set)的key中,選擇一些key進(jìn)行刪除,用以保存新數(shù)據(jù)

  6. volatile-ttl: 只從設(shè)置失效(expire set)的key中,選出存活時(shí)間(TTL)最短的key進(jìn)行刪除,用以保存新數(shù)據(jù)

volatile-lru和volatile-random經(jīng)常在一個(gè)Redis實(shí)例既做cache又做持久化的情況下用到,然而,更好的選擇使用兩個(gè)Redis實(shí)例來解決這個(gè)問題。設(shè)置是失效時(shí)間expire會占用一些內(nèi)存,而采用allkeys-lru就沒有必要設(shè)置失效時(shí)間,進(jìn)而更有效的利用內(nèi)存。

3 置換策略是如何工作的

理解置換策略的執(zhí)行方式是非常重要的,比如:

  1. 客戶端執(zhí)行一條新命令,導(dǎo)致數(shù)據(jù)庫需要增加數(shù)據(jù)(比如set key value)

  2. Redis會檢查內(nèi)存使用,如果內(nèi)存使用超過maxmemory,就會按照置換策略刪除一些key

  3. 新的命令執(zhí)行成功

我們持續(xù)的寫數(shù)據(jù)會導(dǎo)致內(nèi)存達(dá)到或超出上限maxmemory,但是置換策略會將內(nèi)存使用降低到上限以下。

如果一次需要使用很多的內(nèi)存(比如一次寫入一個(gè)很大的set),那么,Redis的內(nèi)存使用可能超出大內(nèi)存限制一段時(shí)間。

設(shè)置轉(zhuǎn)換策略

127.0.0.1:6379> CONFIG GET maxmemory-policy
1) "maxmemory"
2) "0"
127.0.0.1:6379> CONFIG SET maxmemory-policy allkeys-lru
OK
127.0.0.1:6379> CONFIG GET maxmemory-policy
1) "maxmemory-policy"

2) "allkeys-lru"

分享文章:創(chuàng)新互聯(lián)教你設(shè)置Redis的LRU策略
URL分享:http://jinyejixie.com/news44/294894.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供移動(dòng)網(wǎng)站建設(shè)、響應(yīng)式網(wǎng)站、品牌網(wǎng)站建設(shè)、網(wǎng)站改版、建站公司網(wǎng)頁設(shè)計(jì)公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

商城網(wǎng)站建設(shè)
桂平市| 奉化市| 界首市| 芮城县| 湘乡市| 宁陕县| 罗定市| 遂川县| 延津县| 怀远县| 门头沟区| 满城县| 财经| 彭州市| 乐昌市| 吕梁市| 丁青县| 安达市| 金川县| 太原市| 远安县| 柳河县| 中方县| 桃园县| 葫芦岛市| 临夏县| 新蔡县| 宜兰市| 论坛| 南通市| 海原县| 康平县| 定陶县| 钟祥市| 潼南县| 馆陶县| 沙河市| 保亭| 曲麻莱县| 古交市| 蒙山县|