從零開始學 Java - 利用 Nginx 負載均衡實現 Web 伺服器更新不影響訪問

来源:http://www.cnblogs.com/mafly/archive/2016/09/22/upstream_backup.html
-Advertisement-
Play Games

還記得那些美妙的夜晚嗎 你洗洗打算看一個小電影就睡了,這個時候突然想起來今天晚上是伺服器更新的日子,你要在凌晨時分去把最新的代碼更新到伺服器,以保證明天大家一覺醒來打開網站,發現昨天的 Bug 都不見了。這時候你瞬間沒有了看電影的興緻了,這應該就是一個運維人員的日常了吧! 為什麼要在凌晨時分去更新服 ...


還記得那些美妙的夜晚嗎

你洗洗打算看一個小電影就睡了,這個時候突然想起來今天晚上是伺服器更新的日子,你要在凌晨時分去把最新的代碼更新到伺服器,以保證明天大家一覺醒來打開網站,發現昨天的 Bug 都不見了。這時候你瞬間沒有了看電影的興緻了,這應該就是一個運維人員的日常了吧!

為什麼要在凌晨時分去更新伺服器?
做過 Web 開發的應該都明白,可能儘管你開發的系統並沒有多少用戶在使用,但是,你依然不敢大白天去更新生產環境伺服器,因為你並不知道伺服器可能暫停兩分鐘會帶來的影響,又或者我們心目中的「生產環境」這個詞是聖神而不可隨便玷污的,所以,我們總是放在凌晨時分。

你聽過「災備」、「異地多活」、「雙機熱備」這些詞麽

大家都知道「不能把雞蛋放在一個籃子里」,在我們開發中依然是如此,如果是稍微對系統數據及運行狀態有要求的項目,千萬可不能突然系統掛掉幾分鐘,這帶來的後果是不可想象的。所以,在我們開發中就會有「災備」這個詞,我們要考慮到這些不可預防的事件發生,所以,往往我們會把系統部署到多台伺服器上面,這就是「雞蛋」的例子,也就是所謂的「雙機熱備」,以保證我們系統的高可用,當一個伺服器掛掉,後邊的這個完全有能力頂上去!就好像一個程式員你感覺他天天沒什麼事兒可乾,非常氣憤的去找你領導說:xxx 天天沒事幹,為什麼他工資比我高?呵呵呵...

從零開始學 Java - CentOS 下 Nginx + Tomcat 配置負載均衡 這篇文章中,我們已經配置了兩台伺服器實現負載均衡,並且可以自定義權重,其實這個時候 Nginx 是支持你去更新其中一個伺服器的時候,它監測到這個伺服器掛掉了,它把請求都轉發到另一臺伺服器的。但是,我在翻看 Nginx 的 upstream 配置的時候發現有種更好的方式,就是配置備份伺服器。

backup 是什麼鬼

