1.大部分IO操作为随机IO,建议采用SSD或PCIE,普通硬盘RAID10

2.IO调度算法。普通磁盘:deadline避免IO请求出现“饥饿”现象,SSD/PCIE:noop简单的先进先出处理请求。

  echo "noop" > /sys/block/sdxxxx/queue/scheduler        #SSD

  echo "deadline" > /sys/block/sdxxxx/queue/scheduler     #普通盘

  并添加至 /etc/rc.local

  cat /sys/block/sdxxxx/queue/scheduler    #查看

3.文件系统选择XFS

4.磁盘挂载

  vim /etc/fstab

  /dev/vdc  /data1    xfs  defaults,noatime,nodiratime       1 2

5.内存优化

  关闭大叶内存   echo "never" > /sys/kernel/mm/transparent_hugepage/enabled

         echo "never" > /sys/kernel/mm/transparent_hugepage/defrag

  numal设置        echo 0 > /proc/sys/vm/zone_reclaim_mode

并添加到/etc/rc.local

mongodb节点启动 sudo -u mongo numactl --interleave=all mongod -f mongo.cnf

6.NTP时间同步

7.进程数限制

  vim /etc/security/limits.conf

  * soft nofile 65535

  *  hard nofile 65535

*  soft   nproc 65535

*  hard  nproc 65535

*  soft    stack  1024

*  hard   stack   1024

  vim /etc/security/limits.d/90-nproc.conf

  *  soft   nproc   65535

8. mongo性能参数

  journal日志和data分开,journal不支持直接指定目录,可以创建软链接解决。

  wiredTigerCacheSizeGB=x  尽可能覆盖所有热数据

  storage.dirctoryPerDB=true  数据文件单独存储

  wiredTigerDirectoryForIndexes=true 索引文件单独存储

  wiredTigerCollectionBlockCompressor=snappy 集合压缩存储模式 zlib压缩最高

  journal=true

  安全参数

  nohttpinterface=true (<3.6版本)

  bind_ip_all_true (>=3.6) 配置节点访问范围

  keyFile=/dbPath/keyFile 指定集群间认证模式

    openssl rand -base64 66 -out keyFile

    chmod 600 keyFile && chown mongo.mongo keyFile

  setParameter=enableLocalhostAuthBypass=1  启用本地认证

  maxConns=65536 控制最大连接数

参数配置模板

fork =true  #后台运行

port =7777

quiet =true  # 方便排查问题

dbpath = /data1/xxxx

logpath=/data1/xxxx

logappend =true

journal=true

nohttpinterface=true   #3.6后已经废弃

directoryperdb=true

wiredTigerDirectoryForIndexes=true

bind_ip_all =true

maxConns=65536

profile=1  # 日志记录级别

slowms=500    #慢查询记录时间(毫秒)

replset=rs   #备份集

oplogSize=40960   #oplog大小

keyFile=/data1/xxxx/keyFile

setParameter=enableLocalhostAuthBypass=1

storageEngine=wiredTiger

wiredTigerCacheSizeGB=1

wiredTigerCollectionBlockCompressor=snappy

#shardsvr=true   #配置节点角色  (>=3.4 shard节点专用)

#configsvr=true    #指定config节点角色  (>=3.4 config节点专用)

#configdb=mschost    #指定config配置信息 (mongos 节点专用)

