MongoDB命令行与进程是怎样的
admin
2023-04-13 19:21:40
0

一、命令行

MongoDB shell 不仅仅是一个交互式的 shell,它也支持执行指定 javascript文件,也支持执行
指定的命令片断。
有了这个特性,就可以将 MongoDB 与 linux shell 完美结合,完成大部分的日常管理和维护
工作。
1 通过 eval 参数执行指定语句
一般我们这样执行一条命令:

MongoDB shell version: 2.4.7
connecting to: test
> db.stu.count()
10
>

实际上我们也可以这样:通过命令行 eval 参数直接执行语句:
MongoDB命令行与进程是怎样的

2 执行指定文件中的内容
如果涉及到很多的操作后,才能得到结果,那么用 eval 的方式来做的话是不可能完成的,
那么更灵活的执行指定文件的方式就派上用场了。例如我们仍然要查看 test 库 stu 表中的记
录数:

cat stu.js
var total = db.stu.count();
printjson('total count of stu is:'+ total);
printjson('----------------');

MongoDB命令行与进程是怎样的

大家可以看到最终得到stu表的记录数10,那么一些不必要的说明性文字我们要是不希望出
现该怎么办呢?
MongoDB命令行与进程是怎样的

通过指定 quiet 参数,即可以将一些登录信息屏蔽掉,这样可以让结果更清晰。

二、进程控制

DBA 经常要解决系统的一些查询性能问题,此时一般的操作习惯是先查看有哪些进程,
然后将异常的进程杀掉,那么 MongoDB 是怎么样处理的呢?

1 查看活动进程
查看活动进程,便于了解系统正在做什么,以便做下一步判断

db.currentOp()
{
    "inprog" : [
        {
            "opid" : 62475494,
            "active" : true,
            "secs_running" : 2,
            "op" : "getmore",
            "ns" : "local.oplog.rs",
            "query" : {
                                                                                                                                                                                            
            },
            "client" : "192.168.129.21:33065",
            "desc" : "conn1938595",
            "threadId" : "0x40458940",
            "connectionId" : 1938595,
            "waitingForLock" : false,
            "numYields" : 0,
            "lockStats" : {
                "timeLockedMicros" : {
                    "r" : NumberLong(83),
                    "w" : NumberLong(0)
                },
                "timeAcquiringMicros" : {
                    "r" : NumberLong(8),
                    "w" : NumberLong(0)
                }
            }
        }
    ]
}

字段说明:
Opid: 操作进程号
Op: 操作类型(查询,更新等)
Ns: 命名空间, 指操作的是哪个对象
Query: 如果操作类型是查询的话,这里将显示具体的查询内容
lockType: 锁的类型,指明是读锁还是写锁

2 结束进程
如果某个异常是由于某个进程产生的,那么一般 DBA 都会毫不留情的杀掉这个罪魁祸首的
进程,下面将是这操作

> db.killOp(1234/*opid*/)

注意:
不要 kill 内部发起的操作,比如说 replica set 发起的 sync 操作等

相关内容

热门资讯

我来教教您“上海明星麻将到底有... 有 亲,根据资深记者爆料上海明星麻将是可以开挂的,确实有挂(咨询软件无需...
【第一资讯】“微乐山东麻将怎么... 网上科普关于“微乐山东麻将有没有挂”话题很是火热,小编也是针对微乐山东麻将作*弊开挂的方法以及开挂对...
【第一消息】“天天爱麻将到底有... 【第一消息】“天天爱麻将到底有挂吗?”(详细开挂教程)您好,天天爱麻将这个游戏其实有挂的,确实是有挂...
终于了解“乐禧乾安麻将怎么装挂... 有 亲,根据资深记者爆料乐禧乾安麻将是可以开挂的,确实有挂(咨询软件无需...
智涌之江、新质答卷:华为与浙江... 如果将中国经济比作一艘乘风破浪的巨轮,那么浙江无疑是最先感应航向变化并快速付诸行动的“排头兵”。 2...
【今日要闻】“玄龙炸/金/花辅... 网上科普关于“玄龙炸/金/花有没有挂”话题很是火热,小编也是针对玄龙炸/金/花作*弊开挂的方法以及开...
目前拍照最漂亮的手机盘点:20... 在智能手机影像技术突飞猛进的2025年,拍照体验已成为用户选择手机的核心考量。本文通过实测对比,为您...
苹果、OPPO、小米超额了,其... 行业预测2026年对于智能手机领域来讲是非常难的一年,整体市场会出现同比下跌的情况。最主要的原因是存...
华为轮值董事长孟晚舟发表新年致... 12月30日,华为轮值董事长孟晚舟发表2026年新年致辞,题为《追风赶月莫停留,平芜尽处是春山》。“...
玩家分享攻略“温州茶苑怎么装挂... 您好:温州茶苑这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9784099】很多玩家在这款游戏...