mongodb性能问题及原理分析
近期忙着把一个项目从MySQL迁移到MongoDB,在导入旧数据的过程中。遇到了些许波折,犯了不少错误,但同一时候也学到了不少知识,遂记录下来。
公司为这个项目专门配备了几台高性能务器,清一色的双路四核超线程CPU,外加32G内存,运维人员安装好MongoDB后。就轮到我了。我习惯于在使用新server前先看看相关日志。了解一下基本情况。当我浏览MongoDB日志时,发现一些警告信息:
WARNING: You are running on a NUMA machine.
We suggest launching mongod like this to avoid performance problems:
numactl --interleave=all mongod [other options]当时我并不太清楚NUMA是什么东西,所以没有处理,仅仅是把问题报告给了运维人员。事实证明运维人员也没有处理,所以问题的序幕就这样拉开了…
迁移工作首先要导入旧数据。開始一切倒还正常。只是几小时之后,我无意中发现不知道什么时候開始数据导入的速度下降了,同一时候我的PHP脚本開始不停的抛出异常:
cursor timed out (timeout: 30000, time left: 0:0, status: 0)我一时推断不出问题所在,想想先在PHP脚本里加大Timeout的值应付一下:
MongoCursor::$timeout = -1;可惜这样并没有解决这个问题,错误反倒变着花样的出现了:
max number of retries exhausted, couldn't send query
couldn't send query: Broken pipe无奈之下用strace跟踪了一下PHP脚本:
shell> strace -p <PID>发现进程卡在了recvfrom操作上:
recvfrom(<FD>,通过例如以下命令查询recvfrom操作的含义是:receive a message from a socket
shell> apropos recvfrom还能够依照以下的方式确认一下:
shell> lsof -p <PID>
shell> ls -l /proc/<PID>/fd/<FD>此时查询MongoDB当前操作。发现差点儿每一个操作会消耗大量的时间:
shell> echo "db.currentOp()" | /path/to/mongo同一时候执行mongostat显示非常高的locked值。
…
反复做了非常多工作。但始终无法找到问题的症结在哪里,仅仅好求助官方论坛,那里的技术支持都非常热心,在我描写叙述了问题后,没过多久就有了回复,建议我检查一下是不是索引不佳所致,为了验证这样的可能,我激活了Profiler记录慢操作:
mongo> use <DB>
mongo> db.setProfilingLevel(1);只是结果显示基本都是insert操作(由于我是导入数据为主),本身就不须要索引:
mongo> use <DB>
mongo> db.system.profile.find().sort({$natural:-1})…
问题到了这里,似乎已经走投无路了。为了死马当活马医。我又反复了几次迁移旧数据的过程,结果自然是次次都出问题,但幸运的是我发现每当出问题的时候,在top命令的结果中,总有一个名叫irqbalance的进程居高不下,搜索了一下,结果非常多介绍irqbalance的文章中都提及了NUMA。让我一下子记起之前在日志中看到的警告信息,于是乎依照信息里介绍的,又一次启动了一下MongoDB:
shell> numactl --interleave=all /path/to/mongod一切都正常了。为了解决问题。浪费了非常多精神。实在没有力气再解释NUMA究竟是什么东西了。有想了解的网友能够參考老外的文章,里面的介绍非常翔实。
原文链接:huoding.com
对于罪魁祸首,作者留给大家去学习,NoSQLFan在这里能够给大家做一个简单的描写叙述,先解释几个概念
NUMA:NUMA是多核心CPU架构中的一种,其全称为Non-Uniform
Memory Access。简单来说就是在多核心CPU中。机器的物理内存是分配给各个核的。架构简图例如以下所看到的:

每一个核訪问分配给自己的内存会比訪问分配给其他核的内存要快。有以下几种訪问控制策略:
- 1.缺省(default):总是在本地节点分配(分配在当前进程执行的节点上);
- 2.绑定(bind):强制分配到指定节点上。
- 3.交叉(interleave):在全部节点或者指定的节点上交织分配;
- 4.优先(preferred):在指定节点上分配,失败则在其它节点上分配。
上面文章中最后使用numactl –interleave命令就是指定其为交叉共享模式。
irqbalance:这是作者在上面提到的一个占用CPU的进程。这个进程的作用是在多核心CPU的操作系统中,分配系统中断信号的。
概念说完了。以下是上面问题的简单描写叙述:
我们知道虚拟内存机制是通过一个中断信号来通知虚拟内存系统进行内存swap的,所以这个irqbalance进程忙。是一个危急信号。在这里是因为在进行频繁的内存交换。这样的频繁交换现象称为swap insanity,在MySQL中常常提到。也就是在NUMA框架中。採用不合适的策略,导致核心仅仅能从指定内存块节点上分配内存,即使总内存还有富余,也会因为当前节点内存不足时产生大量的swap操作。
对于NUMA。进一步了解能够參考:NUMA与英特尔下一代Xeon处理器 和MySQL单机多实例方案 两篇文章
mongodb性能问题及原理分析的更多相关文章
- mongodb基本命令,mongodb集群原理分析
mongodb基本命令,mongodb集群原理分析 集合: 1.集合没有固定数据格式. 2. 数据: 时间类型: Date() 当前时间(js时间) new Date() 格林尼治时间(object) ...
- 基于Lucene查询原理分析Elasticsearch的性能
前言 Elasticsearch是一个很火的分布式搜索系统,提供了非常强大而且易用的查询和分析能力,包括全文索引.模糊查询.多条件组合查询.地理位置查询等等,而且具有一定的分析聚合能力.因为其查询场景 ...
- 性能测试之数据库监控分析工具PMM
PMM(Percona Monitoring and Management) 是一个用于管理和监控数据库性能的开源平台. . 它能提供全面的基于时间和各类监控指标.计数器的分析. 性能测试中,是做数据 ...
- Handler系列之原理分析
上一节我们讲解了Handler的基本使用方法,也是平时大家用到的最多的使用方式.那么本节让我们来学习一下Handler的工作原理吧!!! 我们知道Android中我们只能在ui线程(主线程)更新ui信 ...
- 原子类java.util.concurrent.atomic.*原理分析
原子类java.util.concurrent.atomic.*原理分析 在并发编程下,原子操作类的应用可以说是无处不在的.为解决线程安全的读写提供了很大的便利. 原子类保证原子的两个关键的点就是:可 ...
- MongoDB性能篇之创建索引,组合索引,唯一索引,删除索引和explain执行计划
这篇文章主要介绍了MongoDB性能篇之创建索引,组合索引,唯一索引,删除索引和explain执行计划的相关资料,需要的朋友可以参考下 一.索引 MongoDB 提供了多样性的索引支持,索引信息被保存 ...
- paip.性能跟踪profile原理与架构与本质-- python扫带java php
paip.性能跟踪profile原理与架构与本质-- python扫带java php ##背景 弄个个输入法音标转换atiEnPH工具,老是python性能不的上K,7k记录浏览过k要30分钟了. ...
- web压测工具http_load原理分析
一.前言 http_load是一款测试web服务器性能的开源工具,从下面的网址可以下载到最新版本的http_load: http://www.acme.com/software/http_load/ ...
- MongoDB 性能优化五个简单步骤
MongoDB 一直是最流行的 NoSQL,而根据 DB-Engines Ranking 最新的排行,时下 MongoDB 已经击败 PostgreSQL 跃居数据库总排行的第四位,仅次于 Oracl ...
随机推荐
- solr copyfield字段使用实践
1.使用场景 比如我们现在有一个文档,有title.author.area.keyword.link等字段.现在要把这个文档索引到 solr中,为了方便对author.area.keyword进行搜索 ...
- 简单工厂模式 SimpleFactory
简单工厂模式 SimpleFactory 1.1什么是简单工厂设计模式 简单工厂模式是属于创建型模式,又叫做静态工厂方法(Static Factory Method)模式,但不属于23种GOF设计模 ...
- Python 自用代码(某方标准类网页源代码清洗)
用于mongodb中“标准”数据的清洗,数据为网页源代码,须从中提取: 标准名称,标准外文名称,标准编号,发布单位,发布日期,状态,实施日期,开本页数,采用关系,中图分类号,中国标准分类号,国际标准分 ...
- 转: android 内存检测工具 LeakCanary 说明
http://www.liaohuqiu.net/cn/posts/leak-canary-read-me/ LeakCanary 中文使用说明 10 May 2015 LeakCanary Andr ...
- [Android] 给图像加入相框、圆形圆角显示图片、图像合成知识
前一篇文章讲述了Android触屏setOnTouchListener实现突破缩放.移动.绘制和加入水印,继续我的"随手拍"项目完毕给图片加入相框.圆形圆角显示图片和图像合 ...
- System.getProperty("line.separator")
转自:http://blog.sina.com.cn/s/blog_707577700100nv74.html 标题所写的代码能获得当前系统的换行符. 不要随便用 \n\r \n \r,因 ...
- 对Socket CAN的理解(5)——【Socket CAN控制器的初始化过程】
转载请注明出处:http://blog.csdn.net/Righthek 谢谢! 对于一般的CAN模块,进行初始化时,最关键的是下面两步: 1. 配置CAN的位时序: 2. 配置CAN的消息报文 ...
- IOS Exception2 this class is not key value coding-compliant for the key Click
2015-06-16 23:00:53.706 MyIOSPackage[823:280049] *** Terminating app due to uncaught exception 'NSUn ...
- 记一次R的可视化使用-生成城市各个景点的多边形图
项目中须要用到全国各个城市的景点坐标范围.须要人工审核各个景点的数据正确性和各个景点之间的距离分布.首先想到的就是使用R绘制每一个景点的多边形区域. 首先通过python,依据数据生成R画图代码,当然 ...
- Android_View_得到Activity
Context context = view.getContext(); if (context instanceof Activity){ Activity activity = (Activity ...