Nginx动静分离经典配置
随着Nginx高性能Web服务器大量被使用,目前Nginx最新稳定版为1.2.6,张宴兄在实际应用中大量使用Nginx,并分享Nginx高性能Web服务器知识,使得Nginx在国内也是飞速的发展。那今天咱们再来温习一下Nginx 动静分离知识,这里仅供参考。
一、实践环境:
1.系统版本:CentOS6.0 X86_64
2.
3. Nginx版本:Nginx-1.2.6
4.
5. Tomcat版本:Tomcat-6.0.18
二、Nginx安装:
实际环境中安装Nginx,首先需要安装pcre库,然后再安装Nginx:
1.#安装pcre支持rewrite库,也可以安装源码,注*安装源码时,指定pcre路径为解压源码的路径,而不是编译后的路径,否则会报错。
2. yuminstall pcre-devel pcre -y
3.
4. #下载Nginx源码包
5. cd /usr/src ;wget -c http://nginx.org/download/nginx-1.2.6.tar.gz
6.
7. #解压Nginx源码包
8. tar -xzf nginx-1.2.6.tar.gz
9.
10.#进入解压目录,然后sed修改Nginx版本信息为TDTWS
11. 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
12.
13.#预编译Nginx
14../configure --user=www --group=www --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module
15.#.configure预编译成功后,执行make命令进行编译
16.
17. make
18.#make执行成功后,执行makeinstall 正式安装
19.makeinstall
20. #自此Nginx安装完毕!!!
三、配置Nginx:
这里鉴于我的51CTO博客已经有Tomcat安装和配置了,这里忽略,只配置Nginx。
1.#进入Nginx应用目录
2. cd /usr/local/nginx/conf
3. #备份原nginx.conf文件
4. mv nginx.conf nginx.bak
创建 vi nginx.conf ,并写入如下内容:
1.user www www;
2. worker_processes 8;
3. worker_cpu_affinity 00000001 00000010 00000100 00001000 00010000 00100000 01000000 10000000;
4. pid /usr/local/nginx/nginx.pid;
5.
6. worker_rlimit_nofile 102400;
7.
8. events
9. {
10.use epoll;
11. worker_connections 102400;
12. }
13.http
14.{
15. include mime.types;
16.
17. default_type application/octet-stream;
18.
19. fastcgi_intercept_errors on;
20.
21. charset utf-8;
22.
23. server_names_hash_bucket_size 128;
24. client_header_buffer_size 4k;
25. large_client_header_buffers 4 32k;
26. client_max_body_size 300m;
27.
28. sendfile on;
29. tcp_nopush on;
30.
31. keepalive_timeout 60;
32.
33. tcp_nodelay on;
34.
35. client_body_buffer_size 512k;
36. proxy_connect_timeout 5;
37. proxy_read_timeout 60;
38. proxy_send_timeout 5;
39. proxy_buffer_size 16k;
40. proxy_buffers 4 64k;
41. proxy_busy_buffers_size 128k;
42. proxy_temp_file_write_size 128k;
43.
44. gzip on;
45. gzip_min_length 1k;
46. gzip_buffers 4 16k;
47. gzip_http_version 1.1;
48. gzip_comp_level 2;
49. gzip_types text/plain application/x-javascript text/css application/xml;
50. gzip_vary on;
51.
52.
53. ###2012-12-19 change nginx logs
54.
55. log_format main '$http_x_forwarded_for - $remote_user [$time_local] "$request" '
56. '$status $body_bytes_sent "$http_referer" '
57. '"$http_user_agent" $request_time $remote_addr';
58.
59. #这里为后端服务器wugk应用集群配置,根据后端实际情况修改即可,tdt_wugk为负载均衡名称,可以任意指定
60. #但必须跟vhosts.conf虚拟主机的pass段一致,否则不能转发后端的请求。
61.upstream tdt_wugk {
62. server 10.10.141.30:8080 weight=1 max_fails=2 fail_timeout=30s;
63. server 10.10.141.30:8081 weight=1 max_fails=2 fail_timeout=30s;
64. server 10.10.141.31:8080 weight=1 max_fails=2 fail_timeout=30s;
65. server 10.10.141.31:8081 weight=1 max_fails=2 fail_timeout=30s;
66. server 10.10.141.32:8080 weight=1 max_fails=2 fail_timeout=30s;
67. server 10.10.141.32:8081 weight=1 max_fails=2 fail_timeout=30s;
68. }
69. #这里为后端APP应用负载均衡配置,根据后端实际情况修改即可。tdt_app为负载均衡名称,可以任意指定
70. upstream tdt_app {
71. server 10.10.141.40:8080 weight=1 max_fails=2 fail_timeout=30s;
72. server 10.10.141.40:8081 weight=1 max_fails=2 fail_timeout=30s;
73. server 10.10.141.41:8080 weight=1 max_fails=2 fail_timeout=30s;
74. server 10.10.141.41:8081 weight=1 max_fails=2 fail_timeout=30s;
75. server 10.10.141.42:8080 weight=1 max_fails=2 fail_timeout=30s;
76. server 10.10.141.42:8081 weight=1 max_fails=2 fail_timeout=30s;
77.}
78. #include引用vhosts.conf,该文件主要用于配置Nginx虚拟主机
79. include vhosts.conf;
80. }
如上nginx.conf配置完毕,继续配置nginx虚拟主机,继续在当前目录创建vhosts.conf
vi vhosts.conf 内容如下:
1.####www.wuguangke.cn
2. server
3.
4. {
5. listen 80;
6. server_name www.wuguangke.cn;
7. index index.html index.htm;
8. #配置发布目录为/data/www/wugk
9. root /data/www/wugk;
10.
11. location /
12. {
13. proxy_next_upstream http_502 http_504 error timeout invalid_header;
14. proxy_set_header Host $host;
15. proxy_set_header X-Real-IP $remote_addr;
16. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
17. proxy_pass http://tdt_wugk;
18. expires 3d;
19. }
20. #动态页面交给http://tdt_wugk,也即我们之前在nginx.conf定义的upstream tdt_wugk 均衡
21. location ~ .*\.(php|jsp|cgi)?$
22. {
23. proxy_set_header Host $host;
24. proxy_set_header X-Real-IP $remote_addr;
25. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
26. proxy_pass http://tdt_wugk;
27. }
28. #配置Nginx动静分离,定义的静态页面直接从Nginx发布目录读取。
29. location ~ .*\.(html|htm|gif|jpg|jpeg|bmp|png|ico|txt|js|css)$
30. {
31. root /data/www/wugk;
32.#expires定义用户浏览器缓存的时间为3天,如果静态页面不常更新,可以设置更长,这样可以节省带宽和缓解服务器的压力
33. expires 3d;
34. }
35. #定义Nginx输出日志的路径
36. access_log /data/logs/nginx_wugk/access.log main;
37. error_log /data/logs/nginx_wugk/error.log crit;
38. }
39.
40. ##########chinaapp.sinaapp.com 2012-12-19
41. server
42.
43. {
44. listen 80;
45. server_name chinaapp.sinaapp.com;
46. index index.html index.htm;
47. root /data/www;
48.
49. location /
50. {
51. proxy_next_upstream http_502 http_504 error timeout invalid_header;
52. proxy_set_header Host $host;
53. proxy_set_header X-Real-IP $remote_addr;
54. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
55. proxy_pass http://tdt_app;
56. expires 3d;
57. }
58.
59. location ~ .*\.(php|jsp|cgi)?$
60. {
61. proxy_set_header Host $host;
62. proxy_set_header X-Real-IP $remote_addr;
63. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
64. proxy_pass http://tdt_app;
65. }
66. location ~ .*\.(html|htm|gif|jpg|jpeg|bmp|png|ico|txt|js|css)$
67. {
68. root /data/www/app;
69. expires 3d;
70. }
71.
72. access_log /data/logs/nginx_app/access.log main;
73. error_log /data/logs/nginx_app/error.log crit;
74. }
四、部署测试:
后端配置好Tomcat服务,并启动,发布的程序需同步到Nginx的/data/www对应的目录,因为配置动静分离后,用户请求你定义的静态页面,默认会去nginx的发布目录请求,而不会到后端请求,所以这时候你要保证后端跟前端的程序保持一致,可以使用Rsync做服务端自动同步。
1.#检查Nginx配置文件是否配置正确,提示Ok andsuccessful表示正确,如下:
2. [root@WEB-11-151~]# /usr/local/nginx/sbin/nginx -t
3. nginx:the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
4. nginx:configuration file /usr/local/nginx/conf/nginx.conf test is successful
5. #启动Nginx服务
6. /usr/local/nginx/sbin/nginx
7. #查看Nginx进程是否启动
8. ps -ef |grep nginx
本文只是一个简单的实际案例,里面的配置和参数这里没有做过多的说明,后期会继续更新。
本文出自 “烟雨楼台” 博客,请务必保留此出处http://wgkgood.blog.51cto.com/1192594/1094236
转载于:https://blog.51cto.com/xiangpang/1721347
Nginx动静分离经典配置相关推荐
- Nginx动静分离技术(配置步骤)
目录 1. 项目前后端联调时,使用 Nginx动静分离技术 来实现报告的展示 2. nginx 常用命令 3. 配置域名:涉及两个配置文件hosts, nginx.conf 3.1 修改win10系统 ...
- Tengine(Nginx)动静分离简要配置
2019独角兽企业重金招聘Python工程师标准>>> 要点:根据URL规则,分离静态资源.例子中是根据"/static/"这个路径分离 1.把原应用服务器的st ...
- nginx动静分离配置_Nginx 动静分离与负载均衡的实现
一.前提 企业中,随着用户的增长,数据量也几乎成几何增长,数据越来越大,随之也就出现了各种应用的瓶颈问题. 问题出现了,我们就得想办法解决,一般网站环境,均会使用LAMP或者LNMP,而我们对于网站环 ...
- nginx动静分离配置_Nginx动静分离配置实例
点击▲关注 "长安大司马" 给公众号标星置顶 更多精彩 第一时间直达 父亲节快乐 HAPPY FATHER'S DAY 1 .什么是动静分离 Nginx 动静分离简单来说就是把 ...
- Nginx动静分离配置
Nginx动静分离 一.动静分离介绍 动静分离,通过中间件将动态请求和静态请求进行分离 通过中间件将动态请求和静态请求分离,可以减少不必要的请求消耗,同时能减少请求的延时. 通过中间件将动态请求和静态 ...
- Nginx系列二:(Nginx Rewrite 规则、Nginx 防盗链、Nginx 动静分离、Nginx+keepalived 实现高可用)...
一.Nginx Rewrite 规则 1. Nginx rewrite规则 Rewrite规则含义就是某个URL重写成特定的URL(类似于Redirect),从某种意义上说为了美观或者对搜索引擎友好, ...
- Nginx动静分离实现负载均衡
转载自 Nginx动静分离实现负载均衡 前期准备 使用Debian环境.安装Nginx(默认安装),一个web项目,安装tomcat(默认安装)等. Nginx.conf配置 1 # 定义Ngin ...
- keepalive高可用nginx(nginx动静分离)的实现
HA Cluster的配置前提: 1.各节点时间要同步:2.确保iptables及selinux不会成为障碍:3.(可选)各节点之间可通过主机名互相通信:节点的名称设定与hosts文件中解析的主机名都 ...
- Nginx 动静分离 -02
Nginx 动静分离 ---- --------切记 10.10.0.7 一.单台机器动静分离 [root@web01 ~]# cat /etc/nginx/conf.d/linux12.wp.com ...
- nginx动静分离和资源隔离的网站搭建
| 作业 nginx动静分离和资源隔离的网站搭建 一.动静分离的网站 0.准备环境 主机 IP 主机角色 条件 web01 192.168.15.7 Android页面 关闭防火墙和selinux w ...
最新文章
- 汇编语言实验七 学习小甲鱼实验代码
- Responsive设计——meta标签
- 用 Python 实现打飞机,让子弹飞吧!
- Linux 的启动流程
- native-maven-plugin与maven-nar-plugin配置
- 图论中的知识点(等待补充和更新)
- boost::math::arcsine用法的测试程序
- 集成activiti-modeler 到 自己的业务系统
- 汽车车灯有必要改造成氙气大灯吗?
- ORACLE 数据同步时,批量进行新增和更新操作的SQL写法
- IronPython系列:利用.NET SoapFormatter学习SOAP序列化
- 【面试题】444- 55 道常见CSS面试题
- MapGuide简介
- 计算机设备没有音频,电脑找不到音频设备是怎么回事_电脑没有音频设备怎么处理...
- android微信版本怎么升级,安卓微信怎么更新到最新版本?
- 华大单片机开发板HC32L13X上手入门
- 门户通专访蓝色理想曾沐阳:用户需慢慢沉淀
- java解压在线tgz文件
- 计算机静音图标无法更改怎么办,电脑声音图标有红叉怎么办?教您解决方法
- 「RPC」简述RPC
热门文章
- SegmentFault 社区访谈 | Linxz:只会写 CSS 不会写 JS 的“伪”前端
- token什么意思中文在C语言中,token什么意思(token里面包含什么信息)
- 计算机u盘被禁用怎么办,电脑U盘启动被禁用了怎么解决 电脑禁用u盘怎样恢复...
- 计算机考研江苏,2020江苏高考分数线公布
- ie不支持includes_IE11 – 对象不支持属性或方法“includes” – javascript window.location.hash...
- uva 10066 The Twin Towers (最长公共子序列)
- 关于Chrome浏览器主页被2345篡改
- 手机幻灯片html代码,html5手机幻灯片制作手指滑动触屏手机幻灯片代码
- 为什么90%的人物画像都是没用的?
- 数据分析之帕累托(贡献度)分析