Nginx动静分离经典案例配置

简介:

随着Nginx高性能Web服务器大量被使用,目前Nginx最新稳定版为1.2.6,张宴兄在实际应用中大量使用Nginx,并分享Nginx高性能Web服务器知识,使得Nginx在国内也是飞速的发展。那今天咱们再来温习一下Nginx 动静分离知识,这里仅供参考。

一、实践环境:

1
2
3
系统版本:CentOS6. 0  X86_64
Nginx版本:Nginx- 1.2 . 6
Tomcat版本:Tomcat- 6.0 . 18

二、Nginx安装:

  实际环境中安装Nginx,首先需要安装pcre库,然后再安装Nginx:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#安装pcre支持rewrite库,也可以安装源码,注*安装源码时,指定pcre路径为解压源码的路径,而不是编译后的路径,否则会报错。
yum install pcre-devel pcre -y
#下载Nginx源码包
cd /usr/src ;wget -c http: //nginx.org/download/nginx-1.2.6.tar.gz
#解压Nginx源码包
tar -xzf nginx- 1.2 . 6 .tar.gz
#进入解压目录,然后sed修改Nginx版本信息为TDTWS
cd nginx- 1.2 . 6  ; sed -i -e  's/1.2.6//g'  -e  's/nginx\//TDTWS/g'  -e  's/"NGINX"/"TDTWS"/g'  src/core/nginx.h
#预编译Nginx
./configure --user=www --group=www --prefix=/usr/local/nginx -- with -http_stub_status_module -- with -http_ssl_module
#.configure预编译成功后,执行make命令进行编译
make
#make执行成功后,执行make install 正式安装
make install
#自此Nginx安装完毕!!!

三、配置Nginx:

  这里鉴于我的51CTO博客已经有Tomcat安装和配置了,这里忽略,只配置Nginx。

#进入Nginx应用目录
cd /usr/local/nginx/conf
#备份原nginx.conf文件
mv  nginx.conf  nginx.bak
创建 vi nginx.conf ,并写入如下内容:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
user www www;
worker_processes  8 ;
worker_cpu_affinity  00000001  00000010  00000100  00001000  00010000  00100000  01000000  10000000 ;
pid /usr/local/nginx/nginx.pid;
worker_rlimit_nofile  102400 ;
events
{
use  epoll;
worker_connections  102400 ;
}
http
{
   include        mime.types;
   default_type  application/octet-stream;
   fastcgi_intercept_errors on;
   charset  utf- 8 ;
   server_names_hash_bucket_size  128 ;
   client_header_buffer_size 4k;
   large_client_header_buffers  4  32k;
   client_max_body_size 300m;
   sendfile on;
   tcp_nopush     on;
   keepalive_timeout  60 ;
   tcp_nodelay on;
   client_body_buffer_size  512k;
   proxy_connect_timeout     5 ;
   proxy_read_timeout        60 ;
   proxy_send_timeout        5 ;
   proxy_buffer_size        16k;
   proxy_buffers             4  64k;
   proxy_busy_buffers_size 128k;
   proxy_temp_file_write_size 128k;
   gzip on;
   gzip_min_length  1k;
   gzip_buffers      4  16k;
   gzip_http_version  1.1 ;
   gzip_comp_level  2 ;
   gzip_types       text/plain application/x-javascript text/css application/xml;
   gzip_ var y on;
### 2012 - 12 - 19  change nginx logs
log_format  main   '$http_x_forwarded_for - $remote_user [$time_local] "$request" '
               '$status $body_bytes_sent "$http_referer" '
               '"$http_user_agent"  $request_time $remote_addr' ;
#这里为后端服务器wugk应用集群配置,根据后端实际情况修改即可,tdt_wugk为负载均衡名称,可以任意指定
#但必须跟vhosts.conf虚拟主机的pass段一致,否则不能转发后端的请求。
upstream tdt_wugk {
     server    10.10 . 141.30 : 8080  weight=1max_fails=2fail_timeout=30s;
     server    10.10 . 141.30 : 8081  weight=1max_fails=2fail_timeout=30s;
     server    10.10 . 141.31 : 8080  weight=1max_fails=2fail_timeout=30s;
     server    10.10 . 141.31 : 8081  weight=1max_fails=2fail_timeout=30s;
     server    10.10 . 141.32 : 8080  weight=1max_fails=2fail_timeout=30s;
     server    10.10 . 141.32 : 8081  weight=1max_fails=2fail_timeout=30s;
}
#这里为后端APP应用负载均衡配置,根据后端实际情况修改即可。tdt_app为负载均衡名称,可以任意指定
upstream tdt_app {
     server    10.10 . 141.40 : 8080  weight=1max_fails=2fail_timeout=30s;
     server    10.10 . 141.40 : 8081  weight=1max_fails=2fail_timeout=30s;
     server    10.10 . 141.41 : 8080  weight=1max_fails=2fail_timeout=30s;
     server    10.10 . 141.41 : 8081  weight=1max_fails=2fail_timeout=30s;
     server    10.10 . 141.42 : 8080  weight=1max_fails=2fail_timeout=30s;
     server    10.10 . 141.42 : 8081  weight=1max_fails=2fail_timeout=30s;
}
# include 引用vhosts.conf,该文件主要用于配置Nginx 虚拟主机
include  vhosts.conf;
}

  如上nginx.conf配置完毕,继续配置nginx虚拟主机,继续在当前目录创建vhosts.conf

  vi vhosts.conf 内容如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
