mongo shell启动配置文件.mongorc.js(四)


~/.mongorc.js文件描述如下:


#mongorc.js  
===============

我的 mongorc.js 文件.

提供:

  - `pretty()` 默认使用pretty()帮助方法查询  
  - `ugly()` 帮助方法    
  - prompt 显示与服务端类型相关的信息


## Pretty

mongo shell 有一个帮助函数叫做 `pretty()` 用于美化结果集。 使用这个 mongorc.js 文件默认启用pretty行为。

    > db.marioGames.find()  
    {    
      "_id" : ObjectId("507333d49c25fa3b6e62174d"),    
      "name" : "Super Mario Bros",    
      "super" : true,    
      "release" : ISODate("1985-09-13T07:00:00Z")    
    }    
    {    
      "_id" : ObjectId("5073347b9c25fa3b6e62174e"),    
      "name" : "Super Mario Bros 2",    
      "super" : true,    
      "release" : ISODate("1988-10-09T07:00:00Z")    
    }    
    {    
      "_id" : ObjectId("5073348f9c25fa3b6e62174f"),    
      "name" : "Super Mario Bros 3",    
      "super" : true,    
      "release" : ISODate("1990-02-09T08:00:00Z")    
    }


## Ugly

现在我们默认得到pretty的结果集合,我们偶尔会需要之前的行为(打印文档到单行)。  
通过使用 `ugly()` 帮助方法。方法:

    > db.marioGames({ super: true }).ugly();  
    { "_id" : ObjectId("507333d49c25fa3b6e62174d"), "name" : "Super Mario Bros", "super" : true, "release" : ISODate("1985-09-13T07:00:00Z") }    
    { "_id" : ObjectId("5073347b9c25fa3b6e62174e"), "name" : "Super Mario Bros 2", "super" : true, "release" : ISODate("1988-10-09T07:00:00Z") }    
    { "_id" : ObjectId("5073348f9c25fa3b6e62174f"), "name" : "Super Mario Bros 3", "super" : true, "release" : ISODate("1990-02-09T08:00:00Z") }


## Prompt

默认的prompt现在显示与连接的服务端相关的信息。

####replSet

```  
replSetName:ServerState|database>    
```

####mongos

```  
mongos|host:port|database>    
```

####mongod

```  
mongod|host:port|database>    
```


## Installation

    git clone [email protected]:aheckmann/mongorc.js.git  
    cd mongorc.js    
    make install

它拷贝 .mongorc.js 文件到你的HOME路径主目录。  
如果另一个 .mongorc.js 文件已经存在,它会被重命名为 .mongorc.js.old


## Uninstall

    cd mongorc.js  
    make uninstall

如果 ~/.mongorc.js.old 存在,它将重命名为 ~/.mongorc.js


## Licence

MIT


~/.mongorc.js文件内容如下:

;(function () {
/**  
* Make all queries pretty print by default.    
*/
DBQuery.prototype._prettyShell = true
/**  
* Allow opting into the default ugly print mode.    
*/
DBQuery.prototype.ugly = function () {  
  this._prettyShell = false;    
  return this    
}
/**  
* Override the default prompt to display info related    
* to type of server we connected to.    
*    
* @return {String}    
*/
prompt = function () {  
  var res = rs.status();    
  if (!res || res.errmsg) {    
    // not in a replica set    
    var status = db.serverStatus();    
    return status.process + "|" + status.host + "|" + db + "> ";    
  }
  return replsetPrompt();  
}
/**  
* Creates a prompt string for replSets    
*    
* @return {String}    
*/
function replsetPrompt () {  
  var status;    
  var admin = db.getSiblingDB("admin");    
  var info = admin.runCommand({ replSetGetStatus: 1, forShell: 1});
  if (info.ok) {  
    var state = "";    
    // do we need this?    
    info.members.some(function (member) {    
      if (member.self) {    
        state = member.stateStr;    
        return true;    
      }    
    });    
    status = info.set + ":" + (state || info.myState);    
  } else if (info.info && info.info.length < 20) {    
    // < 20 seems like a hack ??    
    status = info.info;    
  }
  return status + "|" + db + "> "  
}
})();

 

参见:https://github.com/aheckmann/mongorc.js