【运维知识进阶篇】集群架构-Nginx动静分离详解

简介: 【运维知识进阶篇】集群架构-Nginx动静分离详解

我们先前将静态资源放到NFS,动态资源放到MySQL,一是为了提高我们Web服务器性能,减轻它的压力,另一面如果Web宕机了,我们的静态和动态资源还可以访问到。但是之前方式不管是静态还是动态文件,都是走的代码文件,通过代码文件调取的资源,那么我们越过代码文件去访问我们的资源,效率不是更高吗,如果服务器没出问题,但是代码出了问题,我们依旧可以访问到我们的资源。

本篇文章介绍Nginx动静分离,通过中间件将动态请求和静态请求进行分离,减少不必要的请求和请求时长,这样做提升了服务器运行效率,即使动态服务不可用了,但是静态资源不会收到影响。

使用Web01配置静态资源的文件

1. [root@Web01 wordpress]# vim /etc/nginx/conf.d/jing.conf
2. server {
3.         listen 80;
4.         server_name jing.koten.com;
5.         root /code;
6. index index.html;
7. 
8. location ~* .*\.(jpg|png|gif)$ {
9.                 root /code/images;
10.         }
11. }
12. ~                                                  
13. ~                                                  
14. ~                                                  
15. ~                                                  
16. ~                                                  
17. ~                                                  
18. <g.conf" [New] 10L, 199C written 
19. [root@Web01 wordpress]# nginx -t
20. nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
21. nginx: configuration file /etc/nginx/nginx.conf test is successful
22. [root@Web01 wordpress]# systemctl restart nginx
23. [root@Web01 wordpress]# echo 'Web01' > /code/index.html
24. [root@Web01 wordpress]# mkdir /code/images/
25. [root@Web01 wordpress]# cd /code/images/
26. [root@Web01 images]# rz
27. 
28. [root@Web01 images]#

使用Web02配置动态资源的文件

1. [root@web02 ~]# yum install -y tomcat
2. [root@web02 ~]# mkdir /usr/share/tomcat/webapps/ROOT
3. [root@web02 ~]# cat /usr/share/tomcat/webapps/ROOT/java_test.jsp
4. <%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
5. <HTML>
6. <HEAD>
7. <TITLE>koten JSP Page</TITLE>
8. </HEAD>
9. <BODY>
10. <%
11. Random rand = new Random();
12.             out.println("<h1>随机数:<h1>");
13.             out.println(rand.nextInt(99)+100);
14.         %>
15. </BODY>
16. </HTML>
17. 
18. [root@web02 webapps]# systemctl start tomcat

LB01负载均衡上调度静态文件和动态文件的配置文件

1. [root@LB01 conf.d]# vim proxy_jingdong.conf 
2. upstream webs {
3.  server 172.16.1.7;
4. }
5. 
6. upstream static {
7.         server 172.16.1.7:80;
8. }
9. 
10. upstream java {
11.         server 172.16.1.8:8080;
12. }
13. 
14. server {
15.         listen 80;
16.         server_name jingdong.koten.com;
17. 
18.       location / {
19.         proxy_pass http://webs;
20.       }
21. 
22. location ~* \.(jpg|png|gif)$ {
23.                 proxy_pass http://static;
24.                 proxy_set_header Host $http_host;
25.         }
26. 
27. location ~ \.jsp {
28.                 proxy_pass http://java;
29.                 proxy_set_header Host $http_host;
30.         }
31. }
32. 
33. 
34. [root@lb01 conf.d]# nginx -t
35. nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
36. nginx: configuration file /etc/nginx/nginx.conf test is successful
37. [root@lb01 conf.d]# systemctl restart nginx

修改本地hosts后测试

修改LB01的配置文件并在LB01上整合动态和静态的html文件

