成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

利用 NGINX 最大化 Python 性能,第一部分:Web 服務(wù)和緩存

1treeS / 560人閱讀

摘要:無論是將其用作的服務(wù)器反向代理服務(wù)器負(fù)載均衡器,還是同時使用以上三種功能,和都能帶來很大好處。再就是下篇文章會介紹如何把和當(dāng)作反向代理服務(wù)器和多個應(yīng)用程序服務(wù)器的負(fù)載均衡器。而使用將會有助于解決這一問題。

【編者按】本文主要介紹 nginx 的主要功能以及如何通過 NGINX 優(yōu)化 Python 應(yīng)用性能。本文系國內(nèi) ITOM 管理平臺 OneAPM 編譯呈現(xiàn)。

Python 的著名之處在于使用簡單方便,軟件開發(fā)簡單,而且據(jù)說運行性能優(yōu)于其它腳本語言。(雖然最新版本的 PHP、PHP 7 可能會與它展開激烈競爭。)

所有人都希望自己的網(wǎng)站和應(yīng)用程序運行得更快一些。但是,每個網(wǎng)站在流量增長或驟然出現(xiàn)流量峰值時都很容易發(fā)生性能問題、甚至宕機(jī)(這一般會在服務(wù)器最繁忙的時候發(fā)生)。此外在運行期間,無論是流量穩(wěn)步增長還是使用量急速飛漲,幾乎所有的網(wǎng)站都會經(jīng)歷性能問題。

而關(guān)于網(wǎng)站性能問題,那就到了 NGINX 和 NGINX Plus 發(fā)揮作用的時候。一般可以通過以下三種方式改善網(wǎng)站性能:

作 web 服務(wù)器,NGINX 最開始的設(shè)計初衷就是解決 C10K 問題,也就是能夠輕松支持1萬以上的同時訪問。NGINX 作為 Python web 服務(wù)器,可以保證網(wǎng)站在流量較低時依然能夠快速運行。當(dāng)擁有上千名用戶同時訪問時,你就必須提供更高性能、更少崩潰和更短停機(jī)時間的 web 服務(wù)器。你也可以在 NGINX 服務(wù)器上進(jìn)行靜態(tài)文件緩存或微程序緩存,不過這兩者在多帶帶的 NGINX 反向代理服務(wù)器(見下段)上運行表現(xiàn)更佳。

做反向代理服務(wù)器---你可以在當(dāng)前應(yīng)用程序服務(wù)器上把 NGINX 設(shè)置為反向代理服務(wù)器。NGINX 會將網(wǎng)絡(luò)請求發(fā)送到應(yīng)用程序服務(wù)器。這種古怪招數(shù)可以提高網(wǎng)站運行速度,減少停機(jī)時間,減少服務(wù)器資源占用,并且提高網(wǎng)站安全。你還可以在反向代理服務(wù)器上緩存靜態(tài)數(shù)據(jù)(非常高效),增加動態(tài)數(shù)據(jù)的微程序緩存,從而減少應(yīng)用程序本身的負(fù)擔(dān)。

做多個應(yīng)用程序服務(wù)器的負(fù)載均衡器---首先要部署反向代理服務(wù)器,然后同時運行多個應(yīng)用程序服務(wù)器,并使用 NGINX 或 NGINX Plus 來均衡經(jīng)過它們傳送的流量,進(jìn)行擴(kuò)展。通過這種部署,你可以輕松的根據(jù)流量需求來衡量網(wǎng)站性能,增加可靠度和正常運行時間。如果你需要既定的用戶會話保存在同一個服務(wù)器上,配置負(fù)載均衡器還可以支持會話持久性。

無論是將其用作 Python 的 web 服務(wù)器、反向代理服務(wù)器、負(fù)載均衡器,還是同時使用以上三種功能,NGINX 和 NGINX Plus 都能帶來很大好處。

下面介紹改善 Python 應(yīng)用程序性能的5個技巧,本文會分多個章節(jié)進(jìn)行介紹,包括把 NGINX 和 NGINX Plus 作為 web 服務(wù)器,如何實施靜態(tài)文件緩存,以及微程序緩存應(yīng)用程序生成文件。

再就是下篇文章會介紹如何把 NGINX 和 NGINX Plus 當(dāng)作反向代理服務(wù)器和多個應(yīng)用程序服務(wù)器的負(fù)載均衡器。

技巧1---找出 Python 性能瓶頸

檢驗 Python 應(yīng)用程序的性能分有兩種不同情況。

第一種是在日常合理用戶數(shù)量的情況下;第二種則是負(fù)載很大的情況下。

