主頁(yè) > 知識(shí)庫(kù) > Redis服務(wù)器的啟動(dòng)過(guò)程分析

Redis服務(wù)器的啟動(dòng)過(guò)程分析

熱門標(biāo)簽:百度競(jìng)價(jià)排名 地方門戶網(wǎng)站 鐵路電話系統(tǒng) AI電銷 Linux服務(wù)器 呼叫中心市場(chǎng)需求 服務(wù)外包 網(wǎng)站排名優(yōu)化

本文將通過(guò)分析代碼來(lái)介紹Redis的啟動(dòng)過(guò)程,通過(guò)查看Redis 的啟動(dòng)腳本,得知Redis的啟動(dòng)時(shí)從Redis.c的main方法開始的。Redis啟動(dòng)可以分為以下幾個(gè)步驟:

1.初始化Redis服務(wù)器全局配置
2.重置服務(wù)器Save參數(shù)(具體下文詳解)和加載配置文件
3.初始化服務(wù)器
4.加載數(shù)據(jù)庫(kù)
5.開始網(wǎng)絡(luò)監(jiān)聽

一,初始化Redis服務(wù)器全局配置。這一步驟主要是主要是根據(jù)Redis.h中設(shè)置的Static值來(lái)初始化Redis服務(wù)器配置,這里設(shè)置是Redis服務(wù)器的默認(rèn)配置。如:

·TCP Port,Redis Client的缺省Timeout;
·Redis缺省的數(shù)據(jù)庫(kù)數(shù)目;
·Redis Append 持久化方式的參數(shù)設(shè)置;
·Redis的所支持的各種數(shù)據(jù)結(jié)構(gòu)的缺省值的設(shè)置;
·Redis內(nèi)存Swap相關(guān)設(shè)置;
·Redis Master Slave相關(guān)的配置;
·Redis Command Table初始化。

 二,加載配置文件:

這一步是通過(guò)讀取的配置文件來(lái)對(duì)Redis服務(wù)器進(jìn)行設(shè)置,將會(huì)覆蓋上一步的某些缺省設(shè)置。打開下載下來(lái)的Redis源代碼,我們可以看到其根目錄下有一個(gè)默認(rèn)的配置文件redis.conf。需要注意的是,如果在啟動(dòng)Redis的時(shí)候沒(méi)有指定配置文件,則Redis服務(wù)器在啟動(dòng)的時(shí)候是不會(huì)加載這個(gè)默認(rèn)的配置文件進(jìn)行配置的。而且這個(gè)默認(rèn)的配置文件和第一步中得全局默認(rèn)缺省配置不盡相同,比如針對(duì)Redis的Append模式的數(shù)據(jù)保存策略的配置,redis.conf里面的設(shè)置是:

save 900 1 -------15分鐘內(nèi)一次更新
save 300 10 ------5分鐘內(nèi)10次更新
save 60 10000 ---1分鐘內(nèi)10000次更新。

而上一步里面的默認(rèn)缺省配置確實(shí):

save 60*60 1 -------一個(gè)小時(shí)內(nèi)1次更新
save 300 100 ------5分鐘內(nèi)100次更新
save 60 10000 ---1分鐘內(nèi)10000次更新。

因此我們?cè)趩?dòng)Redis的時(shí)候如果默認(rèn)配置不能滿足要求,則需要指明配置文件進(jìn)行配置。

三,初始化服務(wù)器:

初始化服務(wù)器是在initServer()方法中完成的,次方法利用上兩步設(shè)置的參數(shù)進(jìn)一步初始化服務(wù)器:

·創(chuàng)建用來(lái)維護(hù)clients和slaves的list
·創(chuàng)建共享對(duì)象。redisObject這個(gè)struct里有個(gè)變量叫做refcount,這個(gè)變量就是用來(lái)實(shí)現(xiàn)共享的。Redis的對(duì)象目前Redis只支持共享StringObject。Redis的共享對(duì)象有兩大類比:第一類:Redis server的各種操作需要經(jīng)常用到的各類對(duì)象,如:Redis Command的分隔符 "\r\n",用于Redis command的reply的"+OK\r\n"或者"-ERR\r\n"等對(duì)象,因?yàn)樵赗edis的各種操作這類對(duì)象要被頻繁使用,所以就在啟動(dòng)Redis的時(shí)候創(chuàng)建好,然后共用這些對(duì)象,減少時(shí)間成本和空間成本;第二,類的共享對(duì)象就是對(duì)應(yīng)于數(shù)字的StringObject,如:Set "olylakers1" 1234; Set "olylakes2" 1234;在Redis內(nèi)部,"olylakers1"和"olylakers2"這兩個(gè)key都指向由數(shù)字1234轉(zhuǎn)化的StringObject。這樣在海量數(shù)據(jù)和特定存儲(chǔ)內(nèi)容下,可以節(jié)省大量的內(nèi)存空間。可用通過(guò)REDIS_SHARED_INTEGERS這個(gè)參數(shù)來(lái)指定Redis啟動(dòng)的時(shí)候創(chuàng)建多少個(gè)第二類共享對(duì)象,默認(rèn)的參數(shù)是10000,即創(chuàng)建的StrongObject個(gè)取值范圍是0-9999之間。

·創(chuàng)建Pub/Sub通道
·初始化網(wǎng)絡(luò)監(jiān)聽EventLoop的相關(guān)內(nèi)容,如eventLoop,timeEvent,fileEvent等
·如果開啟了VM,則初始化虛擬內(nèi)存相關(guān)的IO/Thread

四,加載數(shù)據(jù):

根據(jù)配置的不同,Redis加載數(shù)據(jù)的源也不一樣,如果在配置文件里設(shè)置了appendonly  yes(默認(rèn)是no),那么就從appendfile加載數(shù)據(jù),反之則從RedisDb加載數(shù)據(jù)

·從appendfile加載數(shù)據(jù):我們先來(lái)看一下appendfile的內(nèi)容是什么。下面的一條記錄摘取自appendfile:SET $9 olylakers $3 oly。很顯,appendfile保存的就是redis server接收到的各種命令,那么從appendfile加載數(shù)據(jù)就是redis server從appenfile里面讀取這些命令的記錄,然后重新把這些命令執(zhí)行一遍即可。需要注意的是,如果開啟了VM,那么在從appendfile加載數(shù)據(jù)的時(shí)候可能要涉及swap操作。
·從redisdb加載數(shù)據(jù):如果沒(méi)有開啟appendonly,那么則需要從db file加載數(shù)據(jù)到內(nèi)存,其過(guò)程是:
1.通過(guò)處理select命令,選擇DB
2.然后從db file讀取key和value
3.檢查key是否過(guò)期,如果過(guò)期則跳過(guò)這個(gè)key,如果不過(guò)期,則把數(shù)據(jù)Add到對(duì)應(yīng)的db的dict中
4.如果開啟了VM,則從db file中l(wèi)oad數(shù)據(jù),也可能涉及到swap操作

五,開始網(wǎng)絡(luò)監(jiān)聽:

Redis的網(wǎng)絡(luò)監(jiān)聽沒(méi)有采用libevent等,而是自己實(shí)現(xiàn)了一套簡(jiǎn)單的機(jī)遇event驅(qū)動(dòng)的API,具體見ae.c。

標(biāo)簽:銅川 湖南 蘭州 黃山 衡水 崇左 湘潭 仙桃

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Redis服務(wù)器的啟動(dòng)過(guò)程分析》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266