MONGODB数据架构





升级解决.计划



发现问题 



应用server用户数的突然涌入,创建server反应慢 





检查server,我发现,每次反应非常慢,至30ops 





检查过程 





.发现数据库查询缓慢 

.检查索引 

.检查内存占.用量 

.检查TCP连接









对照測试1 





.硬件配置: 

.client: 

.阿.里云,2cpu,2g内存。windows2008 

.服务端: 

.阿.里云,router:4cpu,4g内存。centos6.5 64位 

.阿.里云。mongod:2cpu,8g内存,centos6.5 64位 

.1.对router进.行測试。每秒200qps。

.2.对mongod进.行測试,每秒500qps。 

.小结:使.用sharding架构,查询会.比直接对单台mongo查询慢。









对照測试2 





.硬件配置: 

.client: 

.阿.里云,2cpu,2.5g内存,windows2008 

.阿.里云,2cpu。2.0g内存,windows2008 

.服务端: 

.阿.里云。mongod:2cpu。2.5g内存,windows2008 

.1.在本地2cpu,2.5g内存。windows2008进.行測试。查询速度达到3000qps,甚至有时候能突破5000qps。 

.2.在2cpu,2.0g内存,windows2008对mongod进.行測试,查询速度500qps。 

.小结:tcp对..网络有非常.大的影响。

对照測试3 





.硬件配置: 

.client: 

.物理机,2cpu,4.0g内存,windows2008 

.服务端: 

.物理机,mongod:2cpu,4.0g内存,centos6.5 64位 

.物理机,router:2cpu。4.0g内存。centos6.5 64位 

.1.对mongod进.行測试。查询速度1000qps。

.2.对router进.行測试。查询速度500qps。 

.小结:阿.里云存在.一定的限制。使得速度有上限。









对照測试4 





.硬件配置: 

.client: 

. ucloud,2cpu。4.0g内存,windows2008 

.服务端: 

. ucloud,mongod:2cpu,4.0g内存。centos6.5 64位 

. ucloud,router:2cpu。4.0g内存,centos6.5 64位 

.1.对mongod进.行測试,查询速度2000qps。 

.2.对router进.行測试,查询速度1000qps。 

.小结:ucloud.比阿.里云的机器性能好。









对照測试5 





.硬件配置: 

.client: 

. ucloud,16cpu,64.0g内存,windows2008 

.服务端: 

. ucloud,mongod:16cpu,64.0g内存,centos6.5 64位 

. ucloud。router:16cpu,64.0g内存,centos6.5 64位 

.1.对mongod进.行測试,查询速度13000qps。

.2.对router进.行測试,查询速度10000qps。 

.小结:至此最终找到问题根结,clientcpu核数决定mongodb查询速度。









结论 





1.阿.里云的云主机有做某些限制,导致.不管怎样设定系统。数据库的配置,都.无法突破.一个数量级的qps。

2.clientcpu核数决定mongodb查询速度。 

3.tcp的限制通过.走内..网能够避免。 

4.linux操作系统胜过windows。

因此mongodb架构在linux上.比架构在windows上更好。





最新架构









最新架构









极限性能測试 





.以上.面最新架构进.行測试: 

.打开4个iisclient,同一时候对router进.行查询。 

router能够达到每秒20000次查询。

换成业务对照。即每秒能够应付2000个人。









性能结论 





.为了保证线上业务的正常运.行,数据库所在的server须要8cpu,16g内存。 

.为了保证备份的完整性。因此正确slave数据库备份,正确router备用。备份保留30天。

版权声明:本文博客原创文章,博客,未经同意,不得转载。

