當內存用盡開始往磁碟上刷臟頁的時候,性能有非常大的波動,即使調整了syncdelay也沒有太大改善。在測試中還出現了一個莫名其妙的情況:MongoDB會間歇性地釋放文件系統的cache。下面學步園小編來講解下MongoDB的初始化步驟有哪些?MongoDB數據緩存刷新機制是什麼?
MongoDB的初始化步驟有哪些
intmain(intargc,char*argv[],char*envp[])
{
…
Module::configAll(params);
dataFileSync.go();
…
initAndListen(cmdLine.port,appsrvPath);
…
}
顯然,dataFileSync就是我們感興趣的那個類。dataFileSync類派生自BackgroundJob類,而BackgroundJob主要的功能就是生成一個後台線程並指派任務。數據的刷新是一個不斷執行的後台任務,在dataFileSync.run()裡面可以找到刷數據的相關代碼:
MongoDB數據緩存刷新機制是什麼
voidrun()
{
…
Date_tstart=jsTime();
intnumFiles=MemoryMappedFile::flushAll(true);
time_flushing=(int)(jsTime()–start);
globalFlushCounters.flushed(time_flushing);
…
}
從這一段代碼看,MongoDB會在syncdelay設定的周期內,採取同步的形式刷新所有的臟數據。再看一下flushAll是怎麼刷新所有數據的:
intMongoFile::flushAll(boolsync)
{
…
setseen;
while(true){
auto_ptrf;
{
rwlocklk(mmmutex,false);
for(set::iteratori=mmfiles.begin();i!=mmfiles.end();i++){
MongoFile*mmf=*i;
if(!mmf)
continue;
if(seen.count(mmf))
continue;
f.reset(mmf->prepareFlush());
seen.insert(mmf);
break;
}
}
if(!f.get())
break;
f->flush();
}
returnseen.size();
}
上面這一段代碼實現的功能很簡單,就是把mmfiles中所有MongoFile指針所引用的對象都flush()一次。不過在執行flush()函數之前,需要先執行prepareFlush()確保這個對象是可以執行flush()函數的。下面是最後真正執行刷新操作的代碼:
voidMemoryMappedFile::flush(boolsync)
{
if(view==0||fd==0)
return;
if(msync(view,len,sync?MS_SYNC:MS_ASYNC))
problem()<<「msync」< } 以上就是關於「MongoDB的初始化步驟有哪些?MongoDB數據緩存刷新機制是什麼」的內容,希望對大家有用。更多資訊請關注學步園。學步園,您學習IT技術的優質平台!