很多站長毫不關(guān)心輕負(fù)載時網(wǎng)站性能,然而殘酷的現(xiàn)實經(jīng)驗告訴我們,響應(yīng)時間的每一秒鐘都應(yīng)該為之捏一把汗。雖然將響應(yīng)時間縮短幾毫秒是個苦差事,但卻會帶來更好的用戶體驗和更好的運營成果。

另一個就是所有人都擔(dān)心的情境:網(wǎng)站繁忙時出現(xiàn)的性能問題,例如運行嚴(yán)重減緩和崩潰。此外,很多黑客攻擊也會表現(xiàn)為用戶數(shù)量急劇增長,所以改善網(wǎng)站性能也是解決攻擊問題的重要一步。

服務(wù)器會為每位用戶分配一定數(shù)量的內(nèi)存,例如 Apache HTTP 服務(wù)器,隨著用戶數(shù)量的增長,物理內(nèi)存就會出現(xiàn)超負(fù)載,服務(wù)器開始將數(shù)據(jù)交換到磁盤上,性能驟降,隨之產(chǎn)生性能不良和崩潰。而使用 NGINX 將會有助于解決這一問題。

Python 尤其容易發(fā)生內(nèi)存相關(guān)的性能問題,因為它在執(zhí)行任務(wù)時一般比其它腳本語言占用更多的內(nèi)存(因此它的執(zhí)行速度更高)。因此,在同等條件下,基于 Python 的應(yīng)用程序可能比其他語言的應(yīng)用程序能承受的用戶負(fù)載量更小。

優(yōu)化應(yīng)用程序或多或少會有幫助,但是這通常不是流量相關(guān)網(wǎng)站性能問題的最佳或最快解決方案。本文后續(xù)會列出解決流量相關(guān)問題的最佳/最快解決方案。當(dāng)你看完本文后,無論如何都要回去優(yōu)化你的應(yīng)用程序,或者使用微服務(wù)架構(gòu)重寫。

技巧2---選擇單一服務(wù)器或多個服務(wù)器配置

小網(wǎng)站只要配置單一服務(wù)器就可以運行良好,大網(wǎng)站則需要有多個服務(wù)器。而如果你處于中間地帶,或者你的網(wǎng)站正在由小網(wǎng)站發(fā)展壯大起來,那你就要做些有意思的選擇了。

如果你只具配置有單一服務(wù)器的能力,那么在流量峰值或整體流量迅速增長時,你會面臨極大風(fēng)險。因為此時你的擴(kuò)展性會受限,此時解決問題的方法可以包括優(yōu)化應(yīng)用程序、把網(wǎng)絡(luò)服務(wù)器改成 NGINX、換一個更大更快的服務(wù)器,或者把存儲任務(wù)轉(zhuǎn)移到內(nèi)容分發(fā)網(wǎng)絡(luò)(CDN)等。這其中每一個選項都需要耗費時間、成本,并且在實施過程中都可能會引入錯誤和問題。

此外,配置單一服務(wù)器的情況下,你的網(wǎng)站就有一個單一的失敗節(jié)點,會有很多問題造成你的網(wǎng)站下線而且沒有很快很簡捷的解決方法。

如果把配置單一服務(wù)器改成使用 NGINX,可以自由選擇開源 NGINX 軟件或 NGINX Plus。NGINX Plus 包含企業(yè)級支持及額外功能。有些額外功能可以在單一服務(wù)器配置狀況下實現(xiàn),例如實時活動監(jiān)控,而有些功能只有在把 NGINX Plus 作為多個服務(wù)器配置下的反向代理服務(wù)器時才會出現(xiàn),例如負(fù)載均衡和會話持久性。

綜合以上所有考慮,除非你確信你的網(wǎng)站在接下來很長時間都不會擴(kuò)大規(guī)模,停止運行也不會有大麻煩,可以抵抗一些其他的風(fēng)險,那可以配置單一服務(wù)器。但別忘了配置多個服務(wù)器幾乎可以隨意擴(kuò)展---單次失敗完全可以處理,能迅速擴(kuò)充容量,總之你應(yīng)用的性能由你來定。
Tip 3 – Change Your Web Server to NGINX

技巧3---把你的 web 服務(wù)器改成 NGINX

在網(wǎng)絡(luò)發(fā)展早期,Apache等同于web 服務(wù)器。但是21世紀(jì)初 NGINX 誕生之后使用越來越廣泛,它已經(jīng)成為世界上流量前1000、10000和100000的公司的 web 服務(wù)器首選。