MongoDB---性能优化---(1)的更多相关文章

  1. MongoDB 性能优化五个简单步骤

    MongoDB 一直是最流行的 NoSQL,而根据 DB-Engines Ranking 最新的排行,时下 MongoDB 已经击败 PostgreSQL 跃居数据库总排行的第四位,仅次于 Oracl ...

  2. mongodb可以通过profile来监控数据 (mongodb性能优化)

    mongodb可以通过profile来监控数据 (mongodb性能优化)   开启 Profiling  功能 ,对慢查询进行优化: mongodb可以通过profile来监控数据,进行优化. 查看 ...

  3. MongoDB性能优化

    一.索引 MongoDB 提供了多样性的索引支持,索引信息被保存在system.indexes 中,且默认总是为_id创建索引,它的索引使用基本和MySQL 等关系型数据库一样.其实可以这样说说,索引 ...

  4. MongoDB性能优化指南

    一.索引 MongoDB 提供了多样性的索引支持,索引信息被保存在system.indexes 中,且默认总是为_id创建索引,它的索引使用基本和MySQL 等关系型数据库一样.其实可以这样说说,索引 ...

  5. 开发高性能的MongoDB应用—浅谈MongoDB性能优化(转)

    出处:http://www.cnblogs.com/mokafamily/p/4102829.html 性能与用户量 “如何能让软件拥有更高的性能?”,我想这是一个大部分开发者都思考过的问题.性能往往 ...

  6. 开发高性能的MongoDB应用—浅谈MongoDB性能优化

    关联文章索引: 大数据时代的数据存储,非关系型数据库MongoDB 性能与用户量 “如何能让软件拥有更高的性能?”,我想这是一个大部分开发者都思考过的问题.性能往往决定了一个软件的质量,如果你开发的是 ...

  7. 【MongoDB】MongoDB 性能优化 - BI查询聚合

    在BI服务中通过查询聚合语句分析定位慢查询/聚合分析,小结如下: 慢查询定位: 通过Profile分析慢查询 对于查询优化: 通过添加相应索引提升查询速度: 对于聚合大数据方案: 首先要说明的一个问题 ...

  8. Liunx下Mysql,MongoDB性能优化的配置

    场景 这几天在赶十一上线的项目,但是突然发现接口性能不好,高并发支持不住.又不想改代码,就在数据库层面进行优化. Mysql 分区:项目中有对40万条的数据进行时间查询的要求,就算对DateTime建 ...

  9. MongoDB 性能优化

    Read Preferences/读写分离 有时候为了考虑应用程序的性能或响应性,为了提高读取操作的吞吐率,一个常见的措施就是进行读写分离,MongoDB副本集对读写分离的支持是通过Read Pref ...

  10. MongoDB实战性能优化

    1. 性能优化分类 mongodb性能优化分为软件层面和操作系统层面. 软件层面,一般通过修改mongodb软件配置参数来达到,这个需要非常熟悉mongodb里面的各种配置参数: 而操作系统层面,相对 ...

随机推荐

  1. Windows Azure 社区新闻综述(#77 版)

    欢迎查看最新版本的每周综述,其中包含有关云计算和 Windows Azure 的社区推动新闻.内容和对话.以下是本周的亮点. 文章.视频和博客文章 ·   文章: Windows Azure 表存储简 ...

  2. 【转】 随机梯度下降(Stochastic gradient descent)和 批量梯度下降(Batch gradient descent )的公式对比、实现对比

    梯度下降(GD)是最小化风险函数.损失函数的一种常用方法,随机梯度下降和批量梯度下降是两种迭代求解思路,下面从公式和实现的角度对两者进行分析,如有哪个方面写的不对,希望网友纠正. 下面的h(x)是要拟 ...

  3. GQ_百度百科

    GQ_百度百科 <GQ>杂志(原名<Gentlemen's Quarterly>,中文名<智族>)是一本男性月刊,内容著重于男性的时尚.风格.文化,也包括美食.电影 ...

  4. java基础知识----IO篇

    写在前面:本文章基本覆盖了java IO的所有内容.java新IO没有涉及.文章依然以样例为主,由于解说内容的java书非常多了,我觉的学以致用才是真.代码是写出来的,不是看出来的. 最后欢迎大家提出 ...

  5. 设置outlook自动回复

    当有同事需要出差时,或者不能即时回复邮件时,可用此功能. 下面列出设置步骤: 1.  首先,在桌面新建一个用以保存模板的文件夹,例如:emaii. 2.  新建一封邮件,输入你要自动回复的内容.另存为 ...

  6. iOS UISearchBar UISearchController

    搜索栏的重要性我们就不说了,狼厂就是靠搜索起家的,现在越来越像一匹没有节操的狼,UC浏览器搜索栏现在默认自家的神马搜索,现在不管是社 交,O2O还是在线教育等都会有一个搜索栏的实现,不过彼此实现效果是 ...

  7. Codeforces 486B - OR in Matrix

    矩阵的 OR ,也是醉了. 题目意思很简单,就是问你有没有这么一个矩阵,可以变化,得到输入的矩阵. 要求是这个矩阵每行都可以上下任意移动,每列都可以左右任意移动. 解题方法: 1.也是导致我WA 的原 ...

  8. hdu 2276 Kiki & Little Kiki 2

    点击打开hdu 2276 思路: 矩阵快速幂 分析: 1 题目给定一个01字符串然后进行m次的变换,变换的规则是:如果当前位置i的左边是1(题目说了是个圆,下标为0的左边是n-1),那么i就要改变状态 ...

  9. Android内存泄漏简介

    前言 不少人认为JAVA程序,因为有垃圾回收机制,应该没有内存泄露. 其实如果我们一个程序中,已经不再使用某个对象,但是因为仍然有引用指向它,垃圾回收器就无法回收它,当然该对象占用的内存就无法被使用, ...

  10. HTML5 上播放视频格式兼容性

    视频格式 当前,video 元素支持三种视频格式: 格式 IE Firefox Opera Chrome Safari Ogg No 3.5+ 10.5+ 5.0+ No MPEG 4 9.0+ No ...