浅析mongodb数据库链接

最近遇到服务器迁移,增加了mongodb的权限认证,所以导致之前的程序不能正确的执行,特意查看了相应的api
1. java连接mongodb
    MongoClient mongoClient;
    MongoCredential credential = MongoCredential.createCredential("user", "database", password);
    mongoClient = new MongoClient(new ServerAddress(ip, port), Arrays.asList(credential));
2. python连接mongodb
   from pymongo import MongoClient
    
    client = MongoClient("ip",port)
    client.database.authenticate("user","password")
    db = client.database

    collection = db.collection

    启动 MongoDB服务
    在前面的教程中,我们已经讨论了如何启动MongoDB服务,你只需要在MongoDB安装目录的bin目录下执行'mongod'即可.
    执行启动操作后,mongodb在输出一些必要信息后不会输出任何信息,之后就等待连接的建立,当连接被建立后,就会开始打印日志信息.
    你可以使用 MongoDB shell 来连接 MongoDB 服务器.你也可以使用 PHP 来连接 MongoDB.本教程我们会使用 MongoDB shell 来连接 Mongodb 服务,之后的章节我们将会介绍如何通过php 来连接MongoDB服务.//成都seo
    通过shell连接MongoDB服务
    你可以通过执行以下命令来连接MongoDB的服务.
    注意:localhost为主机名,这个选项是必须的:
    mongodb://localhost
    当你执行以上命令时,你可以看到以下输出结果:
    $ ./mongo
    MongoDB shell version: 3.0.6
    connecting to: test
    > mongodb://localhostmongodb://localhost
    ...
    这时候你返回查看运行 ./mongod 命令的窗口,可以看到是从哪里连接到MongoDB的服务器,您可以看到如下信息:
    ……省略信息……
    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: 3.0.6
    connecting to: test
    mongodb://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的时间.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值