我得到了很多人的帮助,现在我想回馈。对于那些使Node.js服务器与MongoDB一起工作有困难的人来说,这就是我所做的。
答案 0 :(得分:10)
这最初是由提问者发布的。一位国会议员在评论中要求他将其作为答案发布,但没有得到回应。所以,我把它清理干净,然后自己发布。
当您查看代码时,您会注意到createServer
代码位于db.open
内。如果你反转它将无法工作。此外,不要关闭数据库连接。否则,在第一次之后,将不再打开db连接。 (当然,db.open
是在createServer
之外宣布的。)我不知道为什么createServer
位于db.open
之内。我想这可能与不打开太多数据库连接有关吗?
另外,我遇到的一个问题是,当我通过SSH运行它时,即使我在后台运行服务器(例如$ node server.js &
),2.5小时后,服务器也会死(但不是实例)。我不确定是因为终端连接还是什么。
这是程序&代码强>
环境:EC2,AMS-Linux-AMI
目的:获取HTTP请求并将查询,IP和时间戳记录到MongoDB中。
<强>步骤强>
1)创建实例(服务器)后,安装gcc。
$ yum install gcc-c++
2)下载Node.js文件并解压缩。 (我使用的是2.6版本。)
$ curl -O http://nodejs.org/dist/node-v0.2.6.tar.gz
$ tar -xzf node-v0.2.6.tar.gz
我将解压缩的文件夹重命名为“nodejs”
$ cd nodejs
$ sudo ./configure --without-ssl
$ sudo make
$ sudo make install
make
需要很长时间......之后你可以尝试在nodejs.org中运行示例
3)安装MongoDB。我安装了1.6.5版,而不是1.7版。
$ curl -O http://fastdl.mongodb.org/linux/mongodb-linux-x86_64-1.6.5.tgz
$ tar -xzf mongodb-linux-x86_64-1.6.5.tgz
$ sudo mkdir /data/db/r01/
我将文件夹重命名为“mongodb”
运行db进程:
$ ./mongodb/bin/mongod --dbpath /data/db/r01/
然后,如果您愿意,可以运行并尝试命令行。请参阅MongoDB的网站。
4)我建议您根据实例创建自己的AIM。这将需要20分钟。然后,重新创建安装并再次运行MongoDB。
5)安装node-mongodb-native
$ curl -O https://download.github.com/christkv-node-mongodb-native-V0.8.1-91-g54525d8.tar.gz
$ tar -xzf christkv-node-mongodb-native-V0.8.1-91-g54525d8.tar.gz
我将文件夹重命名为node-mongodb-native
$ cd node-mongodb-native
$ make
6)以下是服务器的代码:
GLOBAL.DEBUG = true;
global.inData = '';
var http = require('http');
sys = require("sys");
/* set up DB */
var Db = require('./node-mongodb-native/lib/mongodb').Db,
Connection = require('./node-mongodb-native/lib/mongodb').Connection,
Server = require('./node-mongodb-native/lib/mongodb').Server,
BSON = require('./node-mongodb-native/lib/mongodb').BSONNative;
var host = process.env['MONGO_NODE_DRIVER_HOST'] != null ? process.env['MONGO_NODE_DRIVER_HOST'] : 'localhost';
var port = process.env['MONGO_NODE_DRIVER_PORT'] != null ? process.env['MONGO_NODE_DRIVER_PORT'] : Connection.DEFAULT_PORT;
var db = new Db('test01', new Server(host, port, {}), {native_parser:true});
db.open(function(err, db) {
http.createServer(function (req, res) {
res.writeHead(200, {'Content-Type': 'text/plain'});
global.inData = {'p':'', 'url':''};
// get IP address
var ipAddress = req.connection.remoteAddress;
global.inData.ip = ipAddress;
// date time
var d = new Date();
var ts = d.valueOf();
global.inData.ts = ts;
// get the http query
var qs = {};
qs = require('url').parse(req.url, true);
if (qs.query !== null) {
for (var key in qs.query) {
if (key == 'p') {
global.inData.p = qs.query[key];
}
if (key == 'url') {
global.inData.url = qs.query[key];
}
}
}
if (global.inData.p == '' && global.inData.url == '') {
res.end("");
} else {
db.collection('clickCount', function(err, collection) {
if (err) {
console.log('is error \n' + err);
}
collection.insert({'p':global.inData.p,
'url':global.inData.url,
'ip':global.inData.ip,
'ts':global.inData.ts});
res.end("");
//db.close(); // DO NOT CLOSE THE CONNECTION
});
}
}).listen(8080);
});
console.log('Server running at whatever host :8080');
这可能不是完美的代码,但它会运行。我还不习惯“嵌套”或LISP编码风格。这就是我欺骗并使用global.inData
传递数据的原因。 :)
不要忘记将res.end("")
放在适当的位置(您认为应该结束HTTP请求调用)。
答案 1 :(得分:0)
顺便说一下,我上面发布的答案适用于CentOS和Fedora。
对于拥有Ubuntu的人来说,这是:
# for Gcc
$ sudo apt-get install build-essential
# for SSL
$ sudo apt-get install libssl-dev
然后如上所述安装node.js和mongodb。
此外,经过几个月的发展,我发现使用“npm”,“express”和“mongoose”可以让我的生活更轻松。另外,我已经安装了其他工具,比如调试器。
# Install Node Package Manager
$ sudo curl http://npmjs.org/install.sh | sh
# for debugging
$ sudo npm install node-inspector
# for Profiling
$ sudo npm install profile
# Install Express, the Node.js framework
$ sudo npm install express
# Install Template Engines (Now, let’s install Jade, jQuery Templates and EJS. You can pick the one you want)
$ sudo npm install jade jqtpl ejs
# XML related, install node-expat and then node-xml2js-expat
$ sudo apt-get install -y libexpat1-dev
$ sudo npm install node-xml2js
$ sudo npm install xml2js-expat
# Install Mongoose, (Mongo Driver)
$ sudo npm install mongoose
参考: http://npmjs.org
答案 2 :(得分:0)
看起来可能存在错误。它不允许我在a:b inside collection.insert({
)中使用var作为第一个参数无论哪种方式,它都将第一个文章视为“a”或“硬编码”。
我将调查此内容并在github上发布修复