####www.wuguangke.cn
server
   {
     listen        80 ;
     server_name  www.wuguangke.cn;
     index index.html index.htm;
#配置发布目录为/data/www/wugk
     root  /data/www/wugk;
     location /
     {
          proxy_next_upstream http_502 http_504 error timeout invalid_header;
          proxy_set_header Host  $host;
          proxy_set_header X-Real-IP $remote_addr;
          proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
          proxy_pass http: //tdt_wugk;
          expires      3d;
     }
#动态页面交给http: //tdt_wugk,也即我们之前在nginx.conf定义的upstream tdt_wugk 均衡
     location ~ .*\.(php|jsp|cgi)?$
     {
          proxy_set_header Host  $host;
          proxy_set_header X-Real-IP $remote_addr;
          proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
          proxy_pass http: //tdt_wugk;
     }
#配置Nginx动静分离,定义的静态页面直接从Nginx发布目录读取。
     location ~ .*\.(html|htm|gif|jpg|jpeg|bmp|png|ico|txt|js|css)$
     {
     root /data/www/wugk;
     #expires定义用户浏览器缓存的时间为 3 天,如果静态页面不常更新,可以设置更长,这样可以节省带宽和缓解服务器的压力
     expires      3d;
     }
#定义Nginx输出日志的路径
     access_log  /data/logs/nginx_wugk/access.log main;
     error_log   /data/logs/nginx_wugk/error.log  crit;
}
##########chinaapp.sinaapp.com  2012 - 12 - 19
   server
   {
     listen        80 ;
     server_name  chinaapp.sinaapp.com;
     index index.html index.htm;
     root  /data/www;
     location /
     {
          proxy_next_upstream http_502 http_504 error timeout invalid_header;
          proxy_set_header Host  $host;
          proxy_set_header X-Real-IP $remote_addr;
      proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
          proxy_pass http: //tdt_app;
          expires      3d;
     }
     location ~ .*\.(php|jsp|cgi)?$
     {
          proxy_set_header Host  $host;
          proxy_set_header X-Real-IP $remote_addr;
          proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
          proxy_pass http: //tdt_app;
     }
     location ~ .*\.(html|htm|gif|jpg|jpeg|bmp|png|ico|txt|js|css)$
     {
     root /data/www/app;
     expires      3d;
     }
     access_log  /data/logs/nginx_app/access.log main;
     error_log   /data/logs/nginx_app/error.log  crit;
}