NGINX 的設(shè)計初衷是解決 C10K 問題,也就是在給定內(nèi)存預(yù)算的范圍內(nèi)能支持10000以上的同時訪問。其它 web 服務(wù)器需要給每個訪問分配一部分內(nèi)存,但當(dāng)幾千名用戶同時訪問網(wǎng)站時,它們會面臨物理內(nèi)存不足、運行緩慢或崩潰的問題。NGINX 分別處理每個請求,并且能優(yōu)雅地應(yīng)對更多用戶。(如上文所述,它在其它功能方面也有優(yōu)異表現(xiàn)。)

以下為 NGINX 架構(gòu)的概述。

在本圖中,是一個 Python 應(yīng)用程序服務(wù)器的后臺應(yīng)用程序塊,需要通過 FastCGI 來訪問。NGINX 并不知道如何運行 Python,因此它需要關(guān)口來進(jìn)入一個能夠運行 Python 的環(huán)境。FastCGI 是 PHP、Python 等語言廣泛使用的用戶界面。

不過,Python 和 NGINX 之間的溝通更常用的備選是服務(wù)網(wǎng)關(guān)接口(WSGI)。WSGI 可以在多線程、多進(jìn)程環(huán)境下運行,因此它可以在本文提到的所有配置選擇下運行。

如果你要把 NGINX 作成你的 web 服務(wù)器,網(wǎng)上有很多操作幫助信息:

配置 gunicorn---綠色獨角獸,一個很有名的 WSGI 服務(wù)器,以便使用 NGINX。

配置 uWSGI---另外一個有名的 WSGI 服務(wù)器,以便使用 NGINX。uWSGI 能夠直接支持 NGINX。

使用 uWSGI、NGINX 和 Django---一個很常用的 Python 網(wǎng)站框架。

以下片段展示了如何配置 NGINX 來與 uWSGI 一起運行(給出的實例是使用 Python 框架 Django 的一個項目):

http {
    ...
    upstream django {
       server 127.0.0.1:29000;
    }

    server {
        listen 80;
        server_name myapp.example.com;

        root /var/www/myapp/html;

        location / {
            index index.html;
        }

        location /static/  {
            alias /var/django/projects/myapp/static/;
        }

        location /main {
            include /etc/nginx/uwsgi_params;
            uwsgi_pass django;

            uwsgi_param Host $host;
            uwsgi_param X-Real-IP $remote_addr;
            uwsgi_param X-Forwarded-For $proxy_add_x_forwarded_for;
            uwsgi_param X-Forwarded-Proto $http_x_forwarded_proto;
        }
    }
}
技巧4——實施靜態(tài)數(shù)據(jù)緩存

靜態(tài)數(shù)據(jù)緩存包括把那些不經(jīng)常變更的文件(也許是幾個小時,也許是永遠(yuǎn)不變)存在一個應(yīng)用程序服務(wù)器之外的地方。靜態(tài)文件的典型例子就是作為網(wǎng)頁內(nèi)容一部分展示的 JPEG 圖像。

靜態(tài)文件緩存是增強(qiáng)應(yīng)用程序性能的常見方法,而且實際上會在下面幾個層面發(fā)生:

在用戶的瀏覽器

多個層級的網(wǎng)絡(luò)提供者---從一家公司的內(nèi)網(wǎng),到互聯(lián)網(wǎng)服務(wù)供應(yīng)商(ISP)

web 服務(wù)器上,正如本文所述

在 web 服務(wù)器上實施靜態(tài)數(shù)據(jù)緩存有兩個好處:

更快傳送到用戶---NGINX 針對靜態(tài)數(shù)據(jù)緩存做了優(yōu)化,執(zhí)行靜態(tài)內(nèi)容的請求的速度比應(yīng)用程序服務(wù)器快得多。

減輕應(yīng)用服務(wù)器的負(fù)擔(dān)---應(yīng)用服務(wù)器甚至不會收到緩存靜態(tài)數(shù)據(jù)的請求,因為網(wǎng)絡(luò)服務(wù)器已經(jīng)實現(xiàn)這些請求。

靜態(tài)文件緩存在單個服務(wù)器執(zhí)行時運行良好,但其實硬件方面依然由 web 服務(wù)器和應(yīng)用程序服務(wù)器共享。如果 web 服務(wù)器使用硬件找回緩存的文件(及時非常高效)應(yīng)用程序?qū)o法使用這些硬件,運行速度可能會受到影響。

要支持瀏覽器緩存,就要為靜態(tài)文件正確設(shè)置 HTTP 標(biāo)頭。需要考慮 HTTP 緩存控制標(biāo)頭(尤其是它的 max?age 設(shè)置)、Expires 標(biāo)頭和實體標(biāo)簽。如想了解更多這方面的介紹,可以參考 Using NGINX as an Application Gateway with uWSGI and Django。

