节点 JS 发布请求导致 Heroku 严重错误请求超时 (503)

Posted

技术标签:

【中文标题】节点 JS 发布请求导致 Heroku 严重错误请求超时 (503)【英文标题】:Node JS Post Request Results in Heroku Critical Error Request Timeout (503) 【发布时间】:2018-01-03 16:39:58 【问题描述】:

背景:我有两个应用程序。一个是连接到 Mongo 数据库的 Express Node 应用程序。另一个是基本的 Web 应用程序,它通过 Fetch API 向 Node 应用程序发出 POST 请求,以从 Mongo 获取数据。

问题:发出POST 请求后,我在基本Web 应用程序的控制台中收到以下错误消息。但是,在我的 Heroku 控制台中,它指出 503 错误是 H12 - Request Timeout

Fetch 无法加载(节点应用网址)。请求的资源上不存在“Access-Control-Allow-Origin”标头。因此,不允许访问 Origin(基本 Web 应用程序 url)。响应的 HTTP 状态代码为 503。如果不透明的响应满足您的需求,请将请求的模式设置为“no-cors”以获取禁用 CORS 的资源。

POST 请求似乎确实有效,并且数据已保存到 Mongo 中,但此错误在 Heroku 中被标记为“严重错误”,非常烦人。

Express 节点应用代码

在我的app.js 文件中,我设置了正确的标头,以确保其他应用程序可以发出来自不同来源的请求

app.js

// Add headers so we can make API requests
app.use(function (req, res, next) 
    res.setHeader('Access-Control-Allow-Origin', '*');
    res.setHeader('Access-Control-Allow-Methods', 'GET, POST, OPTIONS, PUT, PATCH, DELETE');
    res.setHeader('Access-Control-Allow-Headers', 'X-Requested-With,content-type');
    res.setHeader('Access-Control-Allow-Credentials', true);
    next();
);

routes/api/api.js

router.post('/users/:url/upload-csv/:csv_name', (req, res) => 
  let csv_name = req.params.csv_name;
  let csv_string = csv_name+req.body.csv_string;

  User.findOne(url: req.params.url)
    .then((user) => 
      if (user.csv_files.length === 0) 
        user.csv_files.push(csv_string);
       else 
        let foundExistingCSV = false;
        for (var i = 0; i < user.csv_files.length; i++) 
          if (user.csv_files[i].includes(csv_name)) 
            foundExistingCSV  = true;
            user.csv_files[i] = csv_string;
            break;
          
        
        if (!foundExistingCSV) user.csv_files.push(csv_string);
      
      user.markModified('csv_files');
      user.save();

      res.status(204);
    )
    .catch((err) => 
      console.log(err);
      res.status(400);
    );
);

基本网络应用代码

POST 我提出的请求

utils.js

utils.exportToMongo = functions(table, name) 
  var exportPlugin = table.getPlugin('exportFile');
  var csv_string   = exportPlugin.exportAsString('csv');

  // Upload the CSV string and its name to Users DB
  fetch(`$utils.fetchUserURL()/upload-csv/$name`, 
    method: 'POST',
    body: JSON.stringify(csv_string: csv_string),
    headers: new Headers(
      'Content-Type': 'application/json',
      Accept: 'application/json',
    )
  ).then((res) => 
    return ;
  ).catch((error) => 
    console.log(error);
    return ;
  );

如何消除503 错误?似乎我可能需要在我的 Express 应用程序中添加一些内容到我的 POST 请求中以处理请求超时。有任何想法吗?谢谢!

【问题讨论】:

【参考方案1】:

您可以尝试添加return 并像这样使用将status 更改为sendStatus 吗?

router.post('/users/:url/upload-csv/:csv_name', (req, res) => 
  let csv_name = req.params.csv_name;
  let csv_string = csv_name+req.body.csv_string;

  return User.findOne(url: req.params.url)
    .then((user) => 
      if (user.csv_files.length === 0) 
        user.csv_files.push(csv_string);
       else 
        let foundExistingCSV = false;
        for (var i = 0; i < user.csv_files.length; i++) 
          if (user.csv_files[i].includes(csv_name)) 
            foundExistingCSV  = true;
            user.csv_files[i] = csv_string;
            break;
          
        
        if (!foundExistingCSV) user.csv_files.push(csv_string);
      
      user.markModified('csv_files');
      user.save();

      return res.sendStatus(204);
    )
    .catch((err) => 
      console.log(err);
      return res.sendStatus(400);
    );
);

【讨论】:

感谢您的建议。我确实添加了return,但我仍然遇到同样的错误。 您也可以尝试将status 更改为sendStatus。我更新了上面的代码。

以上是关于节点 JS 发布请求导致 Heroku 严重错误请求超时 (503)的主要内容,如果未能解决你的问题,请参考以下文章

是啥导致了这个 Heroku mysql 连接错误? (尝试将前端连接到后端 POST 请求)

在 Heroku 上部署 node.js 应用程序(discord.jd bot)导致错误

使用Rack :: Deflator添加GZIP会导致Heroku上的“客户端请求中断”错误

Heroku 和 Socket.io,400 个错误请求和许多断开连接

使用 db.query 方法 node.js 时出现 Heroku H12“请求超时”错误

Heroku 错误:页面是通过 HTTPS 加载的,但请求了一个不安全的脚本“angular-route.js”