MongoDB的初始化步骤有哪些以及其缓存刷新机制是什么
MongoDB的初始化步骤有哪些以及其缓存刷新机制是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
当内存用尽开始往磁盘上刷脏页的时候,性能有非常大的波动,即使调整了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的初始化步骤有哪些以及其缓存刷新机制是什么问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341