MongoDB - 連接
在本教學我們將討論 MongoDB 的不同連接方式。
啟動 MongoDB 服務
在前面的教學中,我們已經討論了如何啟動 MongoDB 服務,你只需要在 MongoDB 安裝目錄的 bin 目錄下執行 mongodb 即可。
執行啟動操作後,mongodb 在輸出一些必要資訊後不會輸出任何資訊,之後就等待連接的建立,當連接被建立後,就會開始列印日誌資訊。
你可以使用 MongoDB shell 來連接 MongoDB 伺服器。你也可以使用 PHP 來連接 MongoDB。本教學我們會使用 MongoDB shell 來連接 Mongodb 服務,之後的章節我們將會介紹如何通過php 來連接MongoDB服務。
標準 URI 連接語法:
mongodb://[username:password@]host1[:port1][,host2[:port2],...[,hostN[:portN]]][/[database][?options]]
-
mongodb:// 這是固定的格式,必須要指定。
username:password@ 可選項,如果設置,在連接資料庫伺服器之後,驅動都會嘗試登陸這個資料庫
host1 必須的指定至少一個host, host1 是這個URI唯一要填寫的。它指定了要連接伺服器的地址。如果要連接複製集,請指定多個主機地址。
portX 可選的指定端口,如果不填,默認為27017
/database 如果指定username:password@,連接並驗證登陸指定資料庫。若不指定,默認打開 test 資料庫。
?options 是連接選項。如果不使用/database,則前面需要加上/。所有連接選項都是鍵值對name=value,鍵值對之間通過&或;(分號)隔開
標準的連接格式包含了多個選項(options),如下所示:
選項 | 描述 |
---|---|
replicaSet=name | 驗證replica set的名稱。 Impliesconnect=replicaSet. |
slaveOk=true|false |
|
safe=true|false |
|
w=n | 驅動添加 { w : n } 到getLastError命令. 應用於safe=true。 |
wtimeoutMS=ms | 驅動添加 { wtimeout : ms } 到 getlasterror 命令. 應用於 safe=true. |
fsync=true|false |
|
journal=true|false | 如果設置為 true, 同步到 journal (在提交到資料庫前寫入到實體中). 應用於 safe=true |
connectTimeoutMS=ms | 可以打開連接的時間。 |
socketTimeoutMS=ms | 發送和接受sockets的時間。 |
實例
使用默認端口來連接 MongoDB 的服務。
mongodb://localhost
通過 shell 連接 MongoDB 服務:
$ ./mongo MongoDB shell version: 4.0.9 connecting to: test ...
這時候你返回查看運行 ./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: 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