<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

          鵝廠二面,Nginx回憶錄

          共 7917字,需瀏覽 16分鐘

           ·

          2021-03-15 07:54


          上周二面鵝廠,面試官問(wèn)出了“nginx你了解嗎?”這樣寬泛直白的句式,我一時(shí)抓不到重點(diǎn),一時(shí)語(yǔ)噻。

          下班想了一下,平時(shí)潛移默化用到不少nginx的能力,但在面試的時(shí)候沒(méi)有吹成對(duì)應(yīng)的概念。

          面談nginx核心能力

          nginx是老牌web服務(wù)器,以下口水話的nginx基礎(chǔ)能力,大家都耳熟能詳,看看就行,面試官也不打算考查這個(gè)。

          高并發(fā)連接: 官方稱單節(jié)點(diǎn)支持5萬(wàn)并發(fā)連接數(shù),實(shí)際生產(chǎn)環(huán)境能夠承受2-3萬(wàn)并發(fā)。
          內(nèi)存消耗少: 在3萬(wàn)并發(fā)連接下,開(kāi)啟10個(gè)nginx進(jìn)程僅消耗150M內(nèi)存 (15M×10=150M)
          配置簡(jiǎn)單
          成本低廉: 開(kāi)源免費(fèi)

          1. 正向、反向代理

          所謂“代理”,是指在內(nèi)網(wǎng)邊緣 設(shè)置一個(gè)硬件/軟件轉(zhuǎn)發(fā)請(qǐng)求;
          “正向”還是“反向”的說(shuō)法,取決于轉(zhuǎn)發(fā)的是"出站請(qǐng)求"還是"入站請(qǐng)求".

          正向代理: 處理來(lái)自客戶端的出站請(qǐng)求,將其轉(zhuǎn)發(fā)到Internet,然后將生成的響應(yīng)返回給客戶端。
          反向代理: 處理來(lái)自Internet的入站請(qǐng)求,將其轉(zhuǎn)發(fā)給后端工作程序,然后將響應(yīng)返回給Internet。

          1. 正向代理和反向代理 在代理的方向上不同,但都會(huì)代理處理HTTP請(qǐng)求/響應(yīng)。
          2. 代理服務(wù)器存在的目的:
          • 堡壘機(jī)/隔離內(nèi)網(wǎng):內(nèi)網(wǎng)客戶端無(wú)法訪問(wèn)外網(wǎng)需要設(shè)置堡壘機(jī)、隱藏內(nèi)網(wǎng)工作服務(wù)器
          • 代理服務(wù)器附加功能:對(duì)流量執(zhí)行操作、使用緩存或壓縮來(lái)提高性能、防御攻擊并過(guò)濾信息

          2. 負(fù)載均衡

          負(fù)載均衡一般伴隨著反向代理, 起到了分配流量、透明代理、 增強(qiáng)容錯(cuò)的效果

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

              server {
                  listen 80;

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

          早期我們的核心產(chǎn)品部署在兩臺(tái)windows Sever IIS上,前面部署了一個(gè)nginx,做的負(fù)載均衡。

          很明顯,這里有個(gè)[負(fù)載均衡策略]的知識(shí)點(diǎn)。

          • round-robin  顧名思義:輪詢
          • least-connected :下一個(gè)請(qǐng)求將發(fā)往最小活動(dòng)鏈接的服務(wù)器
          • ip-hash:根據(jù)客戶端的ip地址和哈希函數(shù) 決定將請(qǐng)求發(fā)往哪個(gè)服務(wù)器http://nginx.org/en/docs/http/load_balancing.html

          ?  延伸技能點(diǎn):

          ① [服務(wù)發(fā)現(xiàn)]:

                 在容器/K8S環(huán)境,服務(wù)地址是由集群系統(tǒng)動(dòng)態(tài)分配,一般都內(nèi)置了服務(wù)發(fā)現(xiàn)能力,docker-comppose/K8s中定義的服務(wù)名就代表了整個(gè)服務(wù)。
          有個(gè)文章講述了: 《巧用nginx 實(shí)現(xiàn)Docker-Comppose服務(wù)多實(shí)例

          ② [會(huì)話親和力]:

                  又叫“粘性會(huì)話”,確保在有狀態(tài)的應(yīng)用中,同一客戶端的請(qǐng)求打到后端一個(gè)服務(wù)器上。

                 也有個(gè)示例可參考:《巧用會(huì)話親和力做圖片預(yù)覽上傳

          3. 動(dòng)靜分離

          動(dòng)靜分離與現(xiàn)在火熱的前后端分離概念火熱相關(guān),

          前端可以自行開(kāi)發(fā)、測(cè)試,自行使用nginx形成靜態(tài)資源服務(wù)器,后端服務(wù)僅作為附加資源。

          下面的例子表明 靜態(tài)資源在/usr/share/nginx/html, 動(dòng)態(tài)資源路徑包含api或swagger。

            upstream eap_website {
                server eapwebsite;
              }

            server {
                listen      80;
                location / {            # 靜態(tài)資源
                      root /usr/share/nginx/html;
                      index index.html index.htm;
                      try_files $uri /index.html;
                }

                location ^~ /api/  {     # 動(dòng)態(tài)資源
                   proxy_pass         http://eap_website/api/;
                }

                location ^~ /swagger/  {    # 動(dòng)態(tài)資源
                   proxy_pass         http://eap_website/swagger/;
                }
            }

          ? 延伸技能點(diǎn)

          ① 以上流程也是《現(xiàn)代十二要素應(yīng)用方法論》所推崇的第四點(diǎn), 從這個(gè)體系來(lái)說(shuō),后端淪落為api開(kāi)發(fā),實(shí)屬遺憾
          ② 這里有個(gè)《有關(guān)在容器生成階段動(dòng)態(tài)插入api基地址的妙招》,對(duì)動(dòng)靜分離的容器化很有裨益。

          實(shí)用功能

          1. 通過(guò)端口支持同一域名下多個(gè)webapp

          2. 綁定Https證書(shū)

            1、2點(diǎn)一起體現(xiàn):一個(gè)域名綁定到4438080端口兩個(gè)https站點(diǎn)

           upstream receiver_server {
                  server receiver:80;
           }
           upstream app_server {
                  server app:80;
           }

           server {
                  listen       443 ssl http2;
                  server_name  eqid.gridsum.com;
                  ssl_certificate         /conf.crt/live/gridsum.com.crt;
                  ssl_certificate_key     /conf.crt/live/gridsum.com.key;
                  
                  location / {
                      proxy_pass         http://receiver_server/;
                  }
             }

           server {
                  listen 8080 ssl http2;
                  server_name             eqid.gridsum.com:8080;
                  ssl_certificate         /conf.crt/live/gridsum.com.crt;
                  ssl_certificate_key     /conf.crt/live/gridsum.com.key;
                  
                  location / {
                      proxy_pass         http://app_server/;
                  }
              }
          1. 支持rewrite重寫(xiě)規(guī)則:    能夠根據(jù)域名、url的不同,將http請(qǐng)求分發(fā)到后端不同的應(yīng)用服務(wù)器節(jié)點(diǎn)上。

          2. 內(nèi)置健康檢查功能:   如果后端的某臺(tái)應(yīng)用節(jié)點(diǎn)掛了,請(qǐng)求不會(huì)再轉(zhuǎn)發(fā)給這個(gè)節(jié)點(diǎn),不影響線上功能。
            關(guān)鍵指令:max_fails,  fail_timeout

          upstream backend {
              server backend1.example.com weight=5;
              server 127.0.0.1:8080       max_fails=3 fail_timeout=30s;
              server unix:/tmp/backend3;

              server backup1.example.com  backup;
          }
          1. 節(jié)省帶寬: 支持gzip壓縮

          2. 解決跨域問(wèn)題    ① 反向代理 ② 增加CORS響應(yīng)頭

             5、6點(diǎn)一起體現(xiàn):在前后端分離項(xiàng)目,對(duì)跨域請(qǐng)求增加CORS響應(yīng)頭、對(duì)靜態(tài)資源開(kāi)啟 gzip壓縮

             location / {
                      gzip on;
                      gzip_types application/javascript text/css image/jpeg;

                     root /usr/share/nginx/html;
                     index index.html index.htm;
                     try_files $uri /index.html;

                     add_header 'Access-Control-Allow-Origin' '*';
                     add_header '
          Access-Control-Allow-Methods' 'GET, POST, OPTIONS, PUT, DELETE';
                     add_header '
          Access-Control-Allow-Headers' 'Content-Type';
                     add_header '
          Access-Control-Allow-Credentials' 'true';
                  }


          要進(jìn)大廠, 技術(shù)棧要向舒適區(qū)以外拓展, 大廠開(kāi)發(fā)大都具備多技能, 隨插隨用。

          基礎(chǔ)知識(shí)牢固,才會(huì)融會(huì)貫通,更快解鎖高難度姿勢(shì)。

          #與本文相關(guān)的延伸技能點(diǎn)

          鵝廠二面大概率掛了,實(shí)踐沒(méi)吹成概念,且行且分享。

          本文回顧了小碼甲使用nginx的實(shí)踐,應(yīng)該足夠在下一次面試中吹水了,如有錯(cuò)誤,請(qǐng)留言賜教。



          往期精彩回顧




          【推薦】.NET Core開(kāi)發(fā)實(shí)戰(zhàn)視頻課程 ★★★

          .NET Core實(shí)戰(zhàn)項(xiàng)目之CMS 第一章 入門(mén)篇-開(kāi)篇及總體規(guī)劃

          【.NET Core微服務(wù)實(shí)戰(zhàn)-統(tǒng)一身份認(rèn)證】開(kāi)篇及目錄索引

          Redis基本使用及百億數(shù)據(jù)量中的使用技巧分享(附視頻地址及觀看指南)

          .NET Core中的一個(gè)接口多種實(shí)現(xiàn)的依賴注入與動(dòng)態(tài)選擇看這篇就夠了

          10個(gè)小技巧助您寫(xiě)出高性能的ASP.NET Core代碼

          用abp vNext快速開(kāi)發(fā)Quartz.NET定時(shí)任務(wù)管理界面

          在ASP.NET Core中創(chuàng)建基于Quartz.NET托管服務(wù)輕松實(shí)現(xiàn)作業(yè)調(diào)度

          現(xiàn)身說(shuō)法:實(shí)際業(yè)務(wù)出發(fā)分析百億數(shù)據(jù)量下的多表查詢優(yōu)化

          關(guān)于C#異步編程你應(yīng)該了解的幾點(diǎn)建議

          C#異步編程看這篇就夠了


          瀏覽 65
          點(diǎn)贊
          評(píng)論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報(bào)
          評(píng)論
          圖片
          表情
          推薦
          點(diǎn)贊
          評(píng)論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報(bào)
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  亚洲激情在线观看 | 亚洲国产综合色在线视频 | 白丝自慰在线 | AⅤ天堂| 最新淫色网站 |