$ npm install start-server-webpack-pluginAutomatically start your server once Webpack's build completes + handle hot reloading (HMR)
$ npm install --save-dev start-server-webpack-plugin
In webpack.config.server.babel.js:
import StartServerPlugin from "start-server-webpack-plugin";
export default {
...
plugins: [
...
// Only use this in DEVELOPMENT
new StartServerPlugin({
// name of the entry to run, defaults to 'main'
entryName: 'server',
// any arguments to nodejs when running the entry, this one allows debugging
nodeArgs: ['--inspect-brk'],
// any arguments to pass to the script
args: ['scriptArgument1', 'scriptArgument2'],
// Allow typing 'rs' to restart the server. default: only if NODE_ENV is 'development'
restartable: true | false,
// Only run the server once (default: false)
once: false | true,
}),
...
],
...
}
The entryName argument defaults to "main", which is the name Webpack uses if you use the string or array versions of the entry option.
You can use nodeArgs and args to pass arguments to node and your script, respectively. For example, you can use this to use the node debugger.
To use Hot Module Reloading with your server code, set Webpack to "hot" and "watch" modes.
This plugin appends some code to the end of the entry so that it can handle HMR and restarts; no need to add any of the webpack/hot modules.
name option and define entryName if it's not just "main"MIT License 2016-2018 © Eric Clemmons