實現動靜分離

来源:https://www.cnblogs.com/1naonao/archive/2019/08/28/11426461.html
-Advertisement-
Play Games

[toc] nginx 實現動靜分離 Nginx動靜分離基本概述 動靜分離,通過中間件將動靜分離和靜態請求進行分離; 通過中間件將動態請求和靜態請求分離,可以建上不必要的請求消耗,同事能減少請求的延時。 通過中間件將動態請求和靜態請求分離,邏輯圖如下: 動靜分離只有好處:動靜分離後,即使動態服務不可 ...


目錄

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;
    .....
}

多台伺服器實現動靜分離

1.環境準備

系統 作用 服務 地址
Centos7.5 負載均衡 nginx proxy 10.0.0.5
Centos7.5 靜態資源 nginx static 10.0.0.7
Centos7.5 動態資源 tomcat server 10.0.0.8

2.web配置靜態資源

[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

3.驗證

打開瀏覽器訪問:http://pic.drz.com/

打開瀏覽器訪問:http://pic.drz.com/cjk.gif

4.web02配置動態資源

[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

img

5.負載均衡上調度

[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 -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
[root@lb01 conf.d]# nginx -s reload

2.5 配置本地hosts,通過負載訪問動態與靜態資源
動態資源 ↓

靜態資源 ↓

網站主頁 ↓

6.負載均衡上整合動態和靜態的html文件

#編輯配置文件
[root@lb01 ~]# cat /etc/nginx/conf.d/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 / {
            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>

7.瀏覽器訪問測試動靜分離是否成功

可以嘗試關掉靜態或者動態的服務,測試是否互不影響

Nginx資源分離場景實踐

Nginx通過負載均衡實現手機與PC調度至不通的後端節點應用案例

根據iphone、安卓,pc跳轉不通的頁面環境規劃

系統版本 主機角色 外網IP 內網IP 提供埠
CentOS7.5 負載均衡 10.0.0.5 172.16.1.5 80
CentOS7.5 提供Android頁面 172.16.1.7 9090
CentOS7.5 提供Iphone頁面 172.16.1.7 9091
CentOS7.5 提供pc頁面 172.16.1.7 9092

1.配置後端WEB節點的Nginx配置

[root@web01 conf.d]# vim sj.conf
server {
        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節點配置對應的網站目錄及代碼

[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.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 {
        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.使用瀏覽器訪問,查看結果

實際上的配置

server {
        listen 80;
        server_name   www.drz.com;
        if ($http_user_agent ~* "Android|Iphone") {   #修改負載,wel上也改
                rewrite ^/$ https://sj.drz.com redirect;
        }       
}

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 彙編語言初探 0x00 參考 "阮一峰的網路日誌之彙編語言入門教程" "ARM彙編語言學習筆記(一) ARM彙編的程式結構" 0x01 要點概述 標準化以後,稱為 assembly language,縮寫為 asm,中文譯為彙編語言。 彙編語言是二進位指令的文本形式,與指令是一一對應的關係。 每一種 ...
  • Linux系統啟動流程 從上至下為: BIOS MBR:Boot Code 執行引導程式-GRUB(操作系統) 載入內核 執行init run level 1.BIOS(Basic Input Output System) 基本輸入輸出系統,一般保存在主板上的BIOS的晶元中,負責檢查硬體/查找可啟 ...
  • 開發平臺介紹: NUC970 + 內置CAN控制器(雙通道CAN1\CAN2) + 官方Linux_Kernel(少量修改) 名詞: 終端,使用NUC970的硬體 異常表現: 1、當CAN收發器(VP251)斷電時,此時再恢復CAN外部通訊,終端表現為能收到全部的CAN數據,發送函數返回成功,但CA ...
  • Vi文本編輯器 首先介紹命令模式,命令模式是在進入文本編輯器的時候的當前狀態;輸入模式(插入模式)是在插入文本時候按下的鍵,比如 大小 i 鍵,a鍵、o鍵;底行模式是在命令模式的狀態直接輸入冒號 ":" ,從插入模式到命令模式,按下Esc鍵即可 ①定位游標 命令模式下 向上 k 向下 j 向左 h ...
  • Linux網路配置原理圖(NAT模式) 查看網路IP和網關: CentOS7:ip addr CentOS6:ifconfig Ping測試主機之間網路的連通性:ping [www.baidu.com] 網路環境配置: /etc/sysconfig/network-scripts/ifcfg-eth ...
  • mysql版本分為企業版(Enterprise)和社區版(Community),其中社區辦是通過GPL協議授權的開源軟體,可以免費使用,而企業版是需要收費的商業軟體。 mysql官網 https://www.mysql.com/ ,進去點擊 download 下拉滾動到最後,看到 MySQL Com ...
  • [TOC] 1.介紹 約束條件與數據類型的寬度一樣,都是可選參數 作用:用於保證數據的完整性和一致性 主要分為: 說明: 2.not null 和default 是否可空,null表示空,非字元串 not null 不可空 null 可空 default預設值,創建列時可以指定預設值,當插入數據時如 ...
  • 上一篇文章咱們說了一條查詢sql的執行過程。如果沒有看過上一篇文章的可以去看下上一篇文章,今天咱們說說一條更新sql的執行過程。 上面一條sql是將id為1的分數加上10。 那麼它的執行流程是怎樣的呢?借用上篇文章的圖,如下: 我這邊就再簡單的說一下這個流程,首先客戶端連接mysql伺服器,連接後執 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...