mongodb 参数优化的更多相关文章

  1. WiredTiger运行时参数优化

    MongoDB的WiredTiger存储引擎,用了一段时间,遇到了一些问题,通过优化WT参数,也解决了一些问题,做个小结. cache_size 指定WT存储引擎内部cache的内存用量上限. 需要注 ...

  2. linux下TCP/IP及内核参数优化调优(转)

    Linux下TCP/IP及内核参数优化有多种方式,参数配置得当可以大大提高系统的性能,也可以根据特定场景进行专门的优化,如TIME_WAIT过高,DDOS攻击等等. 如下配置是写在sysctl.con ...

  3. Windows下tcp参数优化

    Windows系统下的TCP参数优化2013-04-25      0 个评论       作者:最初的幸福ever收藏     我要投稿Windows系统下的TCP参数优化 TCP连接的状态与关闭方 ...

  4. paper 62:高斯混合模型(GMM)参数优化及实现

    高斯混合模型(GMM)参数优化及实现 (< xmlnamespace prefix ="st1" ns ="urn:schemas-microsoft-com:of ...

  5. MySQL配置文件my.cnf参数优化和中文详解

    Mysql参数优化对于新手来讲,是比较难懂的东西,其实这个参数优化,是个很复杂的东西,对于不同的网站,及其在线量,访问量,帖子数量,网络情况,以及机器硬件配置都有关系,优化不可能一次性完成,需要不断的 ...

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

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

  7. 内核参数优化/etc/sysctl.conf

    net.nf_conntrack_max = 65536000net.netfilter.nf_conntrack_tcp_timeout_established = 1200net.ipv4.tcp ...

  8. Limit参数优化MySQL查询的方法

    在做一些查询时,总希望能避免数据库引擎做全表扫描,因为全表扫描时间长,而且其中大部分扫描对客户端而言是没有意义的.那么,在mysql中有那些方式是可以避免全表扫面?除了通过使用索引列或分区等方式来进行 ...

  9. MySQL参数优化

    目前针对MySQL数据库进行了一些参数优化,具体如下: my.ini / my.cnf 参数说明 #使用查询缓存 query_cache_size=100M                     # ...

随机推荐

  1. golang 中string和int类型相互转换

    总结了golang中字符串和各种int类型之间的相互转换方式: string转成int: int, err := strconv.Atoi(string)string转成int64: int64, e ...

  2. Javascript模块化简史

    Script标签和闭包 RequireJS, AngularJS以及依赖注入 Node.js以及CommonJS的出现 ES6, import, Babel和Webpack https://ponyf ...

  3. tarjan 题目汇总(含解析)

    下面容许我偷个懒,洛谷上写过的blog我就不来再抄一遍了 洛谷P3436 [[POI2006]PRO-Professor Szu](别称:作死的老教授) 洛谷P4306 [[JSOI2010]连通数] ...

  4. 浅析nodejs的buffer类(转)

    最近翻阅了node v0.10.4的buffer类的源代码,收获不少,也很久没有在cnode上发表文章了,想把一些收获分享给大家,有什么错误的地方希望大牛们指正啊. 前阵子有位rrestjs框架的使用 ...

  5. 详解HTTPS、TLS、SSL

    HTTPS.TLS.SSL HTTP也称作HTTP over TLS.TLS的前身是SSL,TLS 1.0通常被标示为SSL 3.1,TLS 1.1为SSL 3.2,TLS 1.2为SSL 3.3.下 ...

  6. vue路由懒加载

    大项目中,为了提高初始化页面的效率,路由一般使用懒加载模式,一共三种实现方式.(1)第一种写法: component: (resolve) => require(['@/components/O ...

  7. 还在期待安卓9.0吗?Android 10.0要来了

    目前,美国 Google公司的 AndroidP (安卓9.0),已经正式全面推出有几个多月了.众多手机品牌厂商也都在积极的进行更新适配 Android 9.0 系统(修改UI界面也算是二次开发,嗯) ...

  8. 调用脚本的方式自动的创建或者是更新oracle数据库自带的Seq序列号的值

    执行脚本: CREATE OR REPLACE PACKAGE PKG_QUERY IS -- Author : ADMINISTRATOR -- Created : 2016/12/8 星期四 10 ...

  9. Vue父子组件之间的相互通信

    组件是Vue知识体系中最重要的一部分之一,父子组件由于作用域的不同,无法直接对对方的数据进行操作.它们之间的数据传递都是通过中间介质进行的,父组件给子组件传值是通过props属性,而子组件给父组件传值 ...

  10. 微信支付的安全漏洞之XXE

    1.场景:国外安全社区公布微信支付官方SDK存在严重漏洞,可导致商家服务器被入侵(绕过支付的效果).目前,漏洞详细信息以及攻击方式已被公开,影响范围巨大(已确认陌陌.vivo因使用该SDK而存在该漏洞 ...