四、部署测试:

  后端配置好Tomcat服务,并启动,发布的程序需同步到Nginx的/data/www对应的目录,因为配置动静分离后,用户请求你定义的静态页面,默认会去nginx的发布目录请求,而不会到后端请求,所以这时候你要保证后端跟前端的程序保持一致,可以使用Rsync做服务端自动同步或者使用NFS、MFS分布式共享存储。

1
2
3
4
5
6
7
8
#检查Nginx配置文件是否配置正确,提示Ok and successful表示正确,如下:
[root@WEB- 11 - 151  ~]# /usr/local/nginx/sbin/nginx -t
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax  is  ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test  is  successful
#启动Nginx服务
/usr/local/nginx/sbin/nginx
#查看Nginx进程是否启动
ps -ef |grep nginx

 本文只是一个简单的实际案例,里面的配置和参数这里没有做过多的说明,后期会继续更新。


本文转自 wgkgood 51CTO博客,原文链接:http://blog.51cto.com/wgkgood/1094236

相关文章
|
1月前
|
缓存 应用服务中间件 网络安全
Nginx中配置HTTP2协议的方法
Nginx中配置HTTP2协议的方法
79 7
|
3天前
|
存储 应用服务中间件 nginx
nginx反向代理bucket目录配置
该配置实现通过Nginx代理访问阿里云OSS存储桶中的图片资源。当用户访问代理域名下的图片URL(如 `http://代理域名/123.png`)时,Nginx会将请求转发到指定的OSS存储桶地址,并重写路径为 `/prod/files/2024/12/12/123.png`。
30 5
|
27天前
|
缓存 负载均衡 算法
如何配置Nginx反向代理以实现负载均衡?
如何配置Nginx反向代理以实现负载均衡?
|
1月前
|
存储 负载均衡 中间件
Nginx反向代理配置详解,图文全面总结,建议收藏
Nginx 是大型架构必备中间件,也是大厂喜欢考察的内容,必知必会。本篇全面详解 Nginx 反向代理及配置,建议收藏。
Nginx反向代理配置详解,图文全面总结,建议收藏
|
18天前
|
负载均衡 前端开发 应用服务中间件
负载均衡指南:Nginx与HAProxy的配置与优化
负载均衡指南:Nginx与HAProxy的配置与优化
39 3
|
1月前
|
应用服务中间件 API nginx
nginx配置反向代理404问题
【10月更文挑战第18天】本文介绍了使用Nginx进行反向代理的配置方法,解决了404错误、跨域问题和302重定向问题。关键配置包括代理路径、请求头设置、跨域头添加以及端口转发设置。通过调整`proxy_set_header`和添加必要的HTTP头,实现了稳定的服务代理和跨域访问。
241 1
nginx配置反向代理404问题
|
27天前
|
负载均衡 监控 应用服务中间件
配置Nginx反向代理时如何指定后端服务器的权重?
配置Nginx反向代理时如何指定后端服务器的权重?
49 4
|
27天前
|
安全 应用服务中间件 网络安全
如何测试Nginx反向代理实现SSL加密访问的配置是否正确?
如何测试Nginx反向代理实现SSL加密访问的配置是否正确?
52 3
|
27天前
|
安全 应用服务中间件 网络安全
配置Nginx反向代理实现SSL加密访问的步骤是什么?
我们可以成功地配置 Nginx 反向代理实现 SSL 加密访问,为用户提供更安全、可靠的网络服务。同时,在实际应用中,还需要根据具体情况进行进一步的优化和调整,以满足不同的需求。SSL 加密是网络安全的重要保障,合理配置和维护是确保系统安全稳定运行的关键。
100 3
|
29天前
|
应用服务中间件 网络安全 nginx
轻松上手Nginx Proxy Manager:安装、配置与实战
Nginx Proxy Manager (NPM) 是一款基于 Nginx 的反向代理管理工具,提供直观的 Web 界面,方便用户配置和管理反向代理、SSL 证书等。本文档介绍了 NPM 的安装步骤,包括 Docker 和 Docker Compose 的安装、Docker Compose 文件的创建与配置、启动服务、访问 Web 管理界面、基本使用方法以及如何申请和配置 SSL 证书,帮助用户快速上手 NPM。
188 1