Nginx动静分离经典案例配置
随着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:
- #安装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 ,并写入如下内容:
- 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_vary 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=1 max_fails=2 fail_timeout=30s;
- server 10.10.141.30:8081 weight=1 max_fails=2 fail_timeout=30s;
- server 10.10.141.31:8080 weight=1 max_fails=2 fail_timeout=30s;
- server 10.10.141.31:8081 weight=1 max_fails=2 fail_timeout=30s;
- server 10.10.141.32:8080 weight=1 max_fails=2 fail_timeout=30s;
- server 10.10.141.32:8081 weight=1 max_fails=2 fail_timeout=30s;
- }
- #这里为后端APP应用负载均衡配置,根据后端实际情况修改即可。tdt_app为负载均衡名称,可以任意指定
- upstream tdt_app {
- server 10.10.141.40:8080 weight=1 max_fails=2 fail_timeout=30s;
- server 10.10.141.40:8081 weight=1 max_fails=2 fail_timeout=30s;
- server 10.10.141.41:8080 weight=1 max_fails=2 fail_timeout=30s;
- server 10.10.141.41:8081 weight=1 max_fails=2 fail_timeout=30s;
- server 10.10.141.42:8080 weight=1 max_fails=2 fail_timeout=30s;
- server 10.10.141.42:8081 weight=1 max_fails=2 fail_timeout=30s;
- }
- #include引用vhosts.conf,该文件主要用于配置Nginx 虚拟主机
- include vhosts.conf;
- }
如上nginx.conf配置完毕,继续配置nginx虚拟主机,继续在当前目录创建vhosts.conf
vi vhosts.conf 内容如下:
- ####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做服务端自动同步。
- #检查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
本文只是一个简单的实际案例,里面的配置和参数这里没有做过多的说明,后期会继续更新。
本文出自 “烟雨楼台” 博客,请务必保留此出处http://wgkgood.blog.51cto.com/1192594/1094236
Nginx动静分离经典案例配置相关推荐
- nginx动静分离配置_Nginx 动静分离与负载均衡的实现
一.前提 企业中,随着用户的增长,数据量也几乎成几何增长,数据越来越大,随之也就出现了各种应用的瓶颈问题. 问题出现了,我们就得想办法解决,一般网站环境,均会使用LAMP或者LNMP,而我们对于网站环 ...
- nginx动静分离配置_Nginx动静分离配置实例
点击▲关注 "长安大司马" 给公众号标星置顶 更多精彩 第一时间直达 父亲节快乐 HAPPY FATHER'S DAY 1 .什么是动静分离 Nginx 动静分离简单来说就是把 ...
- Nginx动静分离配置
Nginx动静分离 一.动静分离介绍 动静分离,通过中间件将动态请求和静态请求进行分离 通过中间件将动态请求和静态请求分离,可以减少不必要的请求消耗,同时能减少请求的延时. 通过中间件将动态请求和静态 ...
- Nginx动静分离技术(配置步骤)
目录 1. 项目前后端联调时,使用 Nginx动静分离技术 来实现报告的展示 2. nginx 常用命令 3. 配置域名:涉及两个配置文件hosts, nginx.conf 3.1 修改win10系统 ...
- 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文件中解析的主机名都 ...
- HAproxy负载均衡动静分离实现及配置详解
HAproxy负载均衡动静分离实现及配置详解 HAproxy的介绍 HAProxy提供高可用性.负载均衡以及基于TCP和HTTP应用的代理,支持虚拟主机,它是免费.快速并且可靠的一种解决方案.HAP ...
- Nginx 动静分离 -02
Nginx 动静分离 ---- --------切记 10.10.0.7 一.单台机器动静分离 [root@web01 ~]# cat /etc/nginx/conf.d/linux12.wp.com ...
最新文章
- 构建可扩展的GPU加速应用程序(NVIDIA HPC)
- 提高IIS网站服务器的效率的八种方法 (转载)
- 安装phpredis扩展以及phpRedisAdmin工具
- dynamic_cast详解
- Qt笔记-Linux程序打印带颜色的字符串
- web全栈架构师所需技术栈_统一架构–一种构建全栈应用程序的简单方法
- Windows界面编程_Miniblink(6) 个人信息界面
- Google搜索命令语法大全
- 学习双拼必看:双拼输入法的心得以及快速入门办法
- 品牌笔记本主板刷BIOS升级NVME ssd启动系统
- Arithmetic Code 算术编码
- 职业能力倾向测试下什么软件,职业能力倾向测验
- excel怎么设置自动计算_Excel财务表格大全!公式已设置好,数据自动计算产生...
- 指南-Luat二次开发教程指南-第一个Luat程序
- SQL SERVER 软件和安装步骤
- 50首最好听的英文歌
- [DSP 日常记录] #2 TI DSP 的简单介绍与 DSP 的一些名词解释
- 干了两晚,带你探索那讲不清的字符串
- 怎么用手机和电脑同时预览PS设计稿
- OpenWrt固件构建快速入门