1.什么是动静分离?

将动态请求和静态请求区分访问,

2.为什么要做动静分离?

静态由Nginx处理, 动态由PHP处理或Tomcat处理....
因为Tomcat程序本身是用来处理jsp代码的,但tomcat也能处理静态资源.
tomcat本身处理静态效率不高,还会带来资源开销.

3.如何实现动静分离?

Nginx根据客户端请求的url来判断请求的是否是静态资源,如果请求的url包含jpg、png,则由Nginx处理。
如果请求的url是.php或者.jsp等等,这个时候这个请求是动态的,将转发给tomcat处理。 总结来说,Nginx是通过url来区分请求的类型,并转发给不同的服务端。

4.单机实现动静分离实战

1.安装  【 tomcat监听在8080端口】
[root@web01 ~]# yum install java tomcat -y 2.创建主站点目录
[root@web01 ~]# mkdir /usr/share/tomcat/webapps/ROOT -->主要站点根目录 3.写入jsp代码
[root@web01 ~]# vi /usr/share/tomcat/webapps/ROOT/index.jsp
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<html>
<head>
<title>Nginx+Tomcat</title>
</head>
<body>
<%
Random rand = new Random();
out.println("<h2>动态资源</h2>");
out.println(rand.nextInt(99)+100);
%>
<h2>静态图片</h2>
<img src="nginx.png" />
</body>
</html>
4.下载图片至站点目录
[root@web01 ~]# wget -O /usr/share/tomcat/webapps/ROOT/nginx.png http://nginx.org/nginx.png
5.重启tomcat服务
[root@web01 ~]# systemctl start tomcat
6.浏览器输入10.0.0.7测试验证

4.1配置Nginx 实现动静分离

[root@web01 conf.d]# cat ds.cheng.com.conf
server {
listen 80;
server_name ds.cheng.com; location / {
proxy_pass http://127.0.0.1:8080;
} location ~*\.(png|gif|jpg|mp4)$ {
root /images;
expires 1d;
}
}

5.集群实现动静分离实战

1.停止10.0.0.7nginx服务
[root@web01 conf.d]# systemctl stop nginx
2.10.0.0.8操作
[root@web02 conf.d]# cat ds.cheng.com.conf
server {
listen 80;
server_name ds.cheng.com;
expires 2d; location / {
root /images;
}
} 3.创建静态资源存放的路径以及上传图片
[root@web02 ~]# mkdir /images/ 4. 负载配置:
[root@lb01 conf.d]# cat proxy_ds.cheng.com.conf
upstream java {
server 172.16.1.7:8080;
} upstream static {
server 172.16.1.8:80;
} server {
listen 80;
server_name ds.cheng.com; location / {
proxy_pass http://java;
include proxy_params;
} location ~* \.(png|jpg|gif|jpeg)$ {
proxy_pass http://static;
expires 2d;
include proxy_params;
}
}

6.本章课程内容大纲

1.什么是Rewrite?

2.Rewrite使用场景?

3.Rewrite实现原理?

4.Rewrite URL重写配置场景?

10案例

5.Rewrite URL重写falg标记?

6.Rewrite URL重写生产实践?

1.set设置变量

1.将用户请求的url.cheng.com.cn重定向到url.cheng.com/zh
[root@web01 conf.d]# cat url.cheng.com.conf
server {
listen 80;
server_name url.cheng.com.cn; set $language zh;
rewrite ^/$ http://url.cheng.com/$language/; } server {
listen 80;
server_name url.cheng.com; location / {
root /data;
} } [root@web01 conf.d]# mkdir -p /data/{zh,jp,en}
[root@web01 conf.d]# echo "zh" > /data/zh/index.html
[root@web01 conf.d]# echo "jp"> /data/jp/index.html
[root@web01 conf.d]# echo "en"> /data/en/index.html
重启服务
[root@web01 conf.d]# nginx -t
[root@web01 conf.d]# systemctl restart nginx
域名解析
10.0.0.7 url.cheng.com url.cheng.com.cn 测试【通过域名来实现跳转效果】

2.set结合if示例

