고성능 정적 파일 캐싱을 위해 Nginx를 사용하는 방법
고성능 정적 파일 캐싱을 위해 Nginx를 사용하는 방법
Nginx는 고성능 및 높은 동시성 기능으로 널리 주목받고 널리 사용되는 경량 오픈 소스 웹 서버입니다. 웹 서버인 것 외에도 Nginx에는 웹 사이트의 액세스 속도와 성능을 크게 최적화할 수 있는 정적 파일 캐싱 기능을 제공하는 중요한 기능이 있습니다. 이 기사에서는 고성능 정적 파일 캐싱을 위해 Nginx를 사용하는 방법을 소개하고 해당 코드 예제를 제공합니다.
- 정적 파일 액세스를 위한 Nginx 구성
정적 파일 캐싱 기능을 활성화하려면 먼저 정적 파일에 대한 요청을 식별하고 처리하도록 Nginx를 구성해야 합니다. 일반적으로 정적 파일에는 이미지, CSS 파일, JavaScript 파일 등이 포함됩니다. 다음은 간단한 Nginx 구성 예입니다.
server { listen 80; server_name example.com; root /path/to/static/files; location ~* .(jpg|jpeg|png|gif|css|js)$ { expires 30d; access_log off; } }
위 구성에서 listen
은 Nginx가 수신 대기하는 포트를 지정하고 server_name
은 서버의 도메인 이름을 지정합니다. root
는 정적 파일이 있는 루트 디렉터리를 지정합니다. location
지시문은 일치하는 URL 패턴과 해당 처리 매개변수를 지정합니다. 위 구성에서 정규식 ~* .(jpg|jpeg|png|gif|css|js)$
는 jpg, jpeg, png, gif, css 또는 js의 접미사와 일치합니다. 파일의 경우, expires
는 캐시 유효 기간을 30일로 지정하고 access_log off
는 정적 파일에 대한 액세스 로깅을 비활성화합니다. listen
指定了Nginx监听的端口,server_name
指定了服务器的域名。root
指定了静态文件所在的根目录。location
指令指定了匹配的URL模式,以及对应的处理参数。在上面的配置中,通过正则表达式~* .(jpg|jpeg|png|gif|css|js)$
匹配了以jpg、jpeg、png、gif、css或js为后缀的文件,expires
指定了缓存的有效期为30天,access_log off
则禁止了对静态文件的访问日志记录。
- 配置Nginx进行静态文件缓存
为了启用Nginx的静态文件缓存功能,我们可以添加一些额外的配置指令。下面是一个示例:
location ~* .(jpg|jpeg|png|gif|css|js)$ { expires 30d; access_log off; add_header Cache-Control "public"; add_header Pragma public; etag off; }
在上述示例中,add_header
指令添加了两个头部信息,分别是Cache-Control
和Pragma
。这两个头部信息告诉客户端和其他缓存服务器在一定时间内可以使用缓存的副本。etag off
禁用了Etag头部信息,因为在某些情况下,Etag可能会导致一些兼容性问题。
- 验证静态文件缓存是否生效
为了验证静态文件缓存是否生效,可以使用浏览器的开发者工具或者命令行工具进行查看。在浏览器的开发者工具中,可以查看HTTP响应头部的Cache-Control
和Expires
字段,以及响应内容的大小。如果缓存生效,那么在第一次访问静态文件后,再次请求时会看到Cache-Control
和Expires
的值与上述配置一致,并且响应内容的大小会变得非常小。
另外,可以使用命令行工具如curl来查看HTTP响应头部信息。例如,可以执行以下命令来查看一个图片文件的HTTP响应头部信息:
$ curl -I example.com/path/to/image.jpg
如果缓存生效,那么你会在结果中看到类似下面的行:
Cache-Control: public, max-age=2592000 Expires: Thu, 10 Aug 2023 08:16:50 GMT
- 动态更新缓存
有时候我们可能需要动态地更新缓存,例如当静态文件被修改后。可以通过在文件名或者路径中添加版本号来解决这个问题。例如,假设有一个CSS文件style.css
,我们可以将其重命名为style.v1.css
정적 파일 캐싱을 위한 Nginx 구성
$ nginx -s reload
위 예에서 add_header
지시문은 두 개의 헤더 정보, 즉 Cache-Control
및 Pragma
코드를 추가합니다. >. 이 두 헤더는 클라이언트와 다른 캐싱 서버에 캐시된 복사본을 특정 기간 동안 사용할 수 있음을 알려줍니다. etag off
는 Etag 헤더 정보를 비활성화합니다. 경우에 따라 Etag로 인해 호환성 문제가 발생할 수 있기 때문입니다.
정적 파일 캐시가 효과적인지 확인하세요
정적 파일 캐시가 효과적인지 확인하려면 브라우저의 개발자 도구나 명령줄 도구를 사용하여 확인할 수 있습니다. 브라우저의 개발자 도구에서 HTTP 응답 헤더의 Cache-Control
및 Expires
필드와 응답 콘텐츠의 크기를 볼 수 있습니다. 캐시가 적용되면 처음으로 정적 파일에 액세스한 후 Cache-Control
및 Expires
값이 위 구성과 일치하는 것을 확인할 수 있습니다. 다시 요청하면 응답 내용은 크기가 매우 작아집니다.
- 🎜동적 업데이트 캐시 🎜 때로는 정적 파일이 수정되는 경우와 같이 캐시를 동적으로 업데이트해야 할 수도 있습니다. 파일 이름이나 경로에 버전 번호를 추가하면 이 문제를 해결할 수 있습니다. 예를 들어 CSS 파일
style.css
가 있다고 가정하면 이름을 style.v1.css
로 바꾸고 Nginx의 구성 파일을 새 파일 이름과 일치하도록 업데이트할 수 있습니다. 이렇게 하면 CSS 파일이 수정될 때마다 파일 이름의 버전 번호만 업데이트하면 됩니다. 🎜🎜🎜또한 Nginx는 서버를 중지하지 않고 구성 파일을 다시 로드할 수 있는 reload 명령도 제공합니다. 예를 들어, 다음 명령을 실행하여 Nginx 구성 파일을 다시 로드할 수 있습니다: 🎜rrreee🎜 이러한 방식으로 Nginx는 구성 파일을 다시 읽고 업데이트된 구성이 즉시 적용됩니다. 🎜🎜요약🎜정적 파일 캐싱을 위해 Nginx를 사용하면 웹 사이트의 성능과 액세스 속도를 크게 향상시킬 수 있습니다. 이 기사에서는 정적 파일 액세스 및 캐싱 기능을 활성화하도록 Nginx를 구성하는 방법을 소개하고 해당 코드 예제 및 확인 방법을 제공합니다. 이 콘텐츠가 귀하의 웹사이트 성능을 최적화하는 데 도움이 되기를 바랍니다. 🎜위 내용은 고성능 정적 파일 캐싱을 위해 Nginx를 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Windows에서 Nginx를 구성하는 방법은 무엇입니까? nginx를 설치하고 가상 호스트 구성을 만듭니다. 기본 구성 파일을 수정하고 가상 호스트 구성을 포함하십시오. 시작 또는 새로 고침 Nginx. 구성을 테스트하고 웹 사이트를보십시오. SSL을 선택적으로 활성화하고 SSL 인증서를 구성하십시오. 포트 80 및 443 트래픽을 허용하도록 방화벽을 선택적으로 설정하십시오.