1. [root@LB01 ~]# cat /etc/nginx/conf.d/proxy_jingdong.conf 
2. upstream static {
3.         server 172.16.1.7:80;
4. }
5. 
6. upstream java {
7.         server 172.16.1.8:8080;
8. }
9. 
10. server {
11.         listen 80;
12.         server_name jingdong.koten.com;
13. 
14.   location / {
15.     root /code;
16.     index index.html; 
17.   }
18. 
19. location ~* \.(jpg|png|gif)$ {
20.                 proxy_pass http://static;
21.                 proxy_set_header Host $http_host;
22.         }
23. 
24. location ~ \.jsp {
25.                 proxy_pass http://java;
26.                 proxy_set_header Host $http_host;
27.         }
28. }
29. [root@LB01 ~]# systemctl restart nginx
30. [root@LB01 ~]# cat /code/index.html
31. <html lang="en">
32. <head>
33. <meta charset="UTF-8" />
34. <title>测试ajax和跨域访问</title>
35. <script src="http://libs.baidu.com/jquery/2.1.4/jquery.min.js"></script>
36. </head>
37. <script type="text/javascript">
38. $(document).ready(function(){
39.         $.ajax({
40. type: "GET",
41.         url: "http://jingdong.koten.com/java_test.jsp",
42.         success: function(data){
43.                 $("#get_data").html(data)
44.         },
45. error: function() {
46.                 alert("哎呦喂,失败了,回去检查你服务去~");
47.         }
48.         });
49. });
50. </script>
51. <body>
52. <h1>测试动静分离</h1>
53. <img src="http://jingdong.koten.com/小兔.jpg">
54. <div id="get_data"></div>
55. </body>
56. </html>

动静分离测试

关闭Web01的静态资源服务,查看动态资源是否收到影响

[root@Web01 code]# systemctl stop nginx

 

关闭Web02的动态资源服务,查看静态资源是否收到影响

1. [root@Web01 code]# systemctl start nginx
2. [root@Web02 conf.d]# systemctl stop tomcat

Nginx负载均衡实现手机和PC调度至不同的后端节点

1、准备一台LB01(10.0.0.5、172.16.1.5)一台Web01(172.16.1.7)开发9090、9091、9092端口分别为安卓、苹果、电脑提供服务。

2、配置Web的Nginx文件

1. [root@Web01 ~]# cat /etc/nginx/conf.d/phone.conf
2. server {
3.         listen 9090;
4. location / {
5.                 root /code/android;
6. index index.html;
7.         }
8. }
9. 
10. server {
11.         listen 9091;
12. location / {
13.                 root /code/iphone;
14. index index.html;
15.         }
16. }
17. 
18. server {
19.         listen 9092;
20. location / {
21.                 root /code/pc;
22. index index.html;
23.         }
24. }
25. [root@Web01 ~]# systemctl restart nginx

3、在Web上创建对应网站目录及代码

1. [root@Web01 ~]# mkdir /code/{android,iphone,pc}
2. [root@Web01 ~]# echo '我是安卓' > /code/android/index.html
3. [root@Web01 ~]# echo '我是苹果' > /code/iphone/index.html
4. [root@Web01 ~]# echo '我是电脑' > /code/pc/index.html

4、配置负载均衡服务

1. [root@LB01 ~]# cat /etc/nginx/conf.d/proxy_phone.conf
2. upstream android {
3.         server 172.16.1.7:9090;
4. }
5. 
6. upstream iphone {
7.         server 172.16.1.7:9091;
8. }
9. 
10. upstream pc {
11.         server 172.16.1.7:9092;
12. }
13. 
14. server {
15.         listen 80;
16.         server_name phone.koten.com;
17.         charset 'utf-8';
18. 
19. location / {
20. 
21.                 #如果客户端来源是Android则跳转到Android的资源;
22. if ($http_user_agent ~* "Android") {    #只要是日志里的都可以进行判断
23.                         proxy_pass http://android;
24.                 }
25. 
26.                 #如果客户端来源是Iphone则跳转到Iphone的资源;
27. if ($http_user_agent ~* "Iphone") {
28.                         proxy_pass http://iphone;
29.                 }
30. 
31.                 #如果客户端是IE浏览器则返回403错误;
32. if ($http_user_agent ~* "Edg") {
33. return 403;
34.                 }
35. 
36.                 #默认跳转pc资源;
37.                 proxy_pass http://pc;
38.         }
39. }

