mongo 笔记

mongodb://[username:password@]host1[:port1][,host2[:port2],...[,hostN[:portN]]][/[database][?options]]
  • mongodb:// 这是固定的格式,必需要指定。mongodb

  • username:password@ 可选项,若是设置,在链接数据库服务器以后,驱动都会尝试登录这个数据库shell

  • host1 必须的指定至少一个host, host1 是这个URI惟一要填写的。它指定了要链接服务器的地址。若是要链接复制集,请指定多个主机地址。数据库

  • portX 可选的指定端口,若是不填,默认为27017安全

  • /database 若是指定username:password@,链接并验证登录指定数据库。若不指定,默认打开 test 数据库。服务器

  • ?options 是链接选项。若是不使用/database,则前面须要加上/。全部链接选项都是键值对name=value,键值对之间经过&或;(分号)隔开socket

标准的链接格式包含了多个选项(options),以下所示:spa

选项 描述
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 的服务。get

mongodb://localhost

经过 shell 链接 MongoDB 服务:同步

$ ./mongo MongoDB shell version: 4.0.9 connecting to: test ...

这时候你返回查看运行 ./mongod 命令的窗口,能够看到是从哪里链接到MongoDB的服务器,您能够看到以下信息:it

……省略信息…… 2015-09-25T17:22:27.336+0800 I CONTROL [initandlisten] allocator: tcmalloc 2015-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 27017 2015-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' 为密码。

使用用户名和密码链接登录到默认数据库:

$ ./mongo MongoDB shell version: 4.0.9 connecting to: test

使用用户 admin 使用密码 123456 链接到本地的 MongoDB 服务上。输出结果以下所示:

> 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
相关文章
相关标签/搜索