Nginx基礎(chǔ)應(yīng)用有哪些

本篇內(nèi)容主要講解“Nginx基礎(chǔ)應(yīng)用有哪些”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“Nginx基礎(chǔ)應(yīng)用有哪些”吧!

專注于為中小企業(yè)提供做網(wǎng)站、網(wǎng)站建設(shè)服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)通江免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了近千家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。

一、簡介

nginx作為代理服務(wù)器的使用,但是漏了一個(gè)重要的,也是使用非常普遍的特性——負(fù)載均衡

通過多個(gè)實(shí)例進(jìn)行負(fù)載均衡是一個(gè)比較常用的技術(shù),它用來是資源利用最大化、提高通過率、降低延遲響應(yīng)、確保容災(zāi)等。

二、負(fù)載均衡的方法

  • 輪詢——應(yīng)用服務(wù)器間的請求按照輪詢的方式分配;

  • 最小連接數(shù)——下一個(gè)請求將會(huì)分配給當(dāng)前連接數(shù)最小的服務(wù)器;

  • ip哈?!砸环N哈希的方式?jīng)Q定下一個(gè)請求分配到哪個(gè)服務(wù)器上(基于客戶端的ip進(jìn)行哈希)。

三、默認(rèn)的負(fù)載均衡配置

nginx最簡單的負(fù)載均衡配置如下:

http {
   upstream myapp1 {
       server srv1.example.com;
       server srv2.example.com;
       server srv3.example.com;
   }

   server {
       listen 80;

       location / {
           proxy_pass http://myapp1;
       }
   }
}

上面的例子中,有3個(gè)相同的實(shí)例運(yùn)行在srv1-srv3上。當(dāng)負(fù)載均衡的方法沒有特別指定時(shí),它將默認(rèn)使用輪詢的方式。所有的請求都會(huì)被代理到服務(wù)組myapp1上,nginx將應(yīng)用HTTP的負(fù)載均衡分配請求。

nginx的反向代理實(shí)現(xiàn)包含負(fù)載均衡的種類:HTTP、HTTPS、FastCGI、uwsgi、SCGI和緩存等。

如果要用HTTPS的負(fù)載均衡,只需要使用HTTPS的協(xié)議即可。

當(dāng)為FastCGI、uwsgi、SCGI和緩存設(shè)置負(fù)載均衡時(shí),使用相應(yīng)的fastcgi_pass、uwsgi_pass、scgi_pass和memcached_pass的指令集即可,這里不做詳細(xì)介紹。

四、最小連接負(fù)載均衡

另外一個(gè)負(fù)載連接方式是最小連接。最小連接的方式可以使應(yīng)用實(shí)例間的負(fù)載更公平,例如在一些請求需要花費(fèi)更長時(shí)間去完成的情況。

使用最小連接的方式,nginx不會(huì)將過多的請求分配到一個(gè)比較忙的應(yīng)用服務(wù)上,它將把請求分配到相對(duì)不忙的應(yīng)用服務(wù)上。

最小連接的負(fù)載均衡方式在nginx中的配置如下,它作為服務(wù)組中的一個(gè)配置出現(xiàn):

upstream myapp1 {
       least_conn;
       server srv1.example.com;
       server srv2.example.com;
       server srv3.example.com;
   }

五、會(huì)話保持的方式

在介紹這種方式之前,大家先記住,使用輪詢和最小連接的負(fù)載均衡方式,同一客戶端的下一個(gè)請求有可能分配到不同的應(yīng)用服務(wù)上。這兩種方式不能保證同一客戶端的請求總是分配到同一個(gè)服務(wù)上。

如果需要將一個(gè)客戶端綁定到一個(gè)特殊的應(yīng)用服務(wù)上,換句話說,使客戶端的會(huì)話“粘連”或“保持”,就要使用“ip-hash”的負(fù)載均衡機(jī)制了。

使用ip-hash,客戶端的ip用來做哈希的key,決定著選擇服務(wù)組中的哪個(gè)應(yīng)用服務(wù)這個(gè)客戶端的請求。這種方法決定了相同客戶端的請求總是分配給相同的服務(wù),除非這個(gè)服務(wù)不可用了。

配置ip-hash的負(fù)載均衡,只需要將ip-hash指令添加到服務(wù)組(upstream)中,如下:

upstream myapp1 {
   ip_hash;
   server srv1.example.com;
   server srv2.example.com;
   server srv3.example.com;
}

六、負(fù)載均衡的權(quán)重

通過使用服務(wù)權(quán)重,可以進(jìn)一步影響負(fù)載均衡的邏輯。上面的例子中,沒有配置權(quán)重的意思是,所有指定的服務(wù)將被看做有相同的權(quán)重。

采用輪詢的方式,如果有足夠的請求,并且請求通過統(tǒng)一的方式處理并且快速的完成的情況下,它仍然意味著在服務(wù)之間或多或少的公平的分配。

當(dāng)weight參數(shù)為一個(gè)服務(wù)指定時(shí),它將是負(fù)載均衡過程中的一部分。

upstream myapp1 {
       server srv1.example.com weight=3;
       server srv2.example.com;
       server srv3.example.com;
   }

上面的配置中,每5個(gè)應(yīng)用請求將分配如下:3個(gè)請求分配個(gè)srv1,1個(gè)請求分配給srv2,另一個(gè)請求分配給srv3。在nginx最近的版本中,在最小連接和ip-hash的負(fù)載均衡方式中使用權(quán)重(weight)也是有可能的。

七、健康檢查

nginx的反向代理包括在內(nèi)(或被動(dòng))的健康檢查。如果一個(gè)服務(wù)的響應(yīng)是失敗的,nginx將會(huì)標(biāo)記這個(gè)服務(wù)是失敗的,并且在短暫的時(shí)間內(nèi),避免為下一個(gè)請求選擇這個(gè)服務(wù)。

max_fails指令設(shè)置是,在fail_timeout時(shí)間內(nèi),嘗試和這臺(tái)服務(wù)連續(xù)通信失敗的次數(shù)。默認(rèn)情況下,max_fails設(shè)置為1,當(dāng)設(shè)置為0時(shí),這個(gè)服務(wù)的健康檢查將失效。fail_timeout參數(shù)定義了這個(gè)服務(wù)多長時(shí)間會(huì)被標(biāo)記為失效,在服務(wù)失敗的fail_timeout間隔后,nginx使用活的客戶端請求優(yōu)雅的探測服務(wù),如果探測成功了,這個(gè)服務(wù)將會(huì)標(biāo)記為成功的。

到此,相信大家對(duì)“Nginx基礎(chǔ)應(yīng)用有哪些”有了更深的了解,不妨來實(shí)際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

本文名稱:Nginx基礎(chǔ)應(yīng)用有哪些
URL地址:http://muchs.cn/article20/gepjco.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站建設(shè)、做網(wǎng)站ChatGPT、外貿(mào)網(wǎng)站建設(shè)、品牌網(wǎng)站制作商城網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

綿陽服務(wù)器托管