在Heroku上部署Node.js,express,knex app - 未处理的拒绝错误:池被销毁

时间:2017-06-25 08:05:59

标签: javascript node.js heroku knex.js

超级大菜这里只在4周前开始编码,所以如果这个问题非常无知,我会道歉。

我正在Heroku上部署这个小node.js express和knex web应用程序。一切都在当地运行良好。我已经从命令行成功创建了应用程序,并且所有页面都呈现了。我已经在Heroku上创建了PostgreSQL数据库,并且我已经成功执行了迁移,因此我的表都已设置完毕。但是,当我尝试提交一个表单(假设将数据插入数据库)时,我在日志中不断收到以下错误:

  

2017-06-25T06:01:57.360120 + 00:00 app [web.1]:未处理拒绝错误:池被销毁2017-06-25T06:01:57.360123 + 00:00 app [web.1]:在Pool.acquire(/app/node_modules/pool2/lib/pool.js:162:12)2017-06-25T06:01:57.360124 + 00:00 app [web.1]:at / app / node_modules / knex / lib / client.js:268:29 2017-06-25T06:01:57.360125 + 00:00 app [web.1]:at Promise._execute(/app/node_modules/bluebird/js/release/debuggability.js:300 :9)2017-06-25T06:01:57.360125 + 00:00 app [web.1]:在Promise._resolveFromExecutor(/app/node_modules/bluebird/js/release/promise.js:483:18)2017-06 -25T06:01:57.360126 + 00:00 app [web.1]:at new Promise(/app/node_modules/bluebird/js/release/promise.js:79:10)2017-06-25T06:01:57.360127+ 00:00 app [web.1]:at Client.acquireConnection(/app/node_modules/knex/lib/client.js:264:21)2017-06-25T06:01:57.360131 + 00:00 app [web.1 ]:at /app/node_modules/knex/lib/runner.js:188:47 2017-06-25T06:01:57.360132 + 00:00 app [web.1]:在Promise._execute(/ app / node_modules / bluebird) / JS /发行/调试性。 js:300:9)2017-06-25T06:01:57.360134 + 00:00 app [web.1]:在/app/node_modules/knex/lib/runner.js:187:35 2017-06-25T06:01 :57.360133 + 00:00 app [web.1]:at new Promise(/app/node_modules/bluebird/js/release/promise.js:79:10)2017-06-25T06:01:57.360135 + 00:00 app [web.1]:在Function.Promise.attempt.Promise.try(/app/node_modules/bluebird/js/release/method.js:39:29)2017-06-25T06:01:57.360132 + 00:00 app [web.1]:在Promise._resolveFromExecutor(/app/node_modules/bluebird/js/release/promise.js:483:18)2017-06-25T06:01:57.360134 + 00:00 app [web.1]:在tryCatcher(/app/node_modules/bluebird/js/release/util.js:16:23)2017-06-25T06:01:57.360136 + 00:00 app [web.1]:at Runner.run(/ app / node_modules / knex / lib / runner.js:41:44)2017-06-25T06:01:57.360136 + 00:00 app [web.1]:在Runner.ensureConnection(/ app / node_modules / knex / lib / runner。 js:186:39)2017-06-25T06:01:57.360137 + 00:00 app [web.1]:在QueryBuilder.Target.then(/app/node_modules/knex/lib/interface.js:32:43)

我已经浏览了Heroku上的教程,并阅读了他们的节点文档。我没有设置Procfile,因为我从阅读中理解它没有必要。

这是我的Knex配置:

  production: {
    client: 'pg',
    connection: process.env.DATABASE_URL + '?ssl=true',
    debug: true,
    pool: {
      min: 2,
      max: 10
    },
    migrations: {
      directory: './db/migrations',
      tableName: 'migrations'
    }
  }

这是我的server.js:

"use strict";

if (process.env.NODE_ENV !== 'production') require('dotenv').config();

const PORT        = process.env.PORT || 8080;
const ENV         = process.env.ENV || "development";
const express     = require("express");
const bodyParser  = require("body-parser");
const sass        = require("node-sass-middleware");
const app         = express();
var pg = require('pg');


const knexConfig  = require("./knexfile");
const knex        = require("knex")(knexConfig[ENV]);
const morgan      = require('morgan');
const knexLogger  = require('knex-logger');

// Seperated Routes for each Resource
const pollRoutes  = require("./routes/poll");
const voteRoutes  = require("./routes/vote");
const administrativeRoutes = require("./routes/administrative");
const dbHelper    = require("./lib/dbHelper")(knex);


app.use(morgan('dev'));

app.use(knexLogger(knex));

app.set("view engine", "ejs");
app.use(bodyParser.urlencoded({ extended: true }));
app.use("/styles", sass({
  src: __dirname + "/styles",
  dest: __dirname + "/public/styles",
  debug: true,
  outputStyle: 'expanded'
}));
app.use(express.static("public"));


app.get("/", (req, res) => {
  res.redirect("/create");
});
app.get("/error", (req, res) => {
  res.render('error');
});

// Mount all resource routes
app.use("/create", pollRoutes(dbHelper, process.env));
app.use("/vote", voteRoutes(dbHelper, process.env));
app.use("/administrative", administrativeRoutes(dbHelper));

// Home page

app.listen(PORT, () => {
  console.log("Example app listening on port " + PORT);
});

再次,非常感谢任何帮助。在我开始学习这些东西之前,我曾经以插图画家的身份工作,我很乐意为谁帮助我解决这个问题画一幅肖像< 3

1 个答案:

答案 0 :(得分:1)

您的const ENV = process.env.ENV || "development";正在不断解决"开发,"当你推向生产时,这将是未定义的。这是因为您置于server.js之上的条件语句。

将其更改为:

const ENV = process.env.NODE_ENV || 'development'

您可以console.log knexENV常量进行调试。