MongoDB中連接字串的編寫_MongoDB

來源:互聯網
上載者:User

MongoDB資料庫與傳統的關係型資料庫相比,它具有操作簡單、完全免費、源碼公開等特點,這使MongoDB產品廣泛應用於各種大型門戶網站和專業網站。由於MongoDB串連並不支援HTTP協議,所有你不能直接通過瀏覽器訪問MongoDB,下面詳細介紹MongoDB中連接字串的編寫

一、MongoDB連接字串常用格式

複製代碼 代碼如下:

mongodb://[username:password@]host1[:port1][,host2[:port2],…[,hostN[:portN]]][/[database][?options]]

備忘:字串串連不區分大小寫,並非所有MongoDB驅動都支援完整的連接字串,不支援此格式串連字串的驅動會有替代串連方案,具體請參照驅動自身的說明文檔,看看如何定義uri標準串連的。

1、參數說明

    mongodb:// 這是固定的格式,必須要指定。
 username:password@ 可選項,如果設定,在串連資料庫伺服器之後,驅動都會嘗試登陸這個資料庫 host1 必須的指定至少一個host
    host1 是這個URI唯一要填寫的。它指定了要串連伺服器的地址。如果要串連複製集,請指定多個主機地址。

 :portX 可選的指定連接埠,如果不填,預設為27017
 /database 如果指定username:password@,串連並驗證登陸指定資料庫。若不指定,預設開啟admin資料庫。

 ?options 是串連選項。如果不使用/database,則前面需要加上/。所有串連選項都是索引值對name=value,索引值對之間通過&或;(分號)隔開

2、options 是串連參數

connect=direct|replicaSet
direct: 串連方式為單個伺服器。如果提供了多個主機地址,建立串連之後,按順序訪問。如果僅僅指定了一個主機,direct是預設值。
replicaSet: 就和描述的那樣,串連到replica set . 這個主機地址清單,是為了發現replica set。 如果串連多個主機replicaSet是預設值。
 
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命令中。.
 
maxPoolSize=n
minPoolSize=n
一些驅動會把沒用的串連關閉。 然而,如果串連數低於minPoolSize值之下, 它們不會關閉閒置串連。注意的是串連會按照需要進行建立,因此當串連池被許多串連預填充的時候,minPoolSize不會生效。
 
waitQueueTimeoutMS=ms
在逾時之前,線程等待串連生效的總時間。如果串連池到達最大並且所有的串連都在使用,這個參數就生效了。
 
waitQueueMultiple=n
驅動強行限制線程同時等待串連的個數。 這個限制了串連池的倍數。
 
connectTimeoutMS=ms
可以開啟串連的時間。
 
socketTimeoutMS=ms
發送和接受sockets的時間

二、MongoDB的連接字串執行個體

1、串連本機資料庫伺服器,連接埠是預設的。

複製代碼 代碼如下:

 mongodb://localhost

 2、使用使用者名稱fred,密碼foobar登入localhost的admin資料庫。

複製代碼 代碼如下:

mongodb://fred:foobar@localhost

3、使用使用者名稱fred,密碼foobar登入localhost的baz資料庫

複製代碼 代碼如下:

mongodb://fred:foobar@localhost/baz

4、串連 replica pair, 伺服器1為example1.com伺服器2為example2

複製代碼 代碼如下:

mongodb://example1.com:27017,example2.com:27017

5、串連 replica set 三台伺服器 (連接埠 27017, 27018, 和27019)

複製代碼 代碼如下:

mongodb://localhost,localhost:27018,localhost:27019

6、串連 replica set 三台伺服器, 寫入操作應用在主伺服器 並且分布查詢到從伺服器

複製代碼 代碼如下:

mongodb://host1,host2,host3/?slaveOk=true

7、直接連接第一個伺服器,無論是replica set一部分或者主伺服器或者從伺服器

複製代碼 代碼如下:

mongodb://host1,host2,host3/?connect=direct;slaveOk=true

8、當你的串連伺服器有優先順序,還需要列出所有伺服器,你可以使用上述串連方式
安全模式串連到localhost:

複製代碼 代碼如下:

mongodb://localhost/?safe=true

9、以安全模式串連到replica set,並且等待至少兩個複製伺服器成功寫入,逾時時間設定為2秒

複製代碼 代碼如下:

mongodb://host1,host2,host3/?safe=true;w=2;wtimeoutMS=2000

以上所述就是本文的全部內容了,希望大家能夠喜歡。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.