今天第一次嘗試連接MongoDB數據庫,具體步驟也很簡單。
首先,通過NodeJS運行環境安裝MongoDB包,進入要安裝的目錄,執行語句
npm install mongodb
安裝成功后,通過如下語句測試與數據庫建立連接幾關閉數據庫
var mongo = require('mongodb');
var host = "localhost";
var port = mongo.Connection.DEFAULT_PORT;
//創建MongoDB數據庫所在服務器的Server對象
var server = new mongo.Server(host, port, {auto_reconnect:true});
//創建MongoDB數據庫
var db = new mongo.Db('node-mongo-example', server, {saft:true});
//數據庫連接操作
db.open(function(err, db){
if(err) {
console.log('連接數據庫發生錯誤');
throw err;}
else{
console.log("成功建立數據庫連接");
db.close();
}
});
db.on('close',function(err,db){
if (err) {throw err;}
else{
console.log("成功關閉數據庫");
}
});
在node的運行環境中運行以上代碼所在文件,出現如下所示錯誤:
mongodb數據庫的默認端口為27017,所以我把port改成默認的27017,運行文件后,仍然報錯,如下所示:
很顯然,錯誤本身不是端口號屬性問題,而是無法連接默認的MongoDB數據庫服務,最后終於明白造成以上錯誤的原因是沒有運行數據庫服務器的可執行文件。
具體啟動方法為:
在運行環境中進入MongoDB的安裝位置,進入bin文件夾下,運行如下代碼:
D:\Mongodb\bin>mongod --dbpath D:\Mongodb\data
一般情況下,上面的node.js代碼就可以正常運行了
但在最初嘗試時,我還遇到過一個問題,就是啟動上面的數據庫服務器時,在無法啟動,在反饋信息中有一條錯誤為:
2015-12-13T00:49:12.195+0600 I STORAGE [initandlisten] exception in initAndListen: 28663 Cannot start server. The default storage engine 'wiredTiger' is not available with this build of mongod. Please specify a different storage engine explicitly, e.g. --storageEngine=mmapv1., terminating 2015-12-13T00:49:12.195+0600 I CONTROL [initandlisten] dbexit: rc: 100
查找資料發現,這是由於版本沖突造成存儲路徑的混淆,具體解決方案為在bin目錄下運行如下語句:
D:\MongoDB\bin mongod --storageEngine=mmapv1 --dbpath [your-path]
再啟動數據庫服務就成功了。
可以通過訪問http:\\localhost:27017,可以看到如下提示:
It looks like you are trying to access MongoDB over HTTP on the native driver port.
就可以啟動成功了!
參考資料:http://chenzhou123520.iteye.com/blog/1582174
啟動mongoDB時出現的報錯:
1、Unable to connect MongoDB, please check your configurations. MongoDB said:Failed to connect to: 127.0.0.1:27017: 由於目標計算機積極拒絕,無法連接查看MongoDB故障old lock file,terminating的解決
關閉Mongodb前,未釋放鎖,導致重啟時失敗
刪除data目錄下的mongodb.lock文件,重啟即可
用mongodump備份數據庫時,不能使用fsync和鎖,否則dump程序無法連接數據庫
服務器,其他情況下使用fsync和鎖,需要注意操作可能會執行較長時間