當然是備份的意思了。看到官網的配置(http://nginx.org/en/docs/http/ngx_http_upstream_module.html)是這個樣子的
nginx_example.PNG

  • backup : marks the server as a backup server. It will be passed requests when the primary servers are unavailable.(標記為備用伺服器。當主伺服器不可用以後,請求會被傳給這些伺服器。)
    這意思就是,只有當你的伺服器掛掉的時候才會使用備份伺服器,正常情況下不會訪問到備份伺服器,那好,我來測試一下,還記得我們上一篇負載均衡的配置麽,我增加一個Tomcat伺服器3,然後,裡邊網頁輸出這是網站3333333333

nginx_backup.png

具體配置文字版:

upstream backend {
    server 192.168.198.128:8080 weight=1;
    server 192.168.198.128:8090 weight=4;
    server 192.168.198.128:8091 backup;
}

server {
    listen       80;
    server_name  localhost;

    #charset koi8-r;

    #access_log  logs/host.access.log  main;

    location / {
        root   html;
        index  index.html index.htm;
        proxy_pass  http://backend;
    }

我這裡先做一個必要的小說明:

  • 192.168.198.128:8080 伺服器下麵會稱為 伺服器1 ,每五次請求會到這裡一次;
  • 192.168.198.128:8090 伺服器下麵會稱為 伺服器2 ,每五次請求會到這裡四次;
  • 192.168.198.128:8091 伺服器下麵會稱為 伺服器3 ,即備份伺服器。

這個時候伺服器1伺服器2伺服器3都正常啟動,我刷新頁面,會按照權重規則請求伺服器1伺服器2,並不會請求伺服器3(備份伺服器)

nginx_allstart.gif

接下來我把伺服器1停掉,伺服器2伺服器3都正常啟動,我刷新頁面,這個時候所有請求都是伺服器2,也並不會請求伺服器3(備份伺服器)

nginx_service1stop.gif

接下來我把伺服器1伺服器2都停掉,伺服器3正常啟動,我刷新頁面,所有請求都轉發到伺服器3(備份伺服器),看圖片:

nginx_service1and2stop.gif

我再次依次啟動伺服器1伺服器2,所有請求都又按照權重規則分配了。在你所有正常伺服器都掛掉時,系統依然高可用,這就是備份伺服器的用處

總結:無痛更新

配置完備份伺服器後,你再也不用再凌晨時分爬起床去更新伺服器了,你想什麼時間更新就什麼時間更新,愛誰誰!真的可以做到無痛、無痛、無痛,不斷網重啟伺服器。

好了,我洗洗睡覺了,我特麽終於可以去看一部小電影了...


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

-Advertisement-
Play Games
更多相關文章
  • 定義用來控制應用程式宿主環境的行為的配置設置。 配置如下 shadowCopyBinAssemblies:該值指示 Bin 目錄中的應用程式的程式集是否影像複製到該應用程式的 ASP.NET 臨時文件目錄中。但純看這句話我是一面懵懂的,幸虧看了一篇老外的文章經過自己實踐才明白其作用。平時我們更新bi ...
  • 前段時間 工作需要 生平第一次聽到“無狀態”一詞 隨後 瞭解了下 怕自己忘記 隨手記錄下來 /* 尚未創建過Session:InitializeRequest -> CreateNewStoreData InitializeRequest -> ResetItemTimeout -> Initial ...
  • 用 PostMessage、SendNotifyMessage、SendMessageCallback 等非同步函數發送系統消息時,參數里不可以使用指針,因為發送者並不等待消息的處理就返回,接受者還沒處理指針就已經被釋放了。 5、在 Windows 2000/XP 里,每個消息隊列最多只能存放 10, ...
  • 題目:簡單主機批量管理工具 需求: 流程圖: Readme: ### 作者介紹: * author:lzl ### 博客地址: * http://www.cnblogs.com/lianzhilei/p/5881434.html ### 功能實現 題目:簡單主機批量管理工具 需求: 主機分組 登錄後 ...
  • 本文原創,轉載請註明:http://www.cnblogs.com/fengzheng/p/5889312.html 為什麼要有mybatis mybatis 是一個 Java 的 ORM 框架,ORM 的出現就是為了簡化開發。最初的開發方式是業務邏輯和資料庫查詢邏輯是分開的,或者在程式中編寫 sq ...
  • 在談Spring事務管理之前我們想一下在我們不用Spring的時候,在Hibernate中我們是怎麼進行數據操作的。在Hibernate中我們每次進行一個操作的的時候我們都是要先開啟事務,然後進行數據操作,然後提交事務,關閉事務,我們這樣做的原因是因為Hibernate預設的事務自動提交是false ...
  • 本節探討Java中的容器類ArrayList,它有哪些方法?內部是如何實現的?有什麼特點?與數組如何轉換?迭代是什麼?為什麼要有它?內部是如何實現的?有哪些易犯的錯誤?Collection/List/RandomAccess都用於什麼目的? ...
  • 1、需求 做一個項目會有很多模塊,主要是方便復用,通過各個模塊之間聚合。模塊也可以獨立出來,如公用類庫,也可以在做其它項目中使用。該文的實例會有兩個模塊:分別為dallin web模塊,dallin utils工具類模塊 2、新建一個Maven父項目 1. 打開IDEA工具,通過file——new— ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...