1.将用户请求的url.cheng.com.jp跳转至url.cheng.com/ip
[root@web01 conf.d]# cat url.cheng.com.conf
server {
listen 80;
server_name url.cheng.com.cn url.cheng.com.jp; #判断
if ($http_host ~* cn) {
set $language zh;
}
if ($http_host ~* jp) {
set $language jp;
} rewrite ^/$ http://url.cheng.com/$language/; } server {
listen 80;
server_name url.cheng.com; location / {
root /data;
} }
域名解析: 2.根据用户浏览器使用的语言,自动判断并跳转至不同的语言界面
中国 url.cheng.com ---> url.cheng.com --->中文
english url.cheng.com ---> url.cheng.com --->english [root@web01 conf.d]# cat url.cheng.com.conf
server {
listen 80;
server_name url.cheng.com; location / {
if ($http_accept_language ~* "en") {
set $language en;
} if ($http_accept_language ~* "zh|zh-CN") {
set $language zh;
} root /data/$language;
} } 3.nginx过滤请求中包含a1=3526的http请求到10.0.0.7的8080端口处理
[root@web01 conf.d]# cat url.cheng.com.conf
server {
listen 80;
server_name url.cheng.com; location / {
default_type text/html;
if ($request_uri ~* "a1=3526") {
return 200 "OK";
} if ($http_accept_language ~* "en") {
set $language en;
} if ($http_accept_language ~* "zh|zh-CN") {
set $language zh;
} root /data/$language;
} } 浏览器输入url.cheng.com/?a1=3526 进行测试!

3.return案例

[root@web01 conf.d]# cat url.cheng.com.conf
server {
listen 80;
server_name url.cheng.com; location / {
default_type text/html;
if ($request_uri ~* "a1=3526") { ---->一场景
return 200 "https://www.jd.com";
} if ($request_uri ~* "git") { ---->二场景
return 403;
} if ($request_uri ~* "^/test") { ---->三场景
return 302 "https://www.jd.com";
} if ($http_accept_language ~* "en") {
set $language en;
} if ($http_accept_language ~* "zh|zh-CN") {
set $language zh;
} root /data/$language;
} }

4.break案例

[root@web01 conf.d]# cat url.cheng.com.conf
server {
listen 80;
server_name url.cheng.com;
root /code; location / {
rewrite /1.html /2.html
break;
rewrite /2.html /3.html;
} location /2.html {
rewrite /2.html /a.html;
} location /3.html {
rewrite /3.html /b.html;
}
} [root@web01]# echo "1.html" >/code/1.html
[root@web01]# echo "2.html" >/code/2.html
[root@web01]# echo "3.html" >/code/3.html
[root@web01]# echo "a.html" >/code/a.html
[root@web01]# echo "b.html" >/code/b.html
测试结果:当请求/1.html,最终会访问/2.html
因为在location{ }内部,遇到break,本location{ }内以及后面的所有location{ }内的所有指令都不在执行
set
if
return
状态码
状态码 字符串
状态码 URL 301 302
break
停止后续操作:
rewrite 关键字 正则 替代内容 flag标记
Syntax: rewrite regex replacement [flag]; 跳转 :
重定向:
#flag
last #本条规则匹配完成后,继续向下匹配新的location URI规则 (开发| 伪静态)
break #本条规则匹配完成即终止,不再匹配后面的任何规则 (挂维护页)
redirect #返回302临时重定向, 地址栏会显示跳转后的地址
permanent #返回301永久重定向, 地址栏会显示跳转后的地址
中国 url.cheng.com ---> url.cheng.com/zh --->中文
english url.cheng.com ---> url.cheng.com/cn --->english

5.rewrite案例一[根据浏览器不同的语言跳转至不同的域名]

[root@web01 conf.d]# cat url.cheng.com.conf
server {
listen 80;
server_name url.cheng.com;
root /data; set $language /default;
if ($http_accept_language ~* zh) {
set $language /zh;
}
if ($http_accept_language ~* en) {
set $language /en;
}
if ($http_accept_language ~* ja) {
set $language /jp;
} rewrite ^/$ $language; location / {
index index.html;
}
}

