Electron:Express.js服务器在Mongo DB准备就绪之前查询

时间:2016-05-08 16:04:38

标签: javascript node.js mongodb express electron

我构建的演示应用使用 Express 来提供由 MongoDB 实例浇灌的一些 React 代码在 mLab 上运行并在我的主要React代码中通过SuperAgent调用检索(通过 index.html 加载)。

启动服务器并在浏览器中查看效果很好,我尝试使用Electron创建桌面版本,并且在默认情况下遇到初始数据库查询问题(' /' )GET路线。

简而言之,使用Superagent,我的应用会尝试在数据库连接之前到达数据库,并且第一个查询返回空白。如果我刷新页面,一切都在那里,所以它最终是连接的,只是因为移动到电子后时间有所改变。

自从我搬到电子公司以来,这是我的快递服务器:

const electron = require('electron');
const app = require('app');
const BrowserWindow = require('browser-window');

const express = require('express'),
    db = require('./model/db'),
    bodyParser = require('body-parser'),
    http = require('http'),
    path = require('path');

const expressApp = express();

// Keep a global reference of the window object, if you don't, the window will
// be closed automatically when the JavaScript object is garbage collected.
var mainWindow = null;

// Quit when all windows are closed.
app.on('window-all-closed', function() {
  // On OS X it is common for applications and their menu bar
  // to stay active until the user quits explicitly with Cmd + Q
  if (process.platform != 'darwin') {
    app.quit();
  }
});

function onListening() {
  mainWindow.loadURL('http://127.0.0.1:3000');
  //mainWindow.toggleDevTools();
}

// This method will be called when Electron has finished
// initialization and is ready to create browser windows.
app.on('ready', function() {
  // Create the browser window.
  mainWindow = new BrowserWindow({width: 800, height: 600});

    expressApp.set('port', process.env.PORT || 3000);

    expressApp.use(bodyParser.json());
    expressApp.use(bodyParser.urlencoded({ extended: true }));
    expressApp.use(express.static(path.join(__dirname, './')));

    expressApp.get('/', function(req, res) {
      res.render('index');
    });

    expressApp.get('/tasks/all', db.readAllTasks);
    expressApp.post('/tasks/createTask', db.createTask);
    expressApp.delete('/tasks/deleteTask/:id', db.deleteTask);
    expressApp.put('/tasks/updateTask/:id', db.updateTask);

    server = http.createServer(expressApp);
    server.listen(expressApp.get('port'), function(){console.log("Listenning!")});
    server.on('listening', onListening);

  // Emitted when the window is closed.
  mainWindow.on('closed', function() {
    mainWindow = null;
  });
});

在此之前服务器看起来像:

var express = require('express');
var db = require('./model/db');
var bodyParser = require('body-parser');
var http = require('http');
var path = require('path');

var app = express();

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

app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: true }));
app.use(express.static(path.join(__dirname, './')));

app.get('/', function(req, res) {
  res.render('index');
});

app.get('/tasks/all', db.readAllTasks);
app.post('/tasks/createTask', db.createTask);
app.delete('/tasks/deleteTask/:id', db.deleteTask);
app.put('/tasks/updateTask/:id', db.updateTask);

http.createServer(app).listen(app.get('port'), function(){
  console.log("Express server listening on port " + app.get('port'));
});

我想的可能,我需要做的就是将我的res.render转移到某种回调中?

或者,我的db.js中的某些内容可能需要更改。这是一个简短的版本:

var Task = mongoose.model( 'Task', taskSchema );
mongoose.connect( '<connection string>' );

var db = mongoose.connection;

db.on('error', console.error.bind(console, 'connection error:'));
db.once('open', function(){
  console.log('Connected to mongoDB');
});

var allTasks = db.collection('tasks');

function readAllTasks(req, res) {
  var holster = []
  allTasks.find({}).forEach(function(doc){
    holster.push(doc);    
    }, function(){
        res.send(holster);
    });
}
exports.readAllTasks = readAllTasks;

我得到的错误说allTask​​s是未定义的,然后就在那个错误之后我得到了#34;连接到mongoDB&#34;登录到控制台,然后如果我刷新我可以从数据库中获取数据没问题。

感谢您的期待!

2 个答案:

答案 0 :(得分:0)

可能是本机答案,但我找到了一个名为wait-for-mongo的小js文件,可以让您快速解决问题。根据他们的文档,您可以像这样包装您的res.render:

var waitForMongo = require('wait-for-mongo');

waitForMongo('<connection string>', {timeout: 1000 * 60* 2}, function(err) {
  if(err) {
    console.log('timeout exceeded');
  } else {
   console.log('mongodb comes online');
   res.render();
 }
});

答案 1 :(得分:0)

如此简单,我所要做的只是提升数据库的require语句。

const electron = require('electron');
const app = require('app');
const BrowserWindow = require('browser-window');
const db = require('./model/db')

const express = require('express'),
    bodyParser = require('body-parser'),
    http = require('http'),
    path = require('path');

const expressApp = express();

我的控制台报告它正在收听,然后它告诉我它连接到数据库,但无论如何数据都加载到第一页加载。 有点奇怪。我认为更好的解决方案是只在启动数据库时启动服务器监听,但这现在可以正常工作。