欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

redis快照模式_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理

 更新時(shí)間:2017年08月28日 11:20:16   作者:huangxincheng  
這篇文章主要為大家詳細(xì)介紹了redis快照模式的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

我們知道redis是帶有持久化這個(gè)能力了,那到底持久化成到哪里,持久化成啥樣呢???這篇我們一起來(lái)尋求答案。

一、快照模式

  或許在用Redis之初的時(shí)候,就聽(tīng)說(shuō)過(guò)redis有兩種持久化模式,第一種是SNAPSHOTTING模式,還是一種是AOF模式,而且在實(shí)戰(zhàn)場(chǎng)景下用的最多的莫過(guò)于SNAPSHOTTING模式,這個(gè)不需要反駁吧,而且你可能還知道,使用SNAPSHOTTING模式,需要在redis.conf中設(shè)置配置參數(shù),比如下面這樣:

# Save the DB on disk:
#
# save <seconds> <changes>
#
# Will save the DB if both the given number of seconds and the given
# number of write operations against the DB occurred.
#
# In the example below the behaviour will be to save:
# after 900 sec (15 min) if at least 1 key changed
# after 300 sec (5 min) if at least 10 keys changed
# after 60 sec if at least 10000 keys changed
#
# Note: you can disable saving completely by commenting out all "save" lines.
#
# It is also possible to remove all the previously configured save
# points by adding a save directive with a single empty string argument
# like in the following example:
#
# save ""

save 900 1
save 300 10
save 60 10000

上面三組命令也是非常好理解的,就是說(shuō)900指的是“秒數(shù)”,1指的是“change次數(shù)”,接下來(lái)如果在“900s“內(nèi)有1次更改,那么就執(zhí)行save保存,同樣的道理,如果300s內(nèi)有10次change,60s內(nèi)有1w次change,那么也會(huì)執(zhí)行save操作,就這么簡(jiǎn)單,看了我剛才說(shuō)了這么幾句話,是不是有種直覺(jué)在

告訴你,有兩個(gè)問(wèn)題是不是要澄清一下:

1. 上面這個(gè)操作應(yīng)該是redis自身進(jìn)行的同步操作,請(qǐng)問(wèn)是否可以手工執(zhí)行save呢? 

當(dāng)然可以進(jìn)行手工操作,redis提供了兩個(gè)操作命令:save,bgsave,這兩個(gè)命令都會(huì)強(qiáng)制將數(shù)據(jù)刷新到硬盤(pán)中,如下圖:

2. 看上面的圖,貌似bgsave是開(kāi)啟單獨(dú)線程的,請(qǐng)問(wèn)是嗎?

確實(shí)如你所說(shuō),bgsave是開(kāi)啟次線程進(jìn)行數(shù)據(jù)刷新的,不信的話我們來(lái)看看代碼,它的代碼是在rdb.c源文件中,如下:

從上面的代碼中,有沒(méi)有看到一個(gè)重點(diǎn),那就是fork方法,它就是一些牛人口中說(shuō)的什么fork出一個(gè)線程,今天你也算終于看到了,其實(shí)redis并不是單純的單線程服務(wù),至少fork告訴我們,它在一些場(chǎng)景下也是會(huì)開(kāi)啟工作線程的,然后可以看到代碼會(huì)在工作線程中執(zhí)行同步的bgsave操作,就這么簡(jiǎn)單。

3. 能簡(jiǎn)單說(shuō)下saveparams參數(shù)在redis源碼中的邏輯嗎?

可以的,其實(shí)在redis中有一個(gè)周期性函數(shù),叫做serverCron,它會(huì)周期性啟動(dòng),大概會(huì)做七件事情,如redis注釋所說(shuō):

/* This is our timer interrupt, called server.hz times per second.
 * Here is where we do a number of things that need to be done asynchronously.
 * For instance:
 *
 * - Active expired keys collection (it is also performed in a lazy way on
 * lookup).
 * - Software watchdog.
 * - Update some statistic.
 * - Incremental rehashing of the DBs hash tables.
 * - Triggering BGSAVE / AOF rewrite, and handling of terminated children.
 * - Clients timeout of different kinds.
 * - Replication reconnection.
 * - Many more...
 *
 * Everything directly called here will be called server.hz times per second,
 * so in order to throttle execution of things we want to do less frequently
 * a macro is used: run_with_period(milliseconds) { .... }
 */

int serverCron(struct aeEventLoop *eventLoop, long long id, void *clientData) {

上面的紅色字體就是做了我們所關(guān)心的save操作,看過(guò)方法的注釋?zhuān)酉聛?lái)我們來(lái)找一下具體邏輯。

從上面這段代碼邏輯,你應(yīng)該可以發(fā)現(xiàn)以下幾點(diǎn):

<1>.saveparams參數(shù)是在server對(duì)象下面,而server對(duì)象正好是redisServer類(lèi)型,如下圖:

