>운영 및 유지보수 >엔진스 >Node.js 사이트에서 Nginx를 역방향 프록시로 사용할 때 GZip 압축을 구성하는 방법

Node.js 사이트에서 Nginx를 역방향 프록시로 사용할 때 GZip 압축을 구성하는 방법

PHPz
PHPz앞으로
2023-05-25 19:13:041370검색

Node.js 개발 사이트, nginx를 사용하여 역방향 프록시를 구현하는 경우

그러면 서버 측에서 쉽게 gzip 압축을 구현하여 사이트 탐색을 더 원활하게 만들 수 있습니다.

전제 조건: node.js + nginx 역방향 프록시.

node.js 수행해야 할 작업:

express 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());

모든 요청을 압축하기 위해 압축이 맨 위에 배치됩니다.

express 4.0 이상(4.0 포함)

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

4.0 이상 미들웨어는 독립적으로 제거됩니다.

그러므로 먼저 rquire('압축')이 필요합니다

express 3.5와 express 4.0의 주요 차이점을 보려면 여기를 클릭하세요

node.js가 해야 할 작업은 그만큼 간단합니다.

nginx를 완료해야 합니다. 작업:

nginx 구성 파일을 열고 구성을 수정한 다음 gzip 스위치를 켜세요.

nano /usr/local/nginx/conf/nginx.conf

자체 서버의 nginx가 /usr/local/ 디렉터리에 설치되지 않을 수 있으므로 다음을 찾으세요. 자신의 설치 디렉터리에 있는 nginx.conf 구성 파일

http 구성 노드에 다음 구성을 추가하세요.

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 (
    //放上面配置节点  
)

각 구성 항목의 의미는 무엇인가요?

1) gzip

구문: ​​gzip on/off

기본값 : off

범위: http, 서버, 위치

설명: gzip 모듈을 활성화 또는 비활성화합니다. 여기서 on을 사용하면 시작을 의미합니다.

2) gzip_min_length

구문: gzip_min_length 길이

기본값: gzip_min_length 0

범위: http , server, location

설명: 권한 설정 압축된 페이지의 최소 바이트 수는 헤더의 content-length에서 가져옵니다. 기본값은 0이며, 크기에 관계없이 페이지를 압축합니다. 바이트 수는 1k보다 크게 설정하는 것이 좋습니다. 1k보다 작으면 점점 더 압축될 수 있습니다. |

3) gzip_buffers

구문: ​​gzip_buffers 수 크기

기본값: gzip_buffers 4 4k/8k

범위: http, 서버, 위치

설명: gzip을 저장하기 위해 여러 단위의 캐시를 얻도록 시스템을 설정합니다. 결과 데이터 스트림. 4 16k는 16k 단위로 메모리를 적용하고 16k 단위로 원래 데이터 크기의 4배를 적용한다는 의미입니다.

4) gzip_comp_level

구문: ​​gzip_comp_level 1..9

기본값: gzip_comp_level 1

범위: http, 서버, 위치

설명: gzip 압축 비율, 1은 최소 압축 비율이며 가장 빠른 처리 속도입니다. 9 압축 가장 크지만 처리 속도가 가장 느립니다(전송은 빠르지만 더 많은 CPU를 소비합니다). 여기서는 5로 설정되어 있습니다.

5) gzip_types

구문: ​​gzip_types mime-type [mime-type ...]

기본값: gzip_types text/html

범위: http, 서버, 위치

설명: 압축을 위한 MIME 유형 일치, ( 지정 여부에 관계없이 "text/html" 유형은 항상 압축됩니다. 이는 application/x-javascript text/css application/xml로 설정됩니다.

압축해야 하는 상황에 따라 일반적으로 사용되는 정적 유형이 있습니다.

text/html
text/plain
text/css
application/x-javascript
text/javascript
application/xml

ok, 기본 서버는 여기에서 구성되었으며 nginx만 다시 로드하면 됩니다.

지금 테스트해 보겠습니다. 서버에서 gzip이 켜져 있는지 테스트하기 위해 컬을 사용하는 방법(테스트 조건은 기본 gzip_types입니다. 즉, text.html만 압축되고 다른 유형은 압축되지 않습니다):

gzip이 켜져 있는지 확인하세요. 클라이언트는 "accept-encoding: gzip, deflate" 헤더 정보에 참여해야 합니다.

$ curl -i -h "accept-encoding: gzip, deflate" "http://localhost/tag.php"
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
$ curl -i -h "accept-encoding: gzip, deflate" "http://localhost/style.css"
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

보실 수 있습니다. 두 번째 예는 압축되지 않았습니다.

위 내용은 Node.js 사이트에서 Nginx를 역방향 프록시로 사용할 때 GZip 압축을 구성하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 yisu.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제