【问题标题】:Heroku: How to deploy a node app with client and server running on different ports?Heroku:如何部署一个节点应用程序,客户端和服务器在不同的端口上运行?
【发布时间】:2018-02-10 09:02:11
【问题描述】:

我有一个 nodejs API 作为服务器,React/Redux 应用作为客户端,位于一个 git 项目中:https://github.com/lafisrap/fcc_nightlife.git

我想使用 heroku cli 在 Heroku 上部署它。

package.json 中的 scripts 部分是:

  "scripts": {
    "start-dev": "concurrently \"yarn run server\" \"yarn run client\"",
    "start": "yarn run server | yarn run client",
    "server": "babel-node server.js",
    "client": "node start-client.js",
    "lint": "eslint ."
  },

start-client.js:

const args = [ 'start' ];
const opts = { stdio: 'inherit', cwd: 'client', shell: true };
require('child_process').spawn('yarn', args, opts);

在客户端文件夹中,我有另一个 package.json 定义了客户端。它的脚本部分:

  "scripts": {
    "start": "react-scripts start",
  }

我做到了:

heroku 创建
git push heroku 大师

API 运行良好。但我不知道如何启动/访问客户端。

【问题讨论】:

    标签: node.js heroku deployment server client


    【解决方案1】:

    不能在一个 Heroku 应用中部署两项服务。简而言之,您必须将它们部署到单独的 Heroku dynos 以部署两个应用程序。

    this stackoverflow answer 为类似问题提供了更多信息。

    PS:在构建 React 文件后,始终可以选择从 API 服务器提供 JS 文件。

    希望这会有所帮助!

    【讨论】:

    • 这不是真的,看我下面的回答stackoverflow.com/a/54059054/711672
    • @MarkJackson 构建反应应用程序并将其用作静态字段始终是一种选择。不确定这是否使我的回答不真实。无论如何我都会更新它以呈现更大的画面。
    【解决方案2】:

    此 repo 显示了 Node.js 的设置,该设置为在单个 Heroku dyno 上运行的 React 前端提供服务:https://github.com/mars/heroku-cra-node 我能够以此为指导启动并运行一个。

    【讨论】:

      【解决方案3】:

      实际上你一定不想在不同的端口上运行。因为cors和其他问题。在 nodejs 中实现代理或将 nginx 实现为服务器和客户端请求的网关。

      【讨论】:

        猜你喜欢
        • 2020-08-22
        • 1970-01-01
        • 2023-04-04
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2018-12-28
        • 2015-05-27
        相关资源
        最近更新 更多