6.永久维护

[root@web01 conf.d]# cat url.cheng.com.conf
server {
listen 80;
server_name url.cheng.com;
root /data; rewrite ^(.*)$ /wh.png break;
set $language /default;
if ($http_accept_language ~* zh) {
set $language /zh;
}
if ($http_accept_language ~* en) {
set $language /en;
}
if ($http_accept_language ~* ja) {
set $language /jp;
} rewrite ^/$ $language; location / {
index index.html;
}
}

7.临时维护(跳转至指定的域名)

[root@web01 conf.d]# cat url.cheng.com.conf
server {
listen 80;
server_name url.cheng.com;
root /data; set $language /default;
if ($http_accept_language ~* zh) {
set $language /zh;
}
if ($http_accept_language ~* en) {
set $language /en;
}
if ($http_accept_language ~* ja) {
set $language /jp;
} rewrite ^/$ $language; location / {
index index.html;
} #error_page 403 404 500 502 /wh.png;
#error_page 403 404 500 502 $http_host; error_page 403 404 500 502 @temperror; location @temperror {
rewrite ^(.*)$ http://yinwucheng.com;
} }

8.需求: 用户通过手机设备访问url.cheng.com,跳转至url.cheng.com/m

server {
listen 80;
server_name url.cheng.com;
root /data; if ($http_user_agent ~* "android|iphone|ipad") {
rewrite ^/$ /m;
}
}

9.需求: 用户通过手机设备访问url.cheng.com,跳转至m.cheng.com

server {
listen 80;
server_name url.cheng.com;
root /data; if ($http_user_agent ~* "android|iphone|ipad") {
rewrite ^/$ http://m.cheng.com;
}
}
server {
listen 80;
server_name m.cheng.com;
root /data/m; location / {
index index.html;
}
}

10.需求: 用户访问cheng.com/test,跳转至https://xuliangwei.com

location方法:
location /test {
#rewrite ^(.*)$ https://www.xuliangwei.com/;
return 302 https://www.xuliangwei.com/;
}
if方法:
server {
listen 80;
server_name url.cheng.com;
root /data; if ($request_uri ~* "^/test") {
#rewrite ^(.*)$ https://www.xuliangwei.com/;
return 302 https://www.xuliangwei.com/;
}
location / {
index index.html;
}
}

11.http协议跳转至https协议

return 302 https://$http_host$request_uri;

11.rewrite场景示例: 开发

需求: 用户访问course-11-22-33.html实际上真实访问是/course/11/22/33/course_33.html
[root@web01 conf.d]# cat url.cheng.com.conf
server {
listen 80;
server_name url.cheng.com;
root /data;
location / {
index index.html;
#用户访问的url #文件真实位置
rewrite ^/(.*)-(.*)-(.*)-(.*).html /$1/$2/$3/$4/$1_$4.html;
}
}

