Home Operation and Maintenance Nginx How to configure GZip compression when a Node.js site uses Nginx as a reverse proxy

How to configure GZip compression when a Node.js site uses Nginx as a reverse proxy

May 25, 2023 pm 07:13 PM
node.js nginx gzip

Node.js developed site, if you also use nginx to implement reverse proxy.

Then you can easily implement gzip compression on the server side to make site browsing smoother.

Prerequisite Conditions: node.js nginx reverse proxy.

node.js Work to be done:

express versions below 4.0:

app.use(express.compress()); //主要是这句
app.use(express.json()); 
app.use(express.urlencoded()); 
app.use(express.bodyparser()); 
app.use(express.methodoverride()); 
app.use(express.cookieparser());
Copy after login

In order to compress all requests, compress Put it on top.

express 4.0 and above (including 4.0)

var compress = require('compression');
app.use(compress());
Copy after login

4.0 and above versions take out the middleware independently.

So you first need to rquire('compression ')

Click here to view the main differences between express 3.5 and express 4.0

Node.js The work that needs to be done is that simple.

nginx The work that needs to be done:

Open the nginx configuration file, modify the configuration, and turn on the gzip switch

nano /usr/local/nginx/conf/nginx.conf
Copy after login

The nginx on your own server may not be installed in the /usr/local/ directory, so look for the configuration file nginx according to your own installation directory .conf

Add the following configuration to the http configuration node:

gzip on;
    gzip_min_length 1k;
    gzip_buffers   4 16k;
    gzip_http_version 1.0;
    gzip_comp_level 2;
    gzip_types    text/plain application/x-javascript text/css application/xml;
    gzip_vary on;

http (
    //放上面配置节点  
)
Copy after login

What does each configuration item mean?

1) gzip

Syntax: gzip on/off

Default value: off

Scope: http, server, location

Description: Turn on or off the gzip module, use on here to indicate startup

2) gzip_min_length

Syntax: gzip_min_length length

Default value: gzip_min_length 0

Scope: http, server, location

Description: Settings The minimum number of bytes of the page that is allowed to be compressed. The number of bytes of the page is obtained from the content-length in the header. The default value is 0, which compresses the page regardless of its size. It is recommended to set the number of bytes to be greater than 1k. If it is less than 1k, it may become more and more compressed. |

3) gzip_buffers

Syntax: gzip_buffers number size

Default value: gzip_buffers 4 4k/8k

Scope: http, server, location

Description: Set the system to obtain several units of cache for storing the gzip compression result data stream. 4 16k means to apply for memory in units of 16k and 4 times the original data size in units of 16k.

4) gzip_comp_level

Syntax: gzip_comp_level 1..9

Default value: gzip_comp_level 1

Scope: http, server, location

Description: gzip compression ratio, 1 has the smallest compression ratio and the fastest processing speed, 9 has the largest compression ratio but the slowest processing (fast transmission but consumes more CPU). Here it is set to 5.

5) gzip_types

Syntax: gzip_types mime-type [mime-type ...]

Default value: gzip_types text/html

Scope : http, server, location

Description: Match the mime type for compression, (whether specified or not) the "text/html" type will always be compressed. This is set to application/x-javascript text/css application/xml.

There are commonly used static types, depending on the situation you need to compress:

text/html
text/plain
text/css
application/x-javascript
text/javascript
application/xml
Copy after login

ok, the basic server has been configured here, nginx only needs to reload.

Let’s test how to use curl to test that gzip has been turned on on the server (the test condition is the default gzip_types, that is, only text.html is compressed, and other types are not compressed):

Check whether it is turned on gzip, the client needs to add: "accept-encoding: gzip, deflate" header information.

$ curl -i -h "accept-encoding: gzip, deflate" "http://localhost/tag.php"
Copy after login
http/1.1 200 ok
server: nginx
date: thu, 08 mar 2012 07:23:46 gmt
content-type: text/html
connection: close
content-encoding: gzip
Copy after login
$ curl -i -h "accept-encoding: gzip, deflate" "http://localhost/style.css"
Copy after login
http/1.1 200 ok
server: nginx
date: thu, 08 mar 2012 07:23:54 gmt
content-type: text/css
connection: close
last-modified: tue, 27 dec 2011 10:00:51 gmt
etag: "bc612352322d435769c4bdc03ddb2572"
content-length: 22834
Copy after login

You can see it. The second example is not compressed.

The above is the detailed content of How to configure GZip compression when a Node.js site uses Nginx as a reverse proxy. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How to configure cloud server domain name in nginx How to configure cloud server domain name in nginx Apr 14, 2025 pm 12:18 PM

How to configure an Nginx domain name on a cloud server: Create an A record pointing to the public IP address of the cloud server. Add virtual host blocks in the Nginx configuration file, specifying the listening port, domain name, and website root directory. Restart Nginx to apply the changes. Access the domain name test configuration. Other notes: Install the SSL certificate to enable HTTPS, ensure that the firewall allows port 80 traffic, and wait for DNS resolution to take effect.

How to start nginx server How to start nginx server Apr 14, 2025 pm 12:27 PM

Starting an Nginx server requires different steps according to different operating systems: Linux/Unix system: Install the Nginx package (for example, using apt-get or yum). Use systemctl to start an Nginx service (for example, sudo systemctl start nginx). Windows system: Download and install Windows binary files. Start Nginx using the nginx.exe executable (for example, nginx.exe -c conf\nginx.conf). No matter which operating system you use, you can access the server IP

How to check nginx version How to check nginx version Apr 14, 2025 am 11:57 AM

The methods that can query the Nginx version are: use the nginx -v command; view the version directive in the nginx.conf file; open the Nginx error page and view the page title.

How to check the name of the docker container How to check the name of the docker container Apr 15, 2025 pm 12:21 PM

You can query the Docker container name by following the steps: List all containers (docker ps). Filter the container list (using the grep command). Gets the container name (located in the "NAMES" column).

How to run nginx apache How to run nginx apache Apr 14, 2025 pm 12:33 PM

To get Nginx to run Apache, you need to: 1. Install Nginx and Apache; 2. Configure the Nginx agent; 3. Start Nginx and Apache; 4. Test the configuration to ensure that you can see Apache content after accessing the domain name. In addition, you need to pay attention to other matters such as port number matching, virtual host configuration, and SSL/TLS settings.

How to check whether nginx is started How to check whether nginx is started Apr 14, 2025 pm 01:03 PM

How to confirm whether Nginx is started: 1. Use the command line: systemctl status nginx (Linux/Unix), netstat -ano | findstr 80 (Windows); 2. Check whether port 80 is open; 3. Check the Nginx startup message in the system log; 4. Use third-party tools, such as Nagios, Zabbix, and Icinga.

How to create a mirror in docker How to create a mirror in docker Apr 15, 2025 am 11:27 AM

Steps to create a Docker image: Write a Dockerfile that contains the build instructions. Build the image in the terminal, using the docker build command. Tag the image and assign names and tags using the docker tag command.

How to start containers by docker How to start containers by docker Apr 15, 2025 pm 12:27 PM

Docker container startup steps: Pull the container image: Run "docker pull [mirror name]". Create a container: Use "docker create [options] [mirror name] [commands and parameters]". Start the container: Execute "docker start [Container name or ID]". Check container status: Verify that the container is running with "docker ps".

See all articles