gpt4 book ai didi

node.js - 无法连接错误 - Linux 服务器上的 Node Express 应用程序

转载 作者:太空宇宙 更新时间:2023-11-04 11:45:55 24 4
gpt4 key购买 nike

尝试连接到我的 Node Express 应用程序时,我在浏览器中收到“无法连接”错误。在(我的服务器 ip 地址)1.1.1.1:5000。该应用程序在我的开发环境中运行良好,但在我的 AWS EC2 Linux 服务器上运行不正常。

  • Node Express 应用程序在我的开发计算机上运行
  • 端口 5000 允许传入 TCP。我用一个较小的应用程序 ( https://hackernoon.com/deploying-a-node-app-on-amazon-ec2-d2fb9a6757eb ) 测试并确认了这一点。
  • 我确认我的 Node Express 应用程序正在运行。 (我用的是pm2)
  • PM2 持续在 14 秒左右重启我的 Node Express 应用
  • 我试图从我的机器 curl 到端口 5000,我收到一个连接被拒绝的错误 curl: (7) Failed to connect to 1.1.1.1 port 5000: Connection refused

更新

  • 我没有使用 pm2 start app.js 启动应用程序,而是使用 npm start 启动它,并且我的应用程序成功托管在端口 5000。
  • 我可以转到 1.1.1.1:5000 并返回 API 正在运行
  • 我使用 js fetch api 在 127.0.0.1:5000 调用后端并收到 Cross-Origin Request Blocked: The Same Origin Policy disallows reading the remote resource at http://127.0.0.1:5000/pickTicket/21780482。 (原因:CORS请求没有成功)。
    2个
    类型错误:尝试获取资源时出现网络错误。
    (*注意:我的 api 与我的 nginx/react 应用程序位于同一服务器上)`

我的应用程序以 app.js 开头

var createError = require('http-errors');
var express = require('express');
var path = require('path');
var cookieParser = require('cookie-parser');
var logger = require('morgan');
var cors = require('cors');
var compression = require('compression');
var fetch = require('node-fetch');

var pickTicketRouter = require('./routes/pickTicket');
var kdlRouter = require('./routes/kdl')

console.log('Creating API')
var app = express();
app.use(cors());
app.options('*', cors());

// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'jade');

app.use(compression());
app.use(logger('dev'));
app.use(express.json());
app.use(express.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));

app.get('/', (req, res) => {
res.statusCode = 200;
res.setHeader('Content-Type', 'text/plain');
res.end('API is running\n');
});

app.use('/pickTicket', pickTicketRouter);
app.use('/kdl', kdlRouter)

// catch 404 and forward to error handler
app.use(function(req, res, next) {
next(createError(404));
});

// error handler
app.use(function(err, req, res, next) {
// set locals, only providing error in development
res.locals.message = err.message;
res.locals.error = req.app.get('env') === 'development' ? err : {};

// render the error page
res.status(err.status || 500);
res.render('error');
});

module.exports = app;

/斌/万维网

#!/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 || '5000');
console.log('Listening on port: ', port);
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);
}

包.json

{
"name": "api",
"version": "0.0.0",
"private": true,
"scripts": {
"start": "node ./bin/www",
"dev": "nodemon ./bin/www"
},
"dependencies": {
"compression": "^1.7.4",
"cookie-parser": "~1.4.4",
"cors": "^2.8.5",
"debug": "~2.6.9",
"express": "~4.16.1",
"forever": "^1.0.0",
"http-errors": "~1.6.3",
"jade": "~1.11.0",
"morgan": "~1.9.1",
"mssql": "^5.1.0",
"node-fetch": "^2.6.0",
"sequelize": "^5.11.0",
"tedious": "^6.2.0"
},
"devDependencies": {
"nodemon": "^1.19.1"
}
}

我希望看到来自 api 的响应,但却收到了 CORS 错误。

最佳答案

我有几个关于不同环境的问题。您的开发环境是否托管在 AWS 中?如果没有,我会查看 AWS 安全组以确保为您的应用程序使用正确的 TCP 协议(protocol)。

此外,您是将此 EC2 部署到默认 VPC 中还是创建了自己的 VPC?如果您创建了 VPC,则可能是路由问题或网络级别问题。

关于node.js - 无法连接错误 - Linux 服务器上的 Node Express 应用程序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57790823/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com