我将应用程序部署到谷歌的App Engine服务,这是一个简单的Express.js服务器,提供使用Handlebars.js呈现的动态页面。一切都很好几个小时(它正在为页面提供服务)突然间它开始回答这个消息:
502 错误:服务器错误 服务器遇到临时错误,无法完成您的请求。 请在30秒后重试。
我尝试了以下所有方法来修复它:
即使新项目也以502回答。
我的想法:我认为Google的代理不是向该应用发送请求,因为它是Actualy正在侦听,但它不会记录请求。
以下是代码:
App.js:
'use strict';
const express = require('express');
const hbs = require('hbs');
const axios = require('axios');
const XLSX = require('xlsx');
const http = require('http');
const port = process.env.PORT || 8080;
const env = process.env.NODE_ENV || 'development';
let app = express();
let urls = {
url1: **Some url**,
url2: '**Some url2**'
};
app.set('view engine', 'hbs');
app.use(express.static('public'));
app.get('/page1', async (req, res)=>{
console.log('Page 1');
try{
let products = await getExcel(urls.url1);
res.render('page1.hbs', {
products: products,
});
}catch(err){
console.log(err);
res.status(500).send('Oops! found an Error.')
}
});
app.get('/page2', async (req, res)=>{
console.log('Page 2');
try{
let products = await getExcel(urls.url2);
res.render('page2.hbs', {
products: products,
});
}catch(err){
console.log(err);
res.status(500).send('Oops! found an Error.')
}
});
app.get('/', (req,res)=>{
console.log('Home');
res.render('smx-home.hbs',{});
});
const getExcel = async (url) =>{
**DO SOME STUFF HERE THAT RETURNS AN OBJECT OR AN ERROR**
}
app.listen(port, ()=>{
console.log(`${env} Server listening on port ${port}`);
});
的package.json:
{
"name": "suplementos",
"version": "1.0.0",
"description": "Suplementos Cajeme y SuplementosMX",
"main": "app.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1",
"start": "node app.js"
},
"author": "Wake",
"license": "ISC",
"dependencies": {
"axios": "^0.18.0",
"express": "^4.16.3",
"hbs": "^4.0.1",
"xlsx": "^0.12.13"
}
}
的app.yaml
runtime: nodejs
env: flex
automatic_scaling:
min_num_instances: 1
resources:
cpu: 1
memory_gb: 1
disk_size_gb: 10
我没有选择......关于可能出现什么问题的任何想法?
奇怪的是它在这个开始之前运行了几个小时,现在它只回答了502.
答案 0 :(得分:1)
需要在base处声明路由,返回http状态200。
注意声明路由的顺序。以免冒覆盖的风险。
示例:
app.get('/', function (req, res) {
res.status(200).send('Health Check');
});