文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

MongoDB的初始化步骤有哪些以及其缓存刷新机制是什么

2024-04-02 19:55

关注

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

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     801人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     348人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     311人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     432人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     220人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