中间件 | Nginx实现动静分离

Nginx动静分离基本概述

动静分离,通过中间件将动静分离和静态请求进行分离;

通过中间件将动态请求和静态请求分离,可以建上不必要的请求消耗,同事能减少请求的延时。

通过中间件将动态请求和静态请求分离,逻辑图如下:

?动静分离只有好处:动静分离后,即使动态服务不可用,但静态资源不会受到影响。

Nginx动静分离场景实践

单台服务器实现动静分离

location / { root /code/wordpress; index.php;}location ~* \.(png|jpg|mp4|)${ root /code/wordpress/images; gzip on; .....}location ~ \.php$ { fastcgi_pass 127.0.0.1:9000; .....}


多台服务器实现动静分离

?



环境准备系统作用服务地址Centos7.5负载均衡nginx proxy10.0.0.5Centos7.5静态资源nginx static10.0.0.7Centos7.5动态资源tomcat server10.0.0.8

web01配置静态资源

[[email protected] ~]# cd /etc/nginx/conf.d/[[email protected] conf.d]# cat ds_oldboy.conf server { listen 80; server_name pic.drz.com; root /code; index index.html; location ~* .*\.(jpg|png|gif)$ { root /code/images; }}#配置一个主页[[email protected] conf.d]# echo "zls_test_web01" > /code/index.html#创建图片目录[[email protected] conf.d]# mkdir /code/images/#上传一个静态文件[[email protected] conf.d]# cd /code/images/[[email protected] images]# rz cjk.gif[[email protected] conf.d]# nginx -tnginx: the configuration file /etc/nginx/nginx.conf syntax is oknginx: configuration file /etc/nginx/nginx.conf test is successful[[email protected] conf.d]# nginx -s reload


验证

打开浏览器访问:http://pic.drz.com/

?

打开浏览器访问:http://pic.drz.com/cjk.gif

?



web02配置动态资源

[[email protected] ~]# yum install -y tomcat[[email protected] ~]# mkdir /usr/share/tomcat/webapps/ROOT[[email protected] ~]# cat /usr/share/tomcat/webapps/ROOT/java_test.jsp<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%><HTML> <HEAD> <TITLE>曾老湿JSP Page</TITLE> </HEAD> <BODY> <% Random rand = new Random(); out.println("<h1>曾老湿随机数:<h1>"); out.println(rand.nextInt(99)+100); %> </BODY></HTML>[[email protected] webapps]# systemctl start tomcat

打开浏览器,访问:http://10.0.0.8:8080/java_test.jsp

?



负载均衡上调度

[[email protected] conf.d]# cat proxy_ds.conf upstream static { server 172.16.1.7:80;}upstream java { server 172.16.1.8:8080;}server { listen 80; server_name pic.drz.com; location ~* \.(jpg|png|gif)$ { proxy_pass http://static; proxy_set_header Host $http_host; } location ~ \.jsp { proxy_pass http://java; proxy_set_header Host $http_host; }}[[email protected] conf.d]# nginx -tnginx: the configuration file /etc/nginx/nginx.conf syntax is oknginx: configuration file /etc/nginx/nginx.conf test is successful[[email protected] conf.d]# nginx -s reload

2.5 配置本地hosts,通过负载访问动态与静态资源

动态资源 ↓

?

静态资源 ↓

?

网站主页 ↓

?



负载均衡上整合动态和静态的html文件

