express:node throwing error on mongodb

1: C:\Node_app\microblog\node_modules\connect-mongo\lib\connect-mongo.js:126

       2:         throw new Error('Error connecting to database');

       3:               ^

       4: Error: Error connecting to database

       5:     at module.exports.MongoStore.__proto__ (C:\Node_app\microblog\node_module

       6:     at Db.open (C:\Node_app\microblog\node_modules\connect-mongo\node_modules

       7:     at Server.connect.connectionPool.on.server._serverState (C:\Node_app\micr

       8: ion\server.js:408:7)

       9:     at EventEmitter.emit (events.js:115:20)

      10:     at connection.on.connectionStatus (C:\Node_app\microblog\node_modules\con

      11: :93:15)

      12:     at EventEmitter.emit (events.js:91:17)

      13:     at Socket.errorHandler (C:\Node_app\microblog\node_modules\connect-mongo\

      14:     at Socket.EventEmitter.emit (events.js:88:17)

      15:     at Socket._destroy.self.errorEmitted (net.js:329:14)

      16:     at process.startup.processNextTick.process._tickCallback (node.js:244:9)

与此类似node throwing error on mongodb,一直报Db.open那里出错,查源代码,发现应该是有err参数传入,因为之前从来没接触过mongodb--在某些文章中看到稍微有些了解,觉得是不是没有安装mongodb的问题呢?试了一下,果然如此。

windows下安装mongodb:

1、下载MongoDB,下载页面>>

2、解压安装,因为我电脑的C盘非系统盘,默认是我工作目录,所以我先解压到这个盘里。c:\mongodb (解压出来有一个bin目录,里面很多exe文件),然后再建立一个目录和文件

c:\mongodb\logs\mongodb.log

3、建立MongoDB的数据存放目录,假设为c:\mongodb_data\db

4、启动Mongo Db服务,如果控制台上看到类似的信息,则说明启动成功

默认MongoDB监听的端口是27017,mysql的是3306

5、测试连接

新开一个cmd窗口,进入mongodb的bin目录,输入mongo.exe,出现如下信息说明测试通过

继续测试

1: >use test

       2: sitched to db test

       3: >db.foo.save({hello:1, word:2})

       4: >db.foo.find()

       5: "_id" : ObjectId("500a5fde4ad5d4c1884a5c3f"), "hello" : 1, "word" : 2 }

然后输入exit,退出窗口,然后再输入exit关闭该dos

6、注册MongoDB为系统服务。

1: C:\mongodb\bin>mongod.exe --dbpath=c:\mongodb_data\db --logpath=c:\mongodb\logs\mongodb.log --install

如果需要卸载该服务,使用“sc delete MongoDB”即可

7、启动mongodb服务

net start MongoDB

打开任务管理器,可以看到进程已经启动

如果需要停止服务: net stop MongoDb

再次启动app,发现可以正常启动了

到这里express中使用mongodb来保存session就可以正常工作了,app.js的代码如下:

1:  

       2: /**

       3:  * Module dependencies.

       4:  */

       5:  

       6: var express = require('express');

       7: var http = require('http');

       8: var routes = require('./routes');

       9:  

      10: var settings = require('./settings');

      11:  

      12: var MongoStore = require('connect-mongo')(express);

      13: //var connect = require('connect');

      14: //var MongoStore = require('connect-mongo')(connect);

      15:  

      16:  

      17: var sessionStore = new MongoStore({

      18:     db : settings.db

      19: }, function() {

      20:         console.log('connect mongodb success...');

      21:     });

      22:  

      23:  

      24:  

      25: var app = express();

      26:  

      27: app.configure(function(){

      28:   app.set('port', process.env.PORT || 3000);

      29:   app.set('views', __dirname + '/views');

      30:   app.set('view engine', 'jade');

      31:   app.use(express.favicon());

      32:   app.use(express.logger('dev'));

      33:   app.use(express.bodyParser());

      34:   app.use(express.methodOverride());

      35:  

      36:   app.use(express.cookieParser());

      37:   

      38:   app.use(express.session({

      39:     secret : settings.cookie_secret,

      40:     store : sessionStore,

      41:     cookie : {

      42:         maxAge : new Date(Date.now() + 1000 * 60 * 60)

      43:     }    

      44:   }));

      45:  

      46:   app.use(app.router);

      47:   app.use(express.static(__dirname + '/public'));

      48: });

      49:  

      50: app.configure('development', function(){

      51:   app.use(express.errorHandler());

      52: });

      53:  

      54: app.get('/', routes.index);

      55:  

      56:  

      57: http.createServer(app).listen(app.get('port'), function(){

      58:   console.log("Express server listening on port " + app.get('port'));

      59: });

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏匠心独运的博客

消息中间件—RocketMQ消息消费(一)

文章摘要:在发送消息给RocketMQ后,消费者需要消费。消息的消费比发送要复杂一些,那么RocketMQ是如何来做的呢? 在RocketMQ系列文章的前面几...

44630
来自专栏王硕

原 使用PostgreSQL 9.6 架设mediawiki服务器

23240
来自专栏Golang语言社区

go-nsq使用简述

一 环境依赖:   golang 开发环境(version >= 1.2) 下源码,配置环境变量,执行安装脚本   gpm 依赖包管理...

50460
来自专栏云计算教程系列

如何在Ubuntu 14.04上的主代理安装程序中安装Puppet 4

来自Puppet Labs的Puppet是一种配置管理工具,可帮助系统管理员自动化服务器基础架构的配置,配置和管理。提前规划并使用Puppet等配置管理工具可以...

14230
来自专栏乐沙弥的世界

快速体验Percona XtraDB Cluster(PXC)

Percona XtraDB Cluster(简称PXC)集群是基于Galera 2.x library,事务型应用下的通用的多主同步复制插件,主要用于解决强一...

12720
来自专栏云计算教程系列

如何在CentOS 7上的主代理安装程序中安装Puppet 4

来自Puppet Labs的Puppet是一种配置管理工具,可帮助系统管理员自动化服务器基础架构的配置,配置和管理。提前规划并使用Puppet等配置管理工具可以...

13410
来自专栏zhisheng

RocketMQ 安装及快速入门

如果你对 RocketMQ 还没了解,建议先看下上一篇文章:RocketMQ 初探 安装条件 64位操作系统,建议使用 Linux / Unix / Mac; ...

454110
来自专栏浪淘沙

Kafka学习笔记

Apache Kafka 是分布式发布-订阅消息系统(消息中间件)。它最初由 LinkedIn 公司开发,之后成为 Apache 项目的一部分。Kafka ...

26730
来自专栏匠心独运的博客

消息中间件—RocketMQ消息消费(三)(消息消费重试)

摘要:如果Consumer端消费消息失败,那么RocketMQ是如何对失败的异常情况进行处理? 前面两篇RocketMQ消息消费(一)/(二)篇,主要从Pus...

47830

使用CoreOs,Docker和Nirmata部署微服务类型的应用

随着采用应用容器的持续增长,设计用于运行容器的“最小”操作系统正在普及。CoreOS就是这样的一个操作系统。CoreOs是为运行现代云原生应用,并为Docker...

314100

扫码关注云+社区

领取腾讯云代金券