下面的代碼配置 NGINX,用于緩存包括 JPEG 文件、GIF、PNG文件、MP4 視頻文件、ppt等多種類型的靜態(tài)文件(用你的網(wǎng)址來替代 www.example.com ):

server {
    # substitute your web server"s URL for "www.example.com"
    server_name www.example.com;
    root /var/www/example.com/htdocs;
    index index.php;
    access_log /var/log/nginx/example.com.access.log;
    error_log /var/log/nginx/example.com.error.log;

   location / {
        try_files $uri $uri/ /index.php?$args;
    }

   location ~ .php$ {
        try_files $uri =404;
        include fastcgi_params;
        # substitute the socket, or address and port, of your Python server
        fastcgi_pass unix:/var/run/php5-fpm.sock;
        #fastcgi_pass 127.0.0.1:9000;
    }  

   location ~* .(ogg|ogv|svg|svgz|eot|otf|woff|mp4|ttf|css|rss|atom|js|jpg
                  |jpeg|gif|png|ico|zip|tgz|gz|rar|bz2|doc|xls|exe|ppt|tar|mid
                  |midi|wav|bmp|rtf)$ {
        expires max;
        log_not_found off;
        access_log off;
    }
}
技巧5---實施微程序緩存

微程序緩存給了那些運行 Python、PHP 和其它語言的應(yīng)用程序服務(wù)器提升性能的大好機(jī)會??删彺娴木W(wǎng)頁有以下3種類型:

靜態(tài)文件---可緩存,見技巧4。

應(yīng)用程序生成的、非個人化頁面---一般來說,緩存這些沒有意義,因為這些內(nèi)容需要不斷更新。舉個例子,用戶登錄電商網(wǎng)站時看到的頁面(見下段)---在售商品、同類商品推薦等等可能會不斷更新,因此提供最新的網(wǎng)頁非常重要。不過,如果另一個用戶在十分之一秒之后登錄,向他們展示前一位用戶看到的同樣頁面也沒有什么問題。

應(yīng)用程序生成的、個人化頁面---這些通常不會被緩存,因為它們是單個用戶所屬,而且同一個用戶也不會再次看到相同的頁面。舉個例子,用戶登錄電商網(wǎng)站后看到的頁面,同樣的頁面不能向其他用戶展示。

微程序緩存對上述第二種網(wǎng)頁類型很有用---應(yīng)用程序生成的、非個人化頁面。微是一個概括的時間范圍。如果你的網(wǎng)站一秒之內(nèi)數(shù)次生成同樣的頁面,緩存一秒鐘就不會影響網(wǎng)頁的新鮮度。不過這個概括的緩存時間期限會極大地減輕應(yīng)用程序服務(wù)器的負(fù)擔(dān),尤其是流程峰值期間。在緩存逾時期限內(nèi),不用生成10次、20次、100次(相同的內(nèi)容),而是生成既定的網(wǎng)頁一次,然后這個網(wǎng)頁就會被緩存,并且通過緩存向多個用戶展示。

而這產(chǎn)生的效果卻不可思議,服務(wù)器一秒鐘處理大量請求運行緩慢,但在只處理一個請求時速度是極快的。(當(dāng)然,還有任何個人化的頁面)。設(shè)置一秒超時的代理服務(wù)器這樣的核心變化只需要幾行配置代碼。

proxy_cache_path /tmp/cache keys_zon=cache:10m levels=1:2 inactive=600s max_size=100m;
server {
    proxy_cache cache;
    proxy_cache_valid 200 1s;
    ...
}

更多配置范例,請參考 Tyler Hicks?Wright 的博客 Python and uWSGI with NGINX.。

結(jié)論

在這部分,本文介紹了提升單一服務(wù)器提升 Python 應(yīng)用性能的解決方案,可以在單一服務(wù)器上配置,也可在反向代理服務(wù)器或多帶帶的緩存服務(wù)器上實現(xiàn)。(緩存在多帶帶的服務(wù)器上運行更好。)接下來的第二部分介紹需要兩個或更多服務(wù)器才能實現(xiàn)的性能提升方案。

當(dāng)然如果你想了解 NGINX Plus 適用于你的應(yīng)用程序的高級功能,例如支持、實時活動監(jiān)控、運行時同時配置,可以去 NGINX 官網(wǎng)查看。