#编辑配置文件[[email protected] ~]# cat /etc/nginx/conf.d/proxy_ds.confupstream static { server 172.16.1.7:80;}upstream java { server 172.16.1.8:8080;}server { listen 80; server_name pic.drz.com;

 location / { root /code; index index.html; }

 location ~* \.(jpg|png|gif)$ { proxy_pass http://static; proxy_set_header Host $http_host; } location ~ \.jsp { proxy_pass http://java; proxy_set_header Host $http_host; }}[[email protected] ~]# mkdir -p /code#编辑整合后的index.html[[email protected] ~]# cat /code/index.html<html lang="en"><head> <meta charset="UTF-8" /> <title>曾老湿测试ajax和跨域访问</title> <script src="http://libs.baidu.com/jquery/2.1.4/jquery.min.js"></script></head><script type="text/javascript">$(document).ready(function(){ $.ajax({ type: "GET", url: "http://pic.drz.com/java_test.jsp", success: function(data){ $("#get_data").html(data) }, error: function() { alert("哎呦喂,失败了,回去检查你服务去~"); } });});</script> <body> <h1>曾老湿带你测试动静分离</h1> <img src="http://pic.drz.com/cjk.gif"> <div id="get_data"></div> </body></html>


浏览访问测试动静分离是否能成功

?

可以尝试关掉静态或者动态的服务,测试是否互不影响

Nginx资源分离场景实践

Nginx通过负载均衡实现手机与PC调度至不通的后端节点应用案例



根据Iphone、安卓、pc跳转不通的页面环境规划系统版本主机角色外网IP内网IP提供端口CentOS7.5负载均衡10.0.0.5172.16.1.580CentOS7.5提供Android页面172.16.1.79090CentOS7.5提供Iphone页面172.16.1.79091CentOS7.5提供pc页面172.16.1.79092

1.配置后端WEB节点的Nginx配置

[[email protected] conf.d]# vim sj.confserver { listen 9090; location / { root /code/android; index index.html; }}server { listen 9091; location / { root /code/iphone; index index.html; }}server { listen 9092; location / { root /code/pc; index index.html; }}

2.为后端WEB节点配置对应的网站目录及代码

[[email protected] conf.d]# mkdir /code/{android,iphone,pc}[[email protected] conf.d]# echo "我是安卓" > /code/android/index.html[[email protected] conf.d]# echo "我是iphone" > /code/iphone/index.html[[email protected] conf.d]# echo "我是computer" > /code/pc/index.html

3.配置负载均衡服务,根据不同的浏览器调度到不同的资源地

[[email protected] conf.d]# vim /etc/nginx/conf.d/proxy_sj.confupstream android { server 172.16.1.7:9090;}upstream iphone { server 172.16.1.7:9091;}upstream pc { server 172.16.1.7:9092;}server { listen 80; server_name sj.drz.com; charset ‘utf-8‘; location / { #如果客户端来源是Android则跳转到Android的资源; if ($http_user_agent ~* "Android") { proxy_pass http://android; } #如果客户端来源是Iphone则跳转到Iphone的资源; if ($http_user_agent ~* "Iphone") { proxy_pass http://iphone; } #如果客户端是IE浏览器则返回403错误; if ($http_user_agent ~* "MSIE") { return 403; } #默认跳转pc资源; proxy_pass http://pc; }}

4.使用浏览器访问,查看结果

PC端访问

?



浏览器模拟IPhone

?



浏览器模拟Android

?



实际线上的配置

server { listen 80; server_name www.drz.com; if ($http_user_agent ~* "Android|Iphone") { rewrite ^/$ https://sj.drz.com redirect; } }

原文地址:https://www.cnblogs.com/wyf0518/p/11456837.html

时间: 2024-11-06 12:39:05

中间件 | Nginx实现动静分离的相关文章

Docker构建Nginx+Tomcat动静分离架构

随着主流Nginx WEB服务器的发展,现在基于Nginx的WEB服务器已广泛应用于各大互联网企业.今天我们来使用docker构建我们的Linux+Nginx+Tomcat动静分离服务器. 1)    启动docker镜像 查看当前系统存在的镜像,我这里为centos6.6,大家可以参考我第一篇文章进行下载相应的镜像文件,然后启动. 启动方式如下:   docker run -i -t  centos6.6:v2 /bin/bash 然后进入新的docker容器里,查看ip为172.17.0.6

Nginx+Apache动静分离

Nginx的静态处理能力很强,但是动态处理能力不足,因此,在企业中常用动静分离技术. 针对PHP的动静分离:静态页面交给Nginx处理,动态页面交给PHP-FPM模块或Apache处理. 在Nginx的配置中,是通过location配置段配合正则匹配实现静态与动态页面的不同处理方式 一.Nginx正则匹配 常用的正则匹配规则 ^~ : 标识符后面跟一个字符串.Nginx将在这个字符串匹配后停止进行正则表达式的匹配,如 location  ^~ /images/,它在匹配了/images/这个字符

Linux深入篇之四:构建Nginx+Tomcat动静分离架构

Linux深入篇之四:构建Nginx+Tomcat动静分离架构 Nginx动静分离简单来说就是把动态跟静态请求分开,不能理解成只是单纯的把动态页面和静态页面物理分离.严格意义上说应该是:动态请求跟静态请求分开,可以理解成使用Nginx处理静态页面,Tomcat.Resin处理动态页面. 动静分离从目前实现角度来讲大致分为两种: 一种是纯粹的把静态文件独立成单独的域名,放在独立的服务器上,也是目前主流推崇的方案: 另外一种方法就是动态跟静态文件混合在一起发布,通过nginx来分开. 具体怎么来实现

nginx+tomcat动静分离结构

本文采用另一种策略对动静分离进行演示,它的大致结构如图 2 所示. 图 2. 本文设计的动静分离结构 在本文中,我们将静态资源放在 A 主机的一个目录上,将动态程序放在 B 主机上,同时在 A 上安装 Nginx 并且在 B 上安装 Tomcat.配置 Nginx,当请求的是 html.jpg 等静态资源时,就访问 A 主机上的静态资源目录:当用户提出动态资源的请求时,则将请求转发到后端的 B 服务器上,交由 Tomcat 处理,再由 Nginx 将结果返回给请求端. 提到这,可能有您会有疑问,

nginx实现动静分离负载均衡集群

LB 负载均衡集群分两类: LVS (四层)和 nginx 或 haproxy (七层) 客户端通过访问分发器的 VIP 来访问网站 | 现在应用更复杂,比如现在网站页面有: .php .html .png .jpeg .jsp 等, 有劢态页面有静 态页面.静态页面一般是丌变的,想访问更快些,前面学习过 SQUID. | 但是前面的 LVS 是四层的.基于 IP 的.现在需要在应用层基于丌同的应用迚行分发. | 七层 LB , Nginx / Haproxy 都可以支持 7 层 LB 现在实现

Nginx实现动静分离

一.简介 通过Nginx的动静分离技术,可以实现将服务器单独只提供一种页面,例如,一台web服务器专门提供图片,css,js等静态资源,另外的一台服务器专门处理例如.php,.jsp等动态处理的请求.这样可以减轻双方服务器的压力,同时又可以做到负载分担. 二.拓扑 三.配置实现 0.开启Nginx的路由转发  #vi  /etc/sysctl.conf    net.ipv4.ip_forward = 1  #sysctl  -p 配置Nginx的动静分离 #user  nobody; work

Nginx+Tomcat动静分离架构

Nginx+Tomcat动静分离架构 Nginx+tomcat是目前主流的java web架构,Nginx动静分离简单来说就是把动态跟静态请求分开,不能理解成只是单纯的把动态页面和静态页面物理分离.严格意义上说应该是动态请求跟静态请求分开,可以理解成使用Nginx处理静态页面,Tomcat.Resin出来动态页面. 动静分离从目前实现角度来讲大致分为两种,一种是纯粹的把静态文件独立成单独的域名,放在独立的服务器上,也是目前主流推崇的方案:另外一种方法就是动态跟静态文件混合在一起发布,通过ngin

Nginx系列-9.配置NFS实现Nginx实现动静分离

Nginx系列-9.配置NFS实现Nginx实现动静分离 目录 - Nginx系列 Nginx系列-1.Linux下安装Nginx Nginx系列-2.配置LNMP(Linux.Nginx.MySQL.PHP)架构 Nginx系列-3.配置Nginx虚拟主机 Nginx系列-4.Nginx日志配置及日志切割 Nginx系列-5.配置Nginx的防盗链 Nginx系列-6.配置Nginx的HTTPS Nginx系列-7.配置Nginx使用uwsgi支持web.py框架 Nginx系列-8.配置Ng

nginx 实现动静分离

nginx 实现动静分离 在生产环境中,nginx的图片相关的静态信息是存放在专用的存储服务器上,然后通过挂载让nginx来读取文件. server IP nginx 172.20.27.10 http1 172.20.27.20 http2 172.20.27.21 nfs 172.20.27.22 nginx 服务器做为反向代理来实现动静分离 nginx服务器配置 1.配置反向代理 [[email protected] ~]# mkdir /apps/nginx/conf/servers [