也可以进行如下设置

1. server {
2.         listen 80;
3.         server_name   www.koten.com;
4. if ($http_user_agent ~* "Android|Iphone") {
5. rewrite ^/$ http://m.koten.com redirect;
6.         }       
7. }

5、用浏览器进行测试

电脑端

安卓端

苹果端

 


我是koten,10年运维经验,持续分享运维干货,感谢大家的阅读和关注!

目录
相关文章
|
5天前
|
存储 负载均衡 监控
揭秘 Elasticsearch 集群架构,解锁大数据处理神器
Elasticsearch 是一个强大的分布式搜索和分析引擎,广泛应用于大数据处理、实时搜索和分析。本文深入探讨了 Elasticsearch 集群的架构和特性,包括高可用性和负载均衡,以及主节点、数据节点、协调节点和 Ingest 节点的角色和功能。
16 0
|
1月前
|
人工智能 运维 网络架构
阿里云引领智算集群网络架构的新一轮变革
11月8日至10日,CCF ChinaNet(中国网络大会)在江苏张家港召开,众多院士、教授和技术领袖共聚一堂,探讨网络未来发展方向。阿里云研发副总裁蔡德忠发表主题演讲,展望智算技术发展趋势,提出智算网络架构变革的新思路,发布高通量以太网协议和ENode+超节点系统规划,引起广泛关注。阿里云HPN7.0引领智算以太网生态蓬勃发展,成为业界标杆。未来,X10规模的智算集群将面临新的挑战,Ethernet将成为主流方案,推动Scale up与Scale out的融合架构,提升整体系统性能。
|
1月前
|
存储 缓存 NoSQL
【赵渝强老师】Memcached集群的架构
Memcached 是一个高性能的分布式内存对象缓存系统,通过在内存中维护一个巨大的 Hash 表来存储各种格式的数据,如图像、视频、文件及数据库检索结果等。它主要用于减轻数据库压力,提高网站系统的性能。Memcached 不支持数据持久化,因此仅作为缓存技术使用。其数据分布式存储由客户端应用程序实现,而非服务端。
【赵渝强老师】Memcached集群的架构
|
1月前
|
调度 Docker 容器
【赵渝强老师】Docker Swarm集群的体系架构
Docker Swarm自1.12.0版本起集成至Docker引擎,无需单独安装。它内置服务发现功能,支持跨多服务器或宿主机创建容器,形成集群提供服务。相比之下,Docker Compose仅限于单个宿主机。Docker Swarm采用主从架构,Swarm Manager负责管理和调度集群中的容器资源,用户通过其接口发送指令,Swarm Node根据指令创建容器运行应用。
|
监控 安全 Linux
虚拟机CentOS的Nginx+keepalived 高可用集群配置主从模式
虚拟机CentOS的Nginx+keepalived 高可用集群配置主从模式
194 0
|
应用服务中间件 nginx 负载均衡
|
应用服务中间件 nginx 前端开发
云服务器 nginx + tomcat 部署集群 配置
nginx.conf #user nobody; worker_processes 1; #error_log logs/error.log; #error_log logs/error.log notice; #error_log logs/error.
1138 0
|
负载均衡 算法 应用服务中间件
Nginx实现集群的负载均衡配置过程详解
Nginx 的负载均衡功能,其实实际上和 nginx 的代理是同一个功能,只是把代理一台机器改为多台机器而已。 Nginx 的负载均衡和 lvs 相比,nginx属于更高级的应用层,不牵扯到 ip 和内核的修改,它只是单纯地把用户的请求转发到后面的机器上。
1729 0