簡體   English   中英

Express Generator-TypeError:app.set不是函數

[英]Express Generator - TypeError: app.set is not a function

我首先自己創建了一個具有Node / Express的API,以學習從“天真的”方式到大多數程序員的方式。 它運行良好,因此我決定嘗試Express-Generator。

設置完所有內容后,應用程序即可正常運行。

我添加了我的一堆代碼(主要是在app.js中,並導入了一些嘗試路徑),但在設置express的bin / www中,我沒有做任何更改。

但是在啟動時,我得到了指向此特別是bin / www文件的錯誤:

app.set('port', port);
    ^

TypeError: app.set is not a function

我不知道為什么自動生成的這部分代碼現在不想工作。

這里是兩個主體文件

bin / www :(生成后未更改)

#!/usr/bin/env node

/**
 * Module dependencies.
 */

var app = require('../app');
var debug = require('debug')('API:server');
var http = require('http');

/**
 * Get port from environment and store in Express.
 */

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

/**
 * Create HTTP server.
 */

var server = http.createServer(app);

/**
 * Listen on provided port, on all network interfaces.
 */

server.listen(port);
server.on('error', onError);
server.on('listening', onListening);

/**
 * Normalize a port into a number, string, or false.
 */

function normalizePort(val) {
  var port = parseInt(val, 10);

  if (isNaN(port)) {
    // named pipe
    return val;
  }

  if (port >= 0) {
    // port number
    return port;
  }

  return false;
}

/**
 * Event listener for HTTP server "error" event.
 */

function onError(error) {
  if (error.syscall !== 'listen') {
    throw error;
  }

  var bind = typeof port === 'string'
    ? 'Pipe ' + port
    : 'Port ' + port;

  // handle specific listen errors with friendly messages
  switch (error.code) {
    case 'EACCES':
      console.error(bind + ' requires elevated privileges');
      process.exit(1);
      break;
    case 'EADDRINUSE':
      console.error(bind + ' is already in use');
      process.exit(1);
      break;
    default:
      throw error;
  }
}

/**
 * Event listener for HTTP server "listening" event.
 */

function onListening() {
  var addr = server.address();
  var bind = typeof addr === 'string'
    ? 'pipe ' + addr
    : 'port ' + addr.port;
  debug('Listening on ' + bind);
}

app.js:

// Module dependencies
const express = require('express');
const cluster = require('express-cluster'); // fork the service on different thread
const helmet = require('helmet'); // Secure HTTP header
const cors = require('cors');
const path = require('path');
const bodyParser = require('body-parser'); // Help to easily parse the body of req/res
const port = process.env.PORT || 3000;
const mongoose = require('mongoose'); // Manage MongoDB request

cluster(function(worker) {
  var app = express();

  // MongoDB config
  const config = require('./misc/config/index'); // Config variable like MongoDB credential
  mongoose.Promise = global.Promise;
  mongoose.connect(config.getDBConnectionString()); // Config to cnx to mongodb
  // mongoose.connect(config.getDBConnectionString(), { config: { autoIndex: false } });

  // Middleware
  app.use(bodyParser.json());
  app.use(bodyParser.urlencoded({extended: true}));
  app.use(helmet.frameguard()); // Default Value - Help to secure request by putting some setting in the header
  app.use(cors()); // Handling Cross Origin Ressource Sharing

  // Logfile
  const log = require('./misc/log/log');
  app.use(log);

  // Config Landingpage to /
  app.use('/assets', express.static(path.join(__dirname, 'public')));
  app.set('view engine', 'ejs');

  // Entry point
  const entryPoint = require('./routes/entryPoint');
  app.get('/', entryPoint.index);
  app.get('/api', function (req, res) {
    res.redirect(301, '/');
  })

  // API Key handler
  const auth = require('./misc/auth/auth');
  app.use(auth);

  // List
  const list = require('./routes/list/listRouter'); // Get List endpoints
  // app.use('/api/list', list);

  // Map
  const map = require('./routes/map/mapRouter'); // Get List endpoints
  // app.use('/api/map', map);

  module.exports = app;
}, {count: 2})

我導出包含express()的應用程序。 因此,這里有些我想念的東西,但我看不到。

該問題是由以下設置引起的:

cluster(function(worker) {
  var app = express();
  ...
  module.exports = app;
}, { ... });

由於cluster將異步調用“工作者函數”,因此導出也將異步完成,對於bin/www來說為時已晚。 除此之外,worker函數將在單獨的進程中運行,這也使事情變得復雜。

因為bin/www功能相對簡單,所以您可以選擇將其內容(或至少要執行的內容)移動到app.js ,並從node app.js啟動您的應用程序。 您甚至可以用一個簡單的腳本替換bin/www

#!/usr/bin/env node 

require('../app');

另外,您可以按原樣保留代碼,並依靠外部程序在可用CPU之間提供負載平衡。 流行的解決方案是pm2 ,盡管它並不是對所有人都適用(似乎有些失誤)。

如果需要傳遞環境變量,則可以從命令行進行傳遞:

$ env API_KEY=XXX pm2 start app.js

或為您的應用創建配置文件

還有一個名為dotenv的軟件包,它將允許您的Node應用程序直接從文件讀取環境變量。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM