亚洲视频二区_亚洲欧洲日本天天堂在线观看_日韩一区二区在线观看_中文字幕不卡一区

公告:魔扣目錄網(wǎng)為廣大站長提供免費收錄網(wǎng)站服務,提交前請做好本站友鏈:【 網(wǎng)站目錄:http://www.430618.com 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

目錄
  • 1. nginx負載均衡介紹
  • 2. nginx負載均衡策略
    • 2.1 輪詢
      • 2.1.1 普通輪詢方式
      • 2.1.2 權(quán)重輪詢方式
    • 2.2 最少連接
      • 2.3 ip hash
      • 3. nginx負載均衡搭建示例
        • 3.1 tomcat配置
          • 3.2 nginx配置
          • 總結(jié)

            1. nginx負載均衡介紹

            nginx應用場景之一就是負載均衡。在訪問量較多的時候,可以通過負載均衡,將多個請求分攤到多臺服務器上,相當于把一臺服務器需要承擔的負載量交給多臺服務器處理,進而提高系統(tǒng)的吞吐率;另外如果其中某一臺服務器掛掉,其他服務器還可以正常提供服務,以此來提高系統(tǒng)的可伸縮性與可靠性。

            下圖為負載均衡示例圖,當用戶請求發(fā)送后,首先發(fā)送到負載均衡服務器,而后由負載均衡服務器根據(jù)配置規(guī)則將請求轉(zhuǎn)發(fā)到不同的web服務器上。

            使用nginx進行負載均衡的搭建全過程

            2. nginx負載均衡策略

            以下截圖為nginx官網(wǎng)文檔

            使用nginx進行負載均衡的搭建全過程

            nginx內(nèi)置負載均衡策略主要分為三大類,分別是輪詢、最少連接和ip hash

            • 最少連接

            請求分配給活動連接數(shù)最少的服務器,哪臺服務器連接數(shù)最少,則把請求交給哪臺服務器,由nginx統(tǒng)計服務器連接數(shù)

            • ip hash

            基于客戶端ip的分配方式

            2.1 輪詢

            以循環(huán)方式分發(fā)對應用服務器的請求,將請求平均分發(fā)到每臺服務器上。

            2.1.1 普通輪詢方式

            該方式是默認方式,輪詢適合服務器配置相當,無狀態(tài)且短平快的服務使用。另外在輪詢中,如果服務器掛掉,會自動剔除該服務器。

            http {
                # 定義轉(zhuǎn)發(fā)分配規(guī)則
                upstream myapp1 {
                    server srv1.com; # 要轉(zhuǎn)發(fā)到的服務器,如ip、ip:端口號、域名、域名:端口號
                    server srv2.com:8088;
                    server 192.168.0.100:8088;
                }
            
                server {
                    listen 80; # nginx監(jiān)聽的端口
            
                    location / {
                    	# 使用myapp1分配規(guī)則,即剛自定義添加的upstream節(jié)點
                    	# 將所有請求轉(zhuǎn)發(fā)到myapp1服務器組中配置的某一臺服務器上
                        proxy_pass http://myapp1; 
                    }
                }
            }
            

            2.1.2 權(quán)重輪詢方式

            如果在 upstream 中配置的server參數(shù)后追加 weight 配置,則會根據(jù)配置的權(quán)重進行請求分發(fā)。此策略可以與least_conn和ip_hash結(jié)合使用,適合服務器的硬件配置差別比較大的情況。

            # 定義轉(zhuǎn)發(fā)分配規(guī)則
            upstream myapp1 {
            	server srv1.com weight=1; # 該臺服務器接受1/6的請求量
            	server srv2.com:8088 weight=2; # 該臺服務器接受2/6的請求量
            	server 192.168.0.100:8088 weight=3; # 該臺服務器接受3/6的請求量;
            }
            

            2.2 最少連接

            輪詢算法是把請求平均的轉(zhuǎn)發(fā)給各個后端,使它們的負載大致相同;但是,有些請求占用的時間很長,會導致其所在的后端負載較高。這種情況下,least_conn這種方式就可以達到更好的負載均衡效果,適合請求處理時間長短不一造成服務器過載的情況。

            # 定義轉(zhuǎn)發(fā)分配規(guī)則
            upstream myapp1 {
            	least_conn; # 把請求分派給連接數(shù)最少的服務器
            	server srv1.com;
            	server srv2.com:8088;
            	server 192.168.0.100:8088;
            }
            

            2.3 ip hash

            這個方法確保了相同的客戶端的請求一直發(fā)送到相同的服務器,這樣每個訪客都固定訪問一個后端服務器。如用戶需要分片上傳文件到服務器下,然后再由服務器將分片合并,這時如果用戶的請求到達了不同的服務器,那么分片將存儲于不同的服務器目錄中,導致無法將分片合并,該場景則需要使用ip hash策略。

            需要注意的是,ip_hash不能與backup同時使用,另外當有服務器需要剔除,必須手動down掉,此模式適合有狀態(tài)服務,比如session。

            # 定義轉(zhuǎn)發(fā)分配規(guī)則
            upstream myapp1 {
            	ip_hash; # #保證每個請求固定訪問一個后端服務器
            	server srv1.com;
            	server srv2.com:8088;
            	server 192.168.0.100:8088;
            }
            

            3. nginx負載均衡搭建示例

            該示例使用一臺nginx作為負載均衡服務器,兩臺tomcat作為web服務器;可以把三個服務均在一臺機器進行搭建,也可以使用虛擬機虛擬三臺機器,然后進行測試。教程這里就只在一臺機器進行搭建,采用默認的權(quán)重方式進行配置。

            3.1 tomcat配置

            將兩臺tomcat解壓出來,配置完畢相應的端口,然后在webapps目錄下創(chuàng)建test目錄,然后在test目錄中創(chuàng)建index.html文件,隨便寫入一些內(nèi)容,兩臺tomcat中test目錄下的index.html文件內(nèi)容要區(qū)分開來,例如寫入1111111 / 222222222,如下圖所示。

            使用nginx進行負載均衡的搭建全過程

            使用nginx進行負載均衡的搭建全過程

            3.2 nginx配置

            首先進行nginx的安裝,安裝教程可以參考

            https://www.jb51.net/article/231249.htm

            安裝完畢后,進入nginx目錄下的conf目錄,編輯 nginx.conf 文件,修改內(nèi)容為在http節(jié)點下增加

            upstream tomcat { # 該部分內(nèi)容與 server 節(jié)點同級
            	server tomcat服務的ip:tomcat服務的端口號;
            	server tomcat服務的ip:tomcat服務的端口號;
            }
            

            server節(jié)點下的location /節(jié)點中,把默認的

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

            修改為

            location / {
            	proxy_pass http://tomcat;
            }
            

            然后啟動 兩臺tomcat與nginx服務,在瀏覽器輸入nginx服務的地址:端口,不停刷新頁面,就可以看到每次請求的服務器發(fā)生了改變。

            總結(jié)

            分享到:
            標簽:nginx 全過程 搭建 服務器 負載均衡
            用戶無頭像

            網(wǎng)友整理

            注冊時間:

            網(wǎng)站:5 個   小程序:0 個  文章:12 篇

            • 51998

              網(wǎng)站

            • 12

              小程序

            • 1030137

              文章

            • 747

              會員

            趕快注冊賬號,推廣您的網(wǎng)站吧!
            最新入駐小程序

            數(shù)獨大挑戰(zhàn)2018-06-03

            數(shù)獨一種數(shù)學游戲,玩家需要根據(jù)9

            答題星2018-06-03

            您可以通過答題星輕松地創(chuàng)建試卷

            全階人生考試2018-06-03

            各種考試題,題庫,初中,高中,大學四六

            運動步數(shù)有氧達人2018-06-03

            記錄運動步數(shù),積累氧氣值。還可偷

            每日養(yǎng)生app2018-06-03

            每日養(yǎng)生,天天健康

            體育訓練成績評定2018-06-03

            通用課目體育訓練成績評定