Linux에서는 다음 명령을 사용하여 nginx가 시작되었는지 확인하십시오. SystemCTL 상태 Nginx 판사 명령 출력에 따라 : "active : running"이 표시되면 Nginx가 시작됩니다. "Active : 비활성 (죽음)"이 표시되면 Nginx가 중지됩니다.

Linux에서 Nginx를 시작하는 단계 : Nginx가 설치되어 있는지 확인하십시오. systemctl start nginx를 사용하여 nginx 서비스를 시작하십시오. SystemCTL을 사용하여 NGINX를 사용하여 시스템 시작시 NGINX의 자동 시작을 활성화하십시오. SystemCTL 상태 nginx를 사용하여 시작이 성공했는지 확인하십시오. 기본 환영 페이지를 보려면 웹 브라우저의 http : // localhost를 방문하십시오.

nginx가 시작되었는지 확인하는 방법 : 1. 명령 줄을 사용하십시오 : SystemCTL 상태 nginx (linux/unix), netstat -ano | Findstr 80 (Windows); 2. 포트 80이 열려 있는지 확인하십시오. 3. 시스템 로그에서 nginx 시작 메시지를 확인하십시오. 4. Nagios, Zabbix 및 Icinga와 같은 타사 도구를 사용하십시오.

질문에 대한 답변 : 304 수정되지 않은 오류는 브라우저가 클라이언트 요청의 최신 리소스 버전을 캐시했음을 나타냅니다. 솔루션 : 1. 브라우저 캐시를 지우십시오. 2. 브라우저 캐시를 비활성화합니다. 3. 클라이언트 캐시를 허용하도록 nginx를 구성합니다. 4. 파일 권한을 확인하십시오. 5. 파일 해시를 확인하십시오. 6. CDN 또는 리버스 프록시 캐시를 비활성화합니다. 7. nginx를 다시 시작하십시오.

Nginx 크로스 도메인 문제를 해결하는 두 가지 방법이 있습니다. 크로스 도메인 응답 헤더 수정 : 교차 도메인 요청을 허용하고 허용 된 메소드 및 헤더를 지정하고 캐시 시간을 설정하는 지시문을 추가하십시오. CORS 모듈 사용 : 모듈을 활성화하고 CORS 규칙을 구성하여 크로스 도메인 요청, 메소드, 헤더 및 캐시 시간을 허용합니다.

Nginx 403 금지 된 오류를 수정하는 방법은 무엇입니까? 파일 또는 디렉토리 권한을 확인합니다. 2. 확인 파일을 확인하십시오. 3. nginx 구성 파일 확인; 4. nginx를 다시 시작하십시오. 다른 가능한 원인으로는 방화벽 규칙, Selinux 설정 또는 응용 프로그램 문제가 있습니다.

Nginx 서버를 시작하려면 다른 운영 체제에 따라 다른 단계가 필요합니다. Linux/Unix System : Nginx 패키지 설치 (예 : APT-Get 또는 Yum 사용). SystemCTL을 사용하여 nginx 서비스를 시작하십시오 (예 : Sudo SystemCtl start nginx). Windows 시스템 : Windows 바이너리 파일을 다운로드하여 설치합니다. nginx.exe 실행 파일을 사용하여 nginx를 시작하십시오 (예 : nginx.exe -c conf \ nginx.conf). 어떤 운영 체제를 사용하든 서버 IP에 액세스 할 수 있습니다.
