Mongodb使用killCursors停止运行的cursor

cursor指向查询结果的游标,通过游标向下移动,获得下一条查询结果。MongoDB分批向用户返回数据结果。通过游标的移动, mongodb确定当前返回结果的位置,是否要加载更多数据到内存当中。cursor有默认的超时时间, 超时后cursor会自动停止。当然,用户也可以手动使用killCursors命令,停止未完成的cursor.

killCursors功能

停止指定的游标或某个集合的游标。

各种Mongodb连接工具,基于killCursors命令,实现游标的部分操作。应用程序中,通常应用不会直接调用killCursors命令,而是数据库管理或开发人员,来运行killCurors命令,停止掉对数据库性能产生影响或长时间运行的cursor。

为了减少影响,降低风险,执行killCursors命令必须在当前集合所在的数据库中执行。

语法

复制代码
db.runCommand({    
	killCursors: <collection>,    
  cursors: [<cursor id1>, ...],    
  comment: <any>
})

其中,使用killCursors指定本次操作针对的集合名称。 字段cursors包含cursor id数组。comment是可选字段,用户对本次操作的一些备注和说明。可以是BSON类型中的任何一种数据类型。添加备注说明时,可以在下面的三个位置查看

  • Mongodb日志中,attr.command.cursor.comment字段
  • Database profile输出的command.comment字段
  • currentOp输出的command.comment字段

用户权限

使用killCursors时,用户需要拥有相应的权限。

停止当前用户创建的游标

  • 4.2及以后得版本,当前用户有权限停止自己创建的游标。当用户使用查询语句创建游标时,游标即与当前用户建立关联关系
  • 4.0及以前版本,用户需要有killCursors权限,才能停掉自己创建的游标。同样,与4.2版本想用,用户使用查询语句创建游标时,游标即与当前用户建立关联关系。

停止其他用户创建的游标

用户需要有killAnyCursor权限

应用举例

  • 创建游标

    use test

    db.runCommand({
    find: "resturants",
    filter: {stars: 5},
    projection: {
    name:1,
    rating: 1,
    address:1
    },
    sort: { name: 1},
    batchSize: 5
    })

    //返回
    {
    "waitedMS" : NumberLong(0),
    "cursor" : {
    "firstBatch" : [{
    "_id" : ObjectId("57506d63f578028074723dfd"),
    "name" : "Cakes and more"
    },{
    "_id" : ObjectId("57506d63f578028074723e0b"),
    "name" : "Pies and things"
    },{
    "_id" : ObjectId("57506d63f578028074723e1d"),
    "name" : "Ice Cream Parlour"
    },{
    "_id" : ObjectId("57506d63f578028074723e65"),
    "name" : "Cream Puffs"
    },{
    "_id" : ObjectId("57506d63f578028074723e66"),
    "name" : "Cakes and Rolls"
    }],
    "id" : NumberLong("18314637080"),
    "ns" : "test.restaurants"
    },
    "ok" : 1
    }

  • 使用killCursors停止游标

    use test
    db.runCommand({
    killCusors: "restaurants",
    cusors: [NumberLong("18314637080")]
    })

相关推荐
zh1570231 小时前
JavaScript中WorkerThreads解决服务端计算瓶颈
jvm·数据库·python
代码AI弗森1 小时前
一文理清楚“算力申请 / 成本测算 / 并发评估”
java·服务器·数据库
摇滚侠2 小时前
expdp 查看帮助
java·数据库·oracle
流年似水~2 小时前
MCP协议实战:从零搭建一个让Claude能“看见“数据库的工具服务
数据库·人工智能·程序人生·ai·ai编程
2401_871492853 小时前
Vue.js监听器watch利用回调函数处理级联下拉框数据联动
jvm·数据库·python
志栋智能3 小时前
超自动化安全:构建智能安全运营的核心引擎
大数据·运维·服务器·数据库·安全·自动化·产品运营
zhoutongsheng4 小时前
C#怎么实现Swagger文档 C#如何在ASP.NET Core中集成Swagger自动生成API文档【框架】
jvm·数据库·python
WinterKay4 小时前
【开源】我写了一个轻量级本地数据库浏览工具,支持 MySQL/Redis 只读查询
数据库·mysql·开源
zxrhhm5 小时前
Oracle 索引完整指南
数据库·oracle
程序猿乐锅6 小时前
【Tilas|第三篇】多表SQL语句
数据库·经验分享·笔记·学习·mysql