我正在为客户开发一个项目,我需要使用webpack的热模块替换功能。我正在使用NGINX背后的快速(节点)应用程序。我正在使用许多javascript框架来设计应用程序,React恰好是其中之一。
我将使用HMR功能。
我有这样的webpack.config.js:
var webpack = require('webpack');
var ExtractTextPlugin = require("extract-text-webpack-plugin");
var merge = require('webpack-merge');
var validate = require('webpack-validator');
var CleanWebpackPlugin = require('clean-webpack-plugin');
var styleLintPlugin = require('stylelint-webpack-plugin');
//breaking up into smaller modules
//commons module
//first
var start = {
context : __dirname ,
//entry point defination
entry : {
app : ['./require.js','webpack-hot-middleware/client?https:127.0.0.1:8195'],
vendor : ['angular','angular-animate','angular-messages','angular-aria','angular-route','angular-material','react','react-dom',''webpack-hot-middleware/client?https:127.0.0.1:8195'']
},
//output defination
output : {
path : './public/dist',
publicPath: 'https://127.0.0.1:8195/public/dist/',
filename : 'app.bundle.js'
},
module: { preLoaders: [
{
test: /\.(js|jsx)$/,
exclude: /(node_modules|bower_components)/,
loaders: ['eslint']
}
],
loaders: [
{test: /\.js$/, loader: 'ng-annotate!babel?presets[]=es2015!jshint', exclude: /node_modules/},
{
test: /\.css$/,
exclude: /(node_modules|bower_components)/,
loader: ExtractTextPlugin.extract("style-loader", "css")
},
{
test: /\.less$/,
exclude: /(node_modules|bower_components)/,
loader: ExtractTextPlugin.extract("style", "css!less")
},
{
test: /\.scss$/,
exclude: /(node_modules|bower_components)/,
loader: ExtractTextPlugin.extract("style", "css!sass")
},
{
test: /\.jsx?$/,
exclude: /(node_modules|bower_components)/,
loaders: ['react-hot', 'babel'],
},
{
test: /\.woff2$/,
loader: 'url'
}
]
},
plugins: [
new webpack.optimize.CommonsChunkPlugin(/* chunkName= */"vendor", /* filename= */"vendor.bundle.js"),
new webpack.DefinePlugin({
"process.env": {
NODE_ENV: JSON.stringify("production")
}
}),
new ExtractTextPlugin("styling.css", {allChunks: true}),
new ExtractTextPlugin("styling.css", {allChunks: true}),
new ExtractTextPlugin("styling.css", {allChunks: true}),
//new webpack.optimize.UglifyJsPlugin({
//compress: {
// warnings: false
// },
//}),
// new webpack.optimize.DedupePlugin(),
// new webpack.optimize.OccurrenceOrderPlugin(),
new webpack.HotModuleReplacementPlugin(),
new webpack.NoErrorsPlugin()
],
//target: 'web'
};
var config;
// Detect how npm is run and branch based on that
//choose modules
//all modules
switch(process.env.npm_lifecycle_event) {
case 'build':
config = merge(start);
break;
default:
config = merge(start);
}
//export config
module.exports = validate(config);
我的app.js文件包含:
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'ejs');
//webpack development server integration
app.use(require("webpack-dev-middleware")(compiler, {
noInfo: false, stats: { colors: true,
chunks: true,
'errors-only': true }, headers: { "X-Custom-Header": "yes" }, publicPath: webpackConfig.output.publicPath
}));
app.use(require("webpack-hot-middleware")(compiler, {
log: console.log
}));
我的NGINX文件包含
location / {
...
proxy_pass https://127.0.0.1:8195;
...
...
}
当我打开https://127.0.0.1:8195时。然后创建并提供文件。 Express在8195端口上侦听。 但是当我打开https://domain-name.com时,文件没有提供,但NGINX没有显示502错误。
答案 0 :(得分:1)
确实是。需要一些配置来适应HMR使用的WebSocket。
这是您可以使用的示例配置。
nginx:
location /my-path {
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_http_version 1.1;
proxy_set_header Connection $http_connection;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Sec-WebSocket-Extensions $http_sec_websocket_extensions;
proxy_set_header Sec-WebSocket-Key $http_sec_websocket_key;
proxy_set_header Sec-WebSocket-Version $http_sec_websocket_version;
proxy_cache_bypass $http_upgrade;
proxy_read_timeout 900;
client_max_body_size 0;
proxy_buffering off;
add_header X-Accel-Buffering no;
proxy_pass http://my-internal-server;
}
webpack.config.js:
const webpack = require('webpack')
module.exports = {
mode: mode,
entry: {
main: [
`webpack-hot-middleware/client?path=__webpack__/__webpack_hmr&timeout=20000`,
'app/main.js')
]
},
devServer: {
hot: true
},
plugins: [
new webpack.HotModuleReplacementPlugin()
]
}
答案 1 :(得分:0)
我自己走了一条类似的路线,最终为我的设置弄清楚了。我在这里杂乱地记录了它:https://vcavallo.github.io/how_to/webpack/vps/front_end/2018/06/27/remote-dev-machine-webpack-dev-server-nginx.html#the-solution
这是我的笔记和各种配置文件的要旨的直接链接:https://gist.github.com/vcavallo/4f11985c4364bc4edfdf56556bff4ccf