15.Nginx动静分离Rewrite的更多相关文章

  1. Nginx系列二:(Nginx Rewrite 规则、Nginx 防盗链、Nginx 动静分离、Nginx+keepalived 实现高可用)

    一.Nginx Rewrite 规则 1. Nginx rewrite规则 Rewrite规则含义就是某个URL重写成特定的URL(类似于Redirect),从某种意义上说为了美观或者对搜索引擎友好, ...

  2. 15、Nginx动静分离实战

    1.Nginx动静分离基本概述 动静分离, 通过中间件将动静分离和静态请求进行分离. 那为什么要通过中间件将动态请求和静态请求进行分离? 减少不必要的请求消耗, 同时能减少请求的延时. 通过中间件将动 ...

  3. Nginx动静分离经典

    Nginx:安装nginx之前需要安装pcre包和zlib以支持重写,正则以及网页压缩等等]把所需的包下载到/usr/src下[根据自己的习惯,路径可以改变]1.首先安装pcre: cd /usr/s ...

  4. Nginx动静分离知识及配置

    Nginx动静分离知识及配置,本质上与分离上传下载功能是相同功能,本质就是在文件服务器也是需要部署WEB应用的,只是在进行代理分离的时候分配到对应的文件服务器上去. 随着Nginx高性能Web服务器大 ...

  5. Nginx动静分离经典案例配置

    随着Nginx高性能Web服务器大量被使用,目前Nginx最新稳定版为1.2.6,张宴兄在实际应用中大量使用Nginx,并分享Nginx高性能Web服务器知识,使得Nginx在国内也是飞速的发展.那今 ...

  6. Nginx动静分离(Nginx+Tomcat)

    第一步:nginx构建 第二步:Tomcat构建 1.Tomcat基础点 (1)Tomcat 是基于java开发的web容器,用来发布java代码和jsp网页. (2)开发人员开发java web网站 ...

  7. Nginx动静分离基本概述

    Nginx动静分离基本概述 动静分离,通过中间将动静分离和静态请求进行分离: 通过中间件将动态请求和静态请求分离,可以建上不必要的请求消耗,同时能减少请求的延时. 通过中间件将动态请求和静态请求分离, ...

  8. Nginx动静分离实现

    Nginx动静分离实现: Nginx是一种轻量级,高性能,多进程的Web服务器,非常适合作为静态资源的服务器使用,而动态的访问操作可以使用稳定的Apache.Tomcat及IIS等来实现,这里就以Ng ...

  9. Nginx动静分离架构

    Nginx动静分离简单来说就将动态与静态资源分开,不能理解成只是单纯的把动态页面和静态页面物理分离,严格意义上说应该是动态请求跟静态请求分开,可以理解成使用Nginx处理静态页面,Tomcat,Res ...

随机推荐

  1. 一次容器化springboot程序OOM问题探险

    背景 运维人员反馈一个容器化的java程序每跑一段时间就会出现OOM问题,重启后,间隔大概两天后复现. 问题调查 一查日志 由于是容器化部署的程序,登上主机后使用docker logs Contain ...

  2. LINUX下搭建简单临时的WWW服务器

    首先确定是否安装有python: python -V 如果有: cd 到你要开放的文件夹中,然后使用下面的命令可以把 当前文件夹内的所有文件 发布到 8000 端口. python -m Simple ...

  3. ogeek线下赛web分析1-python-web

    1.python from flask import Flask, request, render_template,send_from_directory, make_response from A ...

  4. jqGrid 日期格式化,只显示日期,去掉小时分

    {name:'operateTime',index:'operateTime', formatter:"date", formatoptions: {newformat:'Y-m- ...

  5. 从 HTTP/1 到 HTTP/2,以及即将到来的 HTTP/3

    如今的生活中已经离不开互联网,智能家居.在线支付.网上购物都需要互联网的支持.互联网切切实实地给生活带来了诸多便利.有了互联网,我们可以呆在空调房里,一边刷着微博,一边等透心凉的西瓜送到手上,安安静静 ...

  6. BeanFactory not initialized or already closed

    产生这个错误有两个可能, 一.你没有配置初始化文件,在web.xml中配置如下 <context-param> <param-name>contextConfigLocatio ...

  7. 1.html基础知识

    1.html定义: html是一种超文本标记语言,“超文本”是指页面可以包含图片.链接.音乐.程序等非文字元素. Html不是一种编程语言. 2.html5的新特性: 用于绘画的canvas元素: 用 ...

  8. c3p0配置记录

    官方文档 : http://www.mchange.com/projects/c3p0/index.html <!--当连接池中的连接耗尽的时候c3p0一次同时获取的连接数.Default: 3 ...

  9. 使用apache的poi来实现数据导出到excel的功能——方式二

    此次,介绍利用poi与layui table结合导出excel.这次不需要从数据库中查询出来的数据进行每一行的拼接那么麻烦,我们这次将标题定义一个id值,对应从数据库中查找出来的字段名即可. 1.po ...

  10. jobs后台任务

    前台作业:占据了命令提示符,就是你当前可以操作的作业后台作业:启动之后,释放命令提示符,后续的操作在后台完成 前台——>后台 ctrl+z:把正在前台的作业送往后台,这时作业的状态是暂停. CO ...