Nginx动静分离知识及配置
Nginx动静分离知识及配置,本质上与分离上传下载功能是相同功能,本质就是在文件服务器也是需要部署WEB应用的,只是在进行代理分离的时候分配到对应的文件服务器上去。
随着Nginx高性能Web服务器大量被使用,目前Nginx最新稳定版为1.2.6,张宴兄在实际应用中大量使用Nginx,并分享Nginx高性能Web服务器知识,使得Nginx在国内也是飞速的发展。那今天咱们再来温习一下Nginx 动静分离知识,这里仅供参考。
一、实践环境:
系统版本:CentOS6.0 X86_64
Nginx版本:Nginx-1.2.6
Tomcat版本:Tomcat-6.0.18
二、Nginx安装:
实际环境中安装Nginx,首先需要安装pcre库,然后再安装Nginx:
01.#安装pcre支持rewrite库,也可以安装源码,注*安装源码时,指定pcre路径为解压源码的路径,而不是编译后的路径,否则会报错。02.yum install pcre-devel pcre -y03. 04.#下载Nginx源码包06. 07.#解压Nginx源码包08.tar -xzf nginx-1.2.6.tar.gz09. 10.#进入解压目录,然后sed修改Nginx版本信息为TDTWS11.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.h12. 13.#预编译Nginx14../configure --user=www --group=www --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module15.#.configure预编译成功后,执行make命令进行编译16. 17.make18.#make执行成功后,执行make install 正式安装19.make install20.#自此Nginx安装完毕!!!三、配置Nginx:
这里鉴于我的51CTO博客已经有Tomcat安装和配置了,这里忽略,只配置Nginx。
1.#进入Nginx应用目录2.cd /usr/local/nginx/conf www.it165.net3.#备份原nginx.conf文件4.mv nginx.conf nginx.bak 创建 vi nginx.conf ,并写入如下内容:
01.user www www;02.worker_processes 8;03.worker_cpu_affinity 00000001 00000010 00000100 00001000 00010000 00100000 01000000 10000000;04.pid /usr/local/nginx/nginx.pid;05. 06.worker_rlimit_nofile 102400;07. 08.events09.{10.use epoll;11.worker_connections 102400;12.}13.http14.{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 logs54. 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 内容如下:
01.####www.wuguangke.cn02.server03. 04.{05.listen 80;06.server_name www.wuguangke.cn;07.index index.html index.htm;08.#配置发布目录为/data/www/wugk 09.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|<a href="http://www.it165.net/pro/webjsp/" target="_blank"class="keylink">jsp</a>|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-1941.server42. 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|<a href="http://www.it165.net/pro/webjsp/" target="_blank"class="keylink">jsp</a>|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 and successful表示正确,如下: 2.[root@WEB-11-151 ~]# /usr/local/nginx/sbin/nginx -t3.nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok4.nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful5.#启动Nginx服务6./usr/local/nginx/sbin/nginx7.#查看Nginx进程是否启动8.ps -ef |grep nginx 本文只是一个简单的实际案例,里面的配置和参数这里没有做过多的说明,后期会继续更新。
Nginx动静分离知识及配置的更多相关文章
- Nginx动静分离经典案例配置
随着Nginx高性能Web服务器大量被使用,目前Nginx最新稳定版为1.2.6,张宴兄在实际应用中大量使用Nginx,并分享Nginx高性能Web服务器知识,使得Nginx在国内也是飞速的发展.那今 ...
- Nginx动静分离经典
Nginx:安装nginx之前需要安装pcre包和zlib以支持重写,正则以及网页压缩等等]把所需的包下载到/usr/src下[根据自己的习惯,路径可以改变]1.首先安装pcre: cd /usr/s ...
- Nginx动静分离实现
Nginx动静分离实现: Nginx是一种轻量级,高性能,多进程的Web服务器,非常适合作为静态资源的服务器使用,而动态的访问操作可以使用稳定的Apache.Tomcat及IIS等来实现,这里就以Ng ...
- Nginx动静分离架构
Nginx动静分离简单来说就将动态与静态资源分开,不能理解成只是单纯的把动态页面和静态页面物理分离,严格意义上说应该是动态请求跟静态请求分开,可以理解成使用Nginx处理静态页面,Tomcat,Res ...
- Nginx 动静分离与负载均衡的实现
一.前提 企业中,随着用户的增长,数据量也几乎成几何增长,数据越来越大,随之也就出现了各种应用的瓶颈问题. 问题出现了,我们就得想办法解决,一般网站环境,均会使用LAMP或者LNMP,而我们对于网站环 ...
- Nginx动静分离
动静分离 Nginx动静分离是让动态网站里的动态网页根据一定规则把不变的资源和经常变的资源区分开来,动静资源做好了拆分以后,我们就可以根据静态资源的特点将其做缓存操作,这就是网站静态化处理的核心思路. ...
- Nginx动静分离架构&&HA-LB集群整合
Nginx动静分离简单来说就将动态与静态资源分开,不能理解成只是单纯的把动态页面和静态页面物理分离,严格意义上说应该是动态请求跟静态请求分开,可以理解成使用Nginx处理静态页面,Tomcat,Res ...
- Nginx系列二:(Nginx Rewrite 规则、Nginx 防盗链、Nginx 动静分离、Nginx+keepalived 实现高可用)
一.Nginx Rewrite 规则 1. Nginx rewrite规则 Rewrite规则含义就是某个URL重写成特定的URL(类似于Redirect),从某种意义上说为了美观或者对搜索引擎友好, ...
- Nginx动静分离(Nginx+Tomcat)
第一步:nginx构建 第二步:Tomcat构建 1.Tomcat基础点 (1)Tomcat 是基于java开发的web容器,用来发布java代码和jsp网页. (2)开发人员开发java web网站 ...
随机推荐
- HDUOJ----4502吉哥系列故事——临时工计划
吉哥系列故事——临时工计划 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others)Tot ...
- Windows远程连接局域网内或同一个网段或同一个路由器的某台机器
http://bbs.shendu.com/thread-1443245-1-1.html 亲自试验,具体操作如下: 我现在有三台机器和对应的ip地址(ip地址自己手动填写,不会网上搜) ...
- C# 调节图片亮度
原文地址:https://www.cnblogs.com/wjr408/p/6727118.html 昨天去客户那里测试,需求才开始,所以很简单,就是测一下能不能接受到视频或图片,然后保存下来,现场客 ...
- C#实现foreach
方法:一.继承既有的接口 如:CollectionBase.DictionaryBase class TestForeach: CollectionBase { public void Add(str ...
- OAF_OAF组件系列1 - Item Style汇总(概念)
20150506 Created By BaoXinjian
- TCP/IP具体解释学习笔记--TCP数据流
1.TCP的交互数据流 (1)基本概念 所谓交互数据流,其对TCP而言,就是他们所产生的大多数的TCP报文段中所包括的数据不超过10个字节.比如聊天等telnet的软件的TCP数据流就属于TCP交互数 ...
- Tree通用的系列方法列表-treepanel
在项目中经常会用到Tree来显示数据进行操作.今天整理出来一系列操作Tree的方法.可供项目中方便调用.不用重复写代码,快速应用,通用性很强. Tree系列方法列表如下:主要针对的是ext.net中的 ...
- 利用eChart绘制网页图表
首先,最好的教程在这里:eCchart eChart所需JS: echarts.min.js china.js echarts.js 页面代码如下: 一.图表 <!DOCTYPE html> ...
- GM11灰色模型
作者:桂. 时间:2017-08-12 08:34:06 链接:http://www.cnblogs.com/xingshansi/p/7348714.html 前言 灰色模型(Gray model ...
- 啸叫抑制(howling suppression)
作者:桂. 时间:2017-05-16 链接:http://www.cnblogs.com/xingshansi/p/6862683.html 前言 下午看到群里讨论有人提到这个问题,记录一下. 一. ...