1. nginx 역방향 프록시 구성
#tomcat
자바 코드
-
업스트림 tomcat_server{
-
서버 127.0.0.1:8080;
-
}
-
-
-
-
에버{
-
들어보세요 80;
- 서버_이름 www.codes51.com
-
- 위치 / {
-
- 프록시 리디렉션 꺼짐
- Proxy_set_header 호스트 $host
- Proxy_set_header X-Real-IP $remote_addr
- Proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
Proxy_pass http:- //tomcat_server;
-
} -
분명히 사용자가 www.codes51.com에 액세스할 때(로컬 로컬 호스트를 설정하고 www.
codes51.com을 nginx가 있는 IP로 지정해야 함)(또는 www.codes51.com 직접 nginx가 위치한 IP 주소)에서 백그라운드의 Tomcat 서버, 즉 127.0.0.1:8080으로 요청을 전송하고, 요청한 데이터를 클라이언트로 전달합니다.
2. 동적 요청과 정적 요청을 분리하세요.
무슨 뜻이에요? 그림, JS, HTML과 같은 정적 항목은 전용 서버로 이동하고 동적 요청은 다른 서버로 이동합니다. 매우 간단합니다. 예를 들면 다음과 같습니다.
자바 코드
-
서버 {
-
들어보세요 192.168.154.128:80;
-
server_name image.codes51.com;
-
색인 index.html;
-
-
-
#proxy_pass http://tomcat_server;
-
-
#charset koi8-r;
-
-
#access_log logs/host.access.log main;
-
-
-
-
위치 / {
-
루트 html;
-
#index index.html index.htm;
-
proxy_redirect 꺼짐;
-
proxy_set_header 호스트 $host;
-
proxy_set_header X-Real-IP $remote_addr;
-
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
-
-
-
}
-
-
-
-
위치 ~ .*.(gif|jpg|jpeg|png|bmp|swf)$
-
{
-
-
valid_referers 없음 차단됨 192.168.154.128 192.168.154.1;
-
if ($invalid_referer)
-
{
-
다시 작성 ^ /403.jpg break;
-
}
-
-
if (!-f $request_filename) {
-
다시 작성 ^ /404.jpg 마지막;
-
}
-
-
30일에 만료됩니다.
-
-
}
-
#error_page 404 /404.html;
-
-
# 서버 오류 페이지를 정적 페이지/50x.html로 리디렉션
-
#
-
error_page 500 502 503 504 /50x.html;
-
위치 = /404.jpg {
-
루트 html;
-
}
-
-
}
-
-
톰캣
-
업스트림 tomcat_server{
-
서버 127.0.0.1:8080;
-
}
-
-
-
서버{
-
들어보세요 192.168.154.128;
-
서버_이름 www.codes51.com;
-
-
위치 / {
-
-
-
proxy_redirect 꺼짐;
-
proxy_set_header 호스트 $host;
-
proxy_set_header X-Real-IP $remote_addr;
-
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
-
proxy_pass http://tomcat_server;
-
-
}
-
-
-
-
}
상단의 방법은 서로 다른 이름으로 설정되어 있으며 동일한 이름과 동일하게 사용되지 않습니다.
자바代码
-
#tomcat
-
업스트림 tomcat_server{
-
서버 127.0.0.1:8080;
-
}
-
-
-
서버{
-
들어보세요 192.168.154.128;
-
서버 이름 www.codes51.com;
-
-
위치 ~ .*.(gif|jpg|jpeg|png|bmp|swf)$
-
{
-
-
루트 html;
-
-
}
-
-
-
위치 ~ .*.(jsp|do)$ {
-
-
proxy_redirect 꺼짐;
-
proxy_set_header 호스트 $host;
-
proxy_set_header X-Real-IP $remote_addr;
-
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
-
proxy_pass http://tomcat_server;
-
-
}
OK!같은 이름, 根据后缀不同, 请求不同服务, 实现动态静态请求域离.如*.abc ,那难道又去修改那个配移文件吗? 아래:
자바代码
-
위치 /정적
-
{
-
-
루트 html/정적;
-
-
}
咦这样是不是就好一些了,而且文件的存放也比较有规范了。
3,nginx缓存应용
nginx에는 웹사이트가 없습니다.就会很快解决问题,nginx第三方模块ngx_cache_purge能清除指정URL 。
nginx 보안은 ngx_cache_purege를 지원합니다.
자바代码
-
./configure --user=www --group=www --add-module=/root/dxm/nginx/ngx_cache_purge-1.2
其中,/root/dxm/nginx/ngx_cache_purge-1.2为ngx_cache_purge解压路径(附件中提供ngx_cache_purge tar包下载)
现在来一段实例,实现图文缓存:
그런데,proxy_tem_path와proxy_cache_path는 같은 파티션 아래에 있어야 합니다!
자바 코드
-
proxy_temp_path /usr/local/nginx/proxy_temp;
- proxy_cache_path /usr/local/nginx/proxy_cache_path level=1:2key_zone=cache_one:200m inactive=1d max_size=1g
자바 코드
-
업스트림 tomcat_server{
-
서버 127.0.0.1:8080;
-
}
-
-
-
서버{
-
들어보세요 192.168.154.128;
-
서버_이름 www.codes51.com;
-
-
위치 ~ .*.(gif|jpg|jpeg|png|bmp|swf)$
-
{
-
-
proxy_cache cache_one;
-
proxy_cache_methods GET HEAD POST;
-
proxy_cache_min_uses 1;
-
proxy_cache_valid 200 302 10m;
-
proxy_cache_valid 404 1m;
-
proxy_cache_valid 모든 1m;
-
proxy_cache_key "$host:$server_port$uri$is_args$args";
-
-
proxy_redirect 꺼짐;
-
proxy_set_header 호스트 $host;
-
proxy_set_header X-Real-IP $remote_addr;
-
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
-
proxy_pass http://tomcat_server;
-
-
-
}
-
-
-
위치 ~ .*.(jsp)$ {
-
-
proxy_redirect 꺼짐;
-
proxy_set_header 호스트 $host;
-
proxy_set_header X-Real-IP $remote_addr;
-
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
-
proxy_pass http://tomcat_server;
-
-
}
-
-
-
위치 ~ /purge(/.*)
-
{
-
192.168.154.128 허용;
- 192.168.154.1 허용;
모두 거부 -
Proxy_cache_purge 캐시_원 $host:$server_port$- 1$is_args$args
} -
음, 정적 페이지는 캐시되지만 동적 요청은 캐시되지 않습니다!
마지막 단락의 퓨지 구성을 살펴보면 분명히 어떤 IP가 지정된 URL을 수동으로 지울 수 있는지 나타납니다.
위 내용은 nginx 역방향 프록시, 동적 및 정적 요청 분리, nginx 캐시 응용 프로그램을 소개하고, ngx_cache_purge를 사용하여 콘텐츠를 포함하여 지정된 URL을 지우는 내용이 PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.