目录
动静分离,通过中间件将动静分离和静态请求进行分离; 通过中间件将动态请求和静态请求分离,可以建上不必要的请求消耗,同事能减少请求的延时。 通过中间件将动态请求和静态请求分离,逻辑图如下:
动静分离只有好处:动静分离后,即使动态服务不可用,但静态资源不会受到影响。
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; .....}
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;
[root@web01 ~]# cd /etc/nginx/conf.d/[root@web01 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; }}#配置一个主页[root@web01 conf.d]# echo "zls_test_web01" > /code/index.html#创建图片目录[root@web01 conf.d]# mkdir /code/images/#上传一个静态文件[root@web01 conf.d]# cd /code/images/[root@web01 images]# rz cjk.gif[root@web01 conf.d]# nginx -tnginx: the configuration file /etc/nginx/nginx.conf syntax is oknginx: configuration file /etc/nginx/nginx.conf test is successful[root@web01 conf.d]# nginx -s reload
[root@web01 ~]# cd /etc/nginx/conf.d/
[root@web01 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;
#配置一个主页
[root@web01 conf.d]# echo "zls_test_web01" > /code/index.html
#创建图片目录
[root@web01 conf.d]# mkdir /code/images/
#上传一个静态文件
[root@web01 conf.d]# cd /code/images/
[root@web01 images]# rz cjk.gif
[root@web01 conf.d]# nginx -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
[root@web01 conf.d]# nginx -s reload
打开浏览器访问:http://pic.drz.com/
打开浏览器访问:http://pic.drz.com/cjk.gif
[root@web02 ~]# yum install -y tomcat[root@web02 ~]# mkdir /usr/share/tomcat/webapps/ROOT[root@web02 ~]# 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>[root@web02 webapps]# systemctl start tomcat
[root@web02 ~]# yum install -y tomcat
[root@web02 ~]# mkdir /usr/share/tomcat/webapps/ROOT
[root@web02 ~]# 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>
[root@web02 webapps]# systemctl start tomcat
打开浏览器,访问:http://10.0.0.8:8080/java_test.jsp
?
[root@lb01 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; }}[root@lb01 conf.d]# nginx -tnginx: the configuration file /etc/nginx/nginx.conf syntax is oknginx: configuration file /etc/nginx/nginx.conf test is successful[root@lb01 conf.d]# nginx -s reload
[root@lb01 conf.d]# cat proxy_ds.conf
upstream static {
server 172.16.1.7:80;
upstream java {
server 172.16.1.8:8080;
location ~* \.(jpg|png|gif)$ {
proxy_pass http://static;
proxy_set_header Host $http_host;
location ~ \.jsp {
proxy_pass http://java;
[root@lb01 conf.d]# nginx -t
[root@lb01 conf.d]# nginx -s reload
2.5 配置本地hosts,通过负载访问动态与静态资源 动态资源 ↓
静态资源 ↓
网站主页 ↓
#编辑配置文件[root@lb01 ~]# 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; }}[root@lb01 ~]# mkdir -p /code#编辑整合后的index.html[root@lb01 ~]# 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>
#编辑配置文件
[root@lb01 ~]# cat /etc/nginx/conf.d/proxy_ds.conf
[root@lb01 ~]# mkdir -p /code
#编辑整合后的index.html
[root@lb01 ~]# 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通过负载均衡实现手机与PC调度至不通的后端节点应用案例
1.配置后端WEB节点的Nginx配置
[root@web01 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; }}
[root@web01 conf.d]# vim sj.conf
listen 9090;
root /code/android;
listen 9091;
root /code/iphone;
listen 9092;
root /code/pc;
2.为后端WEB节点配置对应的网站目录及代码
[root@web01 conf.d]# mkdir /code/{android,iphone,pc}[root@web01 conf.d]# echo "我是安卓" > /code/android/index.html[root@web01 conf.d]# echo "我是iphone" > /code/iphone/index.html[root@web01 conf.d]# echo "我是computer" > /code/pc/index.html
[root@web01 conf.d]# mkdir /code/{android,iphone,pc}
[root@web01 conf.d]# echo "我是安卓" > /code/android/index.html
[root@web01 conf.d]# echo "我是iphone" > /code/iphone/index.html
[root@web01 conf.d]# echo "我是computer" > /code/pc/index.html
3.配置负载均衡服务,根据不同的浏览器调度到不同的资源地
[root@lb01 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; }}
[root@lb01 conf.d]# vim /etc/nginx/conf.d/proxy_sj.conf
upstream android {
server 172.16.1.7:9090;
upstream iphone {
server 172.16.1.7:9091;
upstream pc {
server 172.16.1.7:9092;
server_name sj.drz.com;
charset 'utf-8';
#如果客户端来源是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.使用浏览器访问,查看结果
server { listen 80; server_name www.drz.com; if ($http_user_agent ~* "Android|Iphone") { #修改负载,wel上也改 rewrite ^/$ https://sj.drz.com redirect; } }
server_name www.drz.com;
if ($http_user_agent ~* "Android|Iphone") { #修改负载,wel上也改
rewrite ^/$ https://sj.drz.com redirect;
原文链接:http://www.cnblogs.com/1naonao/p/11426461.html
本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728