現在的位置: 首頁 > 資料庫 > 正文

MongoDB的初始化步驟有哪些?MongoDB數據緩存刷新機制是什麼

2020年07月02日 資料庫 ⁄ 共 1343字 ⁄ 字型大小 評論關閉

  當內存用盡開始往磁碟上刷臟頁的時候,性能有非常大的波動,即使調整了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技術的優質平台!

抱歉!評論已關閉.