從上面圖中 *saveparams 的注釋上來(lái)看,你應(yīng)該知道*saveparams是saveparam類(lèi)型的數(shù)組,那現(xiàn)在是不是有強(qiáng)烈的好奇心想看一下saveparam

類(lèi)型是怎么定義的的呢??? 如下圖:

可以看到,saveparam參數(shù)里面有兩個(gè)參數(shù),seconds就是保存秒數(shù),changes就是改變量,而這二個(gè)參數(shù)就對(duì)應(yīng)著我們配置文件中的900 0 這樣的配置。

<2> 然后我們通過(guò)if發(fā)現(xiàn),如果終滿(mǎn)足,就會(huì)最終調(diào)用rdbSaveBackground來(lái)持久化我們的rdb文件。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Redis過(guò)期事件監(jiān)聽(tīng)器的完整實(shí)現(xiàn)步驟

    Redis過(guò)期事件監(jiān)聽(tīng)器的完整實(shí)現(xiàn)步驟

    要使用 Redis 過(guò)期事件監(jiān)聽(tīng)器來(lái)更新數(shù)據(jù)庫(kù)狀態(tài),我們需要確保 Redis 的事件通知已啟用,并實(shí)現(xiàn)監(jiān)聽(tīng)器來(lái)捕獲過(guò)期的鍵,并根據(jù)需要更新數(shù)據(jù)庫(kù),本文給大家介紹了Redis過(guò)期事件監(jiān)聽(tīng)器的完整實(shí)現(xiàn)步驟,需要的朋友可以參考下
    2024-10-10
  • 淺談我是如何用redis做實(shí)時(shí)訂閱推送的

    淺談我是如何用redis做實(shí)時(shí)訂閱推送的

    這篇文章主要介紹了淺談我是如何用redis做實(shí)時(shí)訂閱推送的,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • Redis中緩存和數(shù)據(jù)庫(kù)雙寫(xiě)數(shù)據(jù)不一致的原因及解決方案

    Redis中緩存和數(shù)據(jù)庫(kù)雙寫(xiě)數(shù)據(jù)不一致的原因及解決方案

    這篇文章主要介紹了Redis中緩存和數(shù)據(jù)庫(kù)雙寫(xiě)數(shù)據(jù)不一致的原因及解決方案,文中通過(guò)圖文結(jié)合的方式講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2024-03-03
  • k8s部署redis哨兵的實(shí)現(xiàn)

    k8s部署redis哨兵的實(shí)現(xiàn)

    本文主要介紹了k8s部署redis哨兵的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • 詳解Redis Stream做消息隊(duì)列

    詳解Redis Stream做消息隊(duì)列

    這篇文章主要介紹了詳解Redis Stream做消息隊(duì)列,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-09-09
  • 一文搞懂Redis最常用String字符串技能

    一文搞懂Redis最常用String字符串技能

    想要一文搞懂Redis最常用字符串技能?你來(lái)對(duì)地方了,這篇指南將帶你深入淺出,輕松掌握Redis字符串的強(qiáng)大功能,別眨眼,跟我們一起,讓數(shù)據(jù)操作變得前所未有的簡(jiǎn)單,需要的朋友可以參考下
    2024-03-03
  • 本地訪問(wèn)不到公網(wǎng)redis的解決方案

    本地訪問(wèn)不到公網(wǎng)redis的解決方案

    本文詳述了本地訪問(wèn)不到公網(wǎng)redis的解決方案,包括分析報(bào)錯(cuò)原因、Redis配置文件的區(qū)別、bind和protected-mode配置的解析,最終通過(guò)修改Redis配置文件及創(chuàng)建啟動(dòng)腳本解決了訪問(wèn)不到公網(wǎng)redis得問(wèn)題,需要的朋友可以參考下
    2024-08-08
  • Redis分布式鎖之紅鎖的實(shí)現(xiàn)

    Redis分布式鎖之紅鎖的實(shí)現(xiàn)

    在Redis中,紅鎖是一種分布式鎖的實(shí)現(xiàn)機(jī)制,旨在解決多個(gè)客戶(hù)端在分布式環(huán)境中對(duì)共享資源進(jìn)行并發(fā)訪問(wèn)的問(wèn)題,本文主要介紹了Redis分布式鎖之紅鎖的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-12-12
  • Redis數(shù)據(jù)結(jié)構(gòu)類(lèi)型示例解析

    Redis數(shù)據(jù)結(jié)構(gòu)類(lèi)型示例解析

    這篇文章主要為大家介紹了Redis數(shù)據(jù)結(jié)構(gòu)類(lèi)型示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-02-02
  • Redis類(lèi)型type與編碼encoding原理及使用示例

    Redis類(lèi)型type與編碼encoding原理及使用示例

    這篇文章主要為大家介紹了Redis類(lèi)型type與編碼encoding原理及使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-03-03

最新評(píng)論