通过shell连接MongoDB服务
你可以通过执行以下命令来连接MongoDB的服务。
注意:localhost为主机名,这个选项是必须的:mongodb://localhost当你执行以上命令时,你可以看到以下输出结果:$ ./mongoMongoDB shell version: 3.0.6connecting to: test> mongodb://localhostmongodb://localhost...这时候你返回查看运行
./mongod 命令的窗口,可以看到是从哪里连接到MongoDB的服务器,您可以看到如下信息:……省略信息……2015-09-25T17:22:27.336+0800 I CONTROL[initandlisten] allocator: tcmalloc2015-09-25T17:22:27.336+0800 I CONTROL[initandlisten] options: { storage: { dbPath: "/data/db" } }2015-09-25T17:22:27.350+0800 I NETWORK[initandlisten] waiting for connections on port 270172015-09-25T17:22:36.012+0800 I NETWORK[initandlisten] connection accepted from 127.0.0.1:37310 #1 (1 connection now open)# 该行表明一个来自本机的连接……省略信息……
MongoDB连接命令格式
使用用户名和密码连接到MongoDB服务器,你必须使用 "
username:password@hostname/dbname" 格式,"username"为用户名,"password" 为密码。使用用户名和密码连接登陆到默认数据库:$ ./mongoMongoDB shell version: 3.0.6connecting to: testmongodb://admin:123456@localhost/以上命令中,用户 admin 使用密码 123456 连接到本地的 MongoDB 服务上。输出结果如下所示:<、p>> mongodb://admin:123456@localhost/...使用用户名和密码连接登陆到指定数据库:连接到指定数据库的格式如下:mongodb://admin:123456@localhost/test
更多连接实例
连接本地数据库服务器,端口是默认的。mongodb://localhost使用用户名fred,密码foobar登录localhost的admin数据库。mongodb://fred:foobar@localhost使用用户名fred,密码foobar登录localhost的baz数据库。mongodb://fred:foobar@localhost/baz连接 replica pair, 服务器1为example1.com服务器2为example2。mongodb://example1.com:27017,example2.com:27017连接 replica set 三台服务器 (端口 27017, 27018, 和27019):mongodb://localhost,localhost:27018,localhost:27019连接 replica set 三台服务器, 写入操作应用在主服务器 并且分布查询到从服务器。mongodb://host1,host2,host3/?slaveOk=true直接连接第一个服务器,无论是replica set一部分或者主服务器或者从服务器。mongodb://host1,host2,host3/?connect=direct;slaveOk=true当你的连接服务器有优先级,还需要列出所有服务器,你可以使用上述连接方式。安全模式连接到localhost:mongodb://localhost/?safe=true以安全模式连接到replica set,并且等待至少两个复制服务器成功写入,超时时间设置为2秒。mongodb://host1,host2,host3/?safe=true;w=2;wtimeoutMS=2000
参数选项说明
标准格式:mongodb://[username:password@]host1[:port1][,host2[:port2],...[,hostN[:portN]]][/[database][?options]]标准的连接格式包含了多个选项(options),如下所示:
| 选项 | 描述 |
|---|
| replicaSet=name | 验证replica set的名称。 Impliesconnect=replicaSet. |
| slaveOk=true|false | - true:在connect=direct模式下,驱动会连接第一台机器,即使这台服务器不是主。在connect=replicaSet模式下,驱动会发送所有的写请求到主并且把读取操作分布在其他从服务器。
- false: 在 connect=direct模式下,驱动会自动找寻主服务器. 在connect=replicaSet 模式下,驱动仅仅连接主服务器,并且所有的读写命令都连接到主服务器。
|
| safe=true|false | - true: 在执行更新操作之后,驱动都会发送getLastError命令来确保更新成功。(还要参考 wtimeoutMS).
false: 在每次更新之后,驱动不会发送getLastError来确保更新成功。 |
| w=n | 驱动添加 { w : n } 到getLastError命令. 应用于safe=true。 |
| wtimeoutMS=ms | 驱动添加 { wtimeout : ms } 到 getlasterror 命令. 应用于 safe=true. |
| fsync=true|false | - true: 驱动添加 { fsync : true } 到 getlasterror 命令.应用于 safe=true.
- false: 驱动不会添加到getLastError命令中。
|
| journal=true|false | 如果设置为 true, 同步到 journal (在提交到数据库前写入到实体中). 应用于 safe=true |
| connectTimeoutMS=ms | 可以打开连接的时间。 |
| socketTimeoutMS=ms | 发送和接受sockets的时间。 |
更多MongoDB相关教程见以下内容:CentOS 编译安装 MongoDB与mongoDB的php扩展 http://www.linuxidc.com/Linux/2012-02/53833.htmCentOS 6 使用 yum 安装MongoDB及服务器端配置 http://www.linuxidc.com/Linux/2012-08/68196.htmUbuntu 13.04下安装MongoDB2.4.3 http://www.linuxidc.com/Linux/2013-05/84227.htmMongoDB入门必读(概念与实战并重) http://www.linuxidc.com/Linux/2013-07/87105.htmUbunu 14.04下MongoDB的安装指南 http://www.linuxidc.com/Linux/2014-08/105364.htm《MongoDB 权威指南》(MongoDB: The Definitive Guide)英文文字版[PDF] http://www.linuxidc.com/Linux/2012-07/66735.htmNagios监控MongoDB分片集群服务实战 http://www.linuxidc.com/Linux/2014-10/107826.htm基于CentOS 6.5操作系统搭建MongoDB服务 http://www.linuxidc.com/Linux/2014-11/108900.htm
MongoDB 的详细介绍:请点这里
MongoDB 的下载地址:请点这里
本文永久更新链接地址