OneAPM 能夠幫你查看 Python 應(yīng)用程序的方方面面,不僅能夠監(jiān)控終端的用戶體驗,還能監(jiān)控服務(wù)器性能,同時還支持追蹤數(shù)據(jù)庫、第三方 API 和 Web 服務(wù)器的各種問題。想閱讀更多技術(shù)文章,請訪問 OneAPM 官方技術(shù)博客。

本文轉(zhuǎn)自 OneAPM 官方博客

原文地址:Maximizing Python Performance with NGINX, Part I: Web Serving and Caching

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/39292.html

相關(guān)文章

  • 利用 NGINX 大化 Python 性能一部Web 服務(wù)緩存

    摘要:無論是將其用作的服務(wù)器反向代理服務(wù)器負(fù)載均衡器,還是同時使用以上三種功能,和都能帶來很大好處。再就是下篇文章會介紹如何把和當(dāng)作反向代理服務(wù)器和多個應(yīng)用程序服務(wù)器的負(fù)載均衡器。而使用將會有助于解決這一問題。 【編者按】本文主要介紹 nginx 的主要功能以及如何通過 NGINX 優(yōu)化 Python 應(yīng)用性能。本文系國內(nèi) ITOM 管理平臺 OneAPM 編譯呈現(xiàn)。 Python 的著名之...

    v1 評論0 收藏0
  • 利用 NGINX 大化 Python 性能,第二部:負(fù)載均衡監(jiān)控

    摘要:現(xiàn)有的服務(wù)器和應(yīng)用程序服務(wù)器相結(jié)合并在一個冒泡中運行,無法直接接觸網(wǎng)絡(luò)流量,由反向代理服務(wù)器提出填鴨式請求。賦予高可用性讓你的反向代理服務(wù)器鏡像到在線備份,同時擁有備用的應(yīng)用程序服務(wù)器,讓你的站點高度可用。 【編者按】本文主要介紹 NGINX 的主要功能以及如何通過 Nginx 優(yōu)化 Python 應(yīng)用性能。本文系國內(nèi) ITOM 管理平臺 OneAPM 編譯呈現(xiàn)。 本文上一篇系: 利用...

    zhangrxiang 評論0 收藏0
  • 利用 NGINX 大化 Python 性能,第二部:負(fù)載均衡監(jiān)控

    摘要:現(xiàn)有的服務(wù)器和應(yīng)用程序服務(wù)器相結(jié)合并在一個冒泡中運行,無法直接接觸網(wǎng)絡(luò)流量,由反向代理服務(wù)器提出填鴨式請求。賦予高可用性讓你的反向代理服務(wù)器鏡像到在線備份,同時擁有備用的應(yīng)用程序服務(wù)器,讓你的站點高度可用。 【編者按】本文主要介紹 NGINX 的主要功能以及如何通過 Nginx 優(yōu)化 Python 應(yīng)用性能。本文系國內(nèi) ITOM 管理平臺 OneAPM 編譯呈現(xiàn)。 本文上一篇系: 利用...

    Snailclimb 評論0 收藏0
  • Apache 與 Nginx 性能對比:Web 服務(wù)器優(yōu)化技術(shù)

    摘要:服務(wù)器市場份額。子進(jìn)程負(fù)責(zé)創(chuàng)建由指令設(shè)置的服務(wù)器線程,同時還負(fù)責(zé)監(jiān)聽接收到的請求,并將請求分發(fā)給處理線程。在版本引入了模塊,這個模塊基于模塊創(chuàng)建的,并加入了獨立的監(jiān)聽線程來管理請求處理完成后的休眠的連接?;谑录姆?wù)器完勝。 譯文首發(fā)于 Apache 與 Nginx 性能對比:Web 服務(wù)器優(yōu)化技術(shù),轉(zhuǎn)載請注明出處。 多年前 Apache 基金會 Web 服務(wù)器 簡稱「Apache」...

    shadowbook 評論0 收藏0
  • Apache 與 Nginx 性能對比:Web 服務(wù)器優(yōu)化技術(shù)

    摘要:服務(wù)器市場份額。子進(jìn)程負(fù)責(zé)創(chuàng)建由指令設(shè)置的服務(wù)器線程,同時還負(fù)責(zé)監(jiān)聽接收到的請求,并將請求分發(fā)給處理線程。在版本引入了模塊,這個模塊基于模塊創(chuàng)建的,并加入了獨立的監(jiān)聽線程來管理請求處理完成后的休眠的連接?;谑录姆?wù)器完勝。 譯文首發(fā)于 Apache 與 Nginx 性能對比:Web 服務(wù)器優(yōu)化技術(shù),轉(zhuǎn)載請注明出處。 多年前 Apache 基金會 Web 服務(wù)器 簡稱「Apache」...

    wangbjun 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<