preface
Recently, I encountered a problem that webpack hot reload failed because I was not familiar with nginx configuration and WebSocket protocol. Every time AFTER editing and saving, I had to actively refresh the web page.
Normally after creating a front-end project using create-react-app, run the project. If no changes are made to the default port configuration, the project will run at http://127.0.0.1:3000. However, in project debugging, we often want to access a specific domain name, such as http://www.test.com, emMM…
Since the project did not use eject to expose the relevant configuration of Webpack, it followed the official instructions in config-overrides. Js, but the partial coverage of dev-server did not take effect, so it was simple and rough, so nginx reverse proxy was used
The host configuration
Configure the domain name to be accessed to the local IP address
127.0.0.1 www.test.com
Copy the code
Nginx configuration
Related concepts:
The server block
- Configure virtual host parameters, one
Http
There can be more than oneserver
The location of
- Configure the routing of requests and the processing of various pages.
Nginx configuration:
server {
listen 80;
server_name www.test.com;
gzip on;
gzip_buffers 4 16k;
gzip_comp_level 5;
gzip_http_version 1.0;
gzip_min_length 1k;
gzip_types text/plain text/css application/javascript application/x-javascript text/xml application/xml application/xml+rss text/javascript image/x-icon image/bmp;
gzip_vary on;
location / {
proxy_pass http://127.0.0.1:3000;
proxy_set_header X-real-ip $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; }}Copy the code
When the domain name was accessed after reload was configured, hot reloading failed. Procedure
why
WebSocket connection ws://www.test.com/sockjs-nodeto failed… The WebSocket handshake failed and the file changes could not be obtained for loading replacement
After searching for information, it was found that the nginx configuration problem was not correctly configured and upgraded to WebSocket protocol. Compared with HTTP protocol, WebSocket protocol can communicate multiple times after a successful handshake until the connection is closed. But the handshake in WebSocket is compatible with the HANDSHAKE in HTTP, which uses the Upgrade protocol header in HTTP to Upgrade the connection from HTTP to WebSocket
Let’s change the location to
location / {
proxy_pass http://127.0.0.1:3000;
proxy_set_header X-real-ip $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "Upgrade";
}
Copy the code
In the browser to access the project, the hot reload takes effect
Increase knowledge
The most important thing is to add the following two lines to the reverse proxy configuration. The rest of the configuration is no different from that of a normal HTTP reverse proxy
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "Upgrade";
Copy the code
The key part of this is that the following headers are added to the HTTP request
Connection: Upgrade
Upgrade: websocket
Copy the code
The two fields indicate that the upgrade protocol of the request server is WebSocket, and the server responds to the following packets:
Status Code: 101 Switching Protocols
Connection: Upgrade
Upgrade: websocket
Copy the code
Tell the client that the protocol has been successfully switched to Websocket
Write in the last
Need to continue to consolidate HTTP knowledge, in addition to the use of Nginx time is not short, but the specific configuration inside, never to understand why such configuration. Proxy_set_header Host $Host; Proxy_pass failed to pass to the gateway address in nginx. Flag and resolve to go deep into nginx