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
以上所述就是本文的全部內容了,希望大家能夠喜歡。