MongoDB教程 专题
您的位置:database > MongoDB教程专题 > MongoDB 连接
MongoDB 连接
作者:--    发布时间:2019-11-20

描述

在本教程我们将讨论mongodb的不同连接方式。


启动 mongodb服务

在前面的教程中,我们已经讨论了如何启动mongodb服务,你只需要在mongodb安装目录的bin目录下执行'mongod'即可。

执行启动操作后,mongodb在输出一些必要信息后不会输出任何信息,之后就等待连接的建立,当连接被建立后,就会开始打印日志信息。

你可以使用mongodb shell 来连接 mongodb 服务器。你也可以使用php来连接mongodb。本教程我们会使用 mongodb shell来连接mongodb服务,之后的章节我们将会介绍如何通过php 来连接mongodb服务。

默认情况下,mongodb的启动端口为27017。比mongodb启动端口大1000的端口为mongodb的web用户界面,你可以再浏览器中输入http://localhost:28017 来访问mongodb的web用户界面。



通过shell连接mongodb服务

你可以通过执行以下命令来连接mongodb的服务。

注意:localhost为主机名,这个选项是必须的:

mongodb://localhost

当你执行以上命令时,你可以看到以下输出结果:

mongodb-connect

如果你检查从哪里连接到mongodb的服务器,您可以看到如下信息:

mongodb-connected 最后一行(标记处),打印了你成功连接上mongodb服务的信息。

mongodb连接命令格式

使用用户名和密码连接到mongodb服务器,你必须使用 'username:password@hostname/dbname' 格式,'username'为用户名,'password' 为密码。

使用用户名和密码连接登陆到默认数据库:<、p>

mongodb://mongo_admin:axb6_w3r@localhost/

以上命令中,用户 mongo_admin使用密码axb6_w3r连接到本地的mongodb服务上。输出结果如下所示:<、p> mongodb-connect-with-username-and-password-to-default-database

使用用户名和密码连接登陆到指定数据库:

连接到指定数据库的格式如下:

mongodb://mongo_admin:axb6_w3r@localhost/w3r


更多连接实例

连接本地数据库服务器,端口是默认的。

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 如果设置wie true, 同步到 journal (在提交到数据库前写入到实体中). 应用于 safe=true
connecttimeoutms=ms 可以打开连接的时间。
sockettimeoutms=ms 发送和接受sockets的时间。
网站声明:
本站部分内容来自网络,如您发现本站内容
侵害到您的利益,请联系本站管理员处理。
联系站长
373515719@qq.com
关于本站:
编程参考手册