1.1 在独立服务器上面建立索引

在独立服务器上面创建索引,可以在空闲时间于后台建立索引。

在后台建立索引,可利用background:true参数运行

>db.foo.ensureIndex({"somefield":1,{:background":true})

1、任何类型的索引均可在后台完成建立

2、前台建立索引耗时少,但是索引建立期间会锁定数据库,导致其他操作无法进行数据读写

3、后台建立索引期间,则会定期释放写锁,从而保证其他操作的运行

1.2 在副本集上建立索引

1、副本建立索引问题

如果集合较大,则会出现备份节点同时开始建立索引的情况。

突然间所有备份节点都无法被客户端读取了,同时可能也无法及时进行同步操作。

2、对于较大结合,推荐采用如下方式

(1)关闭一个备份节点

(2)将其作为独立的节点启动

(3)在这一服务器上建立索引

(4)重新将其作为成员加入副本集

(5)对每个备份节点执行同样的操作

3、对于主节点

(1)备份节点创建完索引后,于后台在主节点中建立索引

(2)关闭主节点,并执行以上步骤(1)-(4),像在备份节点一样,在主节点建立索引。该方式需要数据库停运一次,应权衡利弊进行选择。

1.3 在分片上建立索引

1.4 删除索引

使用dropIndexes命令指定索引名删除索引

查询system.indexes集合找出索引名,即使时自动生成的索引名,在不同驱动器键也会存在些差异

1、删除指定的单个索引

>db.runCommand({"dropIndex":"foo","index":"alphabet"})

2、删除集合中所有索引

>db.runCommand({"dropIndexes":"foo","index":"*"})

但是这种方法无法删除_id索引。只有删除整个集合才能删除掉该索引。

删除集合中的全部文档不会对该索引产生影响,新文档插入后索引仍可正常增加。

1.5 内存溢出杀手OOM Killer

可将MongoDB设置为不可被OOM Killer终止

MongoDB 建立与删除索引的更多相关文章

  1. mysql建立、删除索引及使用

    同步发布:http://www.yuanrengu.com/index.php/2017-01-13.html 一.索引的作用 一般的应用系统,读写比例在10:1左右,而且插入操作和一般的更新操作很少 ...

  2. MongoDB性能篇之创建索引,组合索引,唯一索引,删除索引和explain执行计划

    这篇文章主要介绍了MongoDB性能篇之创建索引,组合索引,唯一索引,删除索引和explain执行计划的相关资料,需要的朋友可以参考下 一.索引 MongoDB 提供了多样性的索引支持,索引信息被保存 ...

  3. paip.提升性能--- mysql 建立索引 删除索引 很慢的解决.

    paip.提升性能--- mysql 建立索引 删除索引 很慢的解决. 作者Attilax ,  EMAIL:1466519819@qq.com 来源:attilax的专栏 地址:http://blo ...

  4. oracle索引建立和删除

    1.多列建立索引 SQL> create index dex_index2 on dex(sex,name); Index created. SQL> select object_name ...

  5. mongodb建立索引

    创建索引 索引:以提升查询速度 语法:db.集合.ensureIndex({属性:1}),1表示升序,-1表示降序 具体操作:db.t255.ensureIndex({name:1}) db.t1.f ...

  6. mysql建立索引 删除索引

    建立索引 1.添加PRIMARY KEY(主键索引) mysql>ALTER TABLE `table_name` ADD PRIMARY KEY ( `column` ) 2.添加UNIQUE ...

  7. MYSQL索引的建立、删除以及简单使用

    一.前期数据准备 1.建表 CREATE TABLE `user` ( `uid` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(50) DEFAUL ...

  8. MySQL索引建立与删除

    #添加索引alter table 表名 add index 索引名称(列名1, 列名2);alter table 表名 add index 索引名称(列名1, 列名2, 列名3);alter tabl ...

  9. 【转载】8天学通MongoDB——第四天 索引操作

    这些天项目改版,时间比较紧,博客也就没跟得上,还望大家见谅. 好,今天分享下mongodb中关于索引的基本操作,我们日常做开发都避免不了要对程序进行性能优化,而程序的操作无非就是CURD,通常我们 又 ...

随机推荐

  1. 剑指offer62:二叉搜索树的第k个结点,二叉搜索树【左边的元素小于根,右边的元素大于根】

    1 题目描述 给定一棵二叉搜索树,请找出其中的第k小的结点.例如, (5,3,7,2,4,6,8)    中,按结点数值大小顺序第三小结点的值为4. 2 思路和方法 二叉搜索树[左边的元素小于根,右边 ...

  2. python 之 并发编程(守护线程与守护进程的区别、线程互斥锁、死锁现象与递归锁、信号量、GIL全局解释器锁)

    9.94 守护线程与守护进程的区别 1.对主进程来说,运行完毕指的是主进程代码运行完毕2.对主线程来说,运行完毕指的是主线程所在的进程内所有非守护线程统统运行完毕,主线程才算运行完毕​详细解释:1.主 ...

  3. PB之常用函数

    原文网址:https://www.cnblogs.com/zhaoxiong/p/8082523.html PB之常用函数 弹出窗口:messagebox() 基本写法:Messagebox('标题' ...

  4. linux环境,hidraw设备自动加载时默认权限的设置方法

    在linux系统中,hidraw设备会自动加载并设置默认权限,但系统的默认只允许root用户访问,普通用户是不允许读写. 设置的方法是修改udev的配置,配置路径是/etc/udev/rules.d/ ...

  5. vscode IIsExpress用法

    最近前端调试项目,都要安装IIS,使用IIS Express插件不需要另外在IIS架设站点,方便使用 1.安装IIS Express插件 2.ctrl+shfit+p 启动IIS Express 命令 ...

  6. Docker可视化管理工具portainer的简单应用

    portainer简介 略 安装portainer $ docker pull portainer/portainer$ docker volume create portainer_data $ d ...

  7. Element ui tree 搜索

    搜索框 属性 :filter-node-method="filterNode" 对树节点进行筛选时执行的方法,返回 true 表示这个节点可以显示,返回 false 则表示这个节点 ...

  8. CentOS 6.5 iptables原理详解以及功能说明

    CentOS 6.5 iptables原理详解以及功能说明 来源 https://blog.51cto.com/tanxw/1389114 前言 iptables其实就是Linux下的一个开源的信息过 ...

  9. 远程 Linux(Ubuntu 18)添加字体

    安装 xshell与xftp 连接xshell 点击 xshell上方工具栏中的xftp图标, 自动连接xftp linux下创建字体目录 su cd / cd usr/share/fonts mkd ...

  10. weui中的picker滑动报错

    html { touch-action: none; } 在页面插入上述代码即可解决