一开始,我创建了一个带有反应前端(使用 webpack)的节点应用程序。在一个子文件夹中,我创建了一个节点和反应聊天应用程序,它使用 socket-io 进行实时协作。这个聊天应用也有自己的 package.json 和 webpack.config.js 文件。
文件结构如下:
root
- package.json
- webpack.config.js
- server
- client
- database
- chat_folder
-- package.json
-- webpack.config.js
-- client
-- server
我决定采用这种架构,将聊天服务器与应用程序的其余部分分开,但保留对共享数据库的访问权限。
将这样的架构应用部署到 Heroku 的最佳方式是什么?
我最初的想法是“移动”或将聊天应用程序的 package.json 文件合并到根文件夹的 package.json 中?以某种方式添加到 package.json 的启动脚本以启动聊天服务器。我不确定如何从脚本启动 2 个服务器。我也不确定如何更改 2 个 webpack.config 文件或者是否有必要。还是我需要部署 2 个单独的应用程序?还是2个独立的测功机?
主文件夹中 package.json 文件中的启动脚本:
"start": "node server/index.js"
主文件夹中 package.json 文件中的启动脚本:
"start": "node server/index.js",
两个文件夹中的 webpack.config.js 文件看起来一样:
var path = require('path');
var SRC_DIR = path.join(__dirname, '/client/src');
var DIST_DIR = path.join(__dirname, '/client/dist');
module.exports = {
entry: `${SRC_DIR}/index.jsx`,
output: {
filename: 'bundle.js',
path: DIST_DIR
},
module : {
loaders : [
{
test : /\.jsx?/,
include : SRC_DIR,
loader : 'babel-loader',
query: {
presets: ['react', 'es2015', 'env']
}
}
]
}
};