电竞比分网-中国电竞赛事及体育赛事平台

分享

為什么PHP程序員要了解Nginx服務器?Apache與Nginx的優(yōu)缺點比

 小馬哥技術屋 2016-11-21
一、為什么PHP程序員要了解Nginx服務器?

       Apache是非常強大的Web服務器,模塊化結(jié)構(gòu),也是Web服務端的鼻祖。除了捆綁一些其他的工具外,Apache已經(jīng)成為了世上最廣泛部署的開源系統(tǒng),直到最近,世界上大多數(shù)網(wǎng)站仍運行著Apache系統(tǒng)。但是,Apache并不是完美的,并且不再適合大規(guī)模系統(tǒng)。為什么?因為他的進程模式雖然簡單而靈活,但并不適合大規(guī)模尤其是當要處理像PHP這種需要占用大量內(nèi)存應用程序代碼時。所以當超過100個用戶同時訪問時,Apache就已經(jīng)滿負荷了。



        目前有兩個主要的解決方法:


本帖隱藏的內(nèi)容

第一個方法,也是現(xiàn)有系統(tǒng)上最容易的方法,就是在Apache前端安裝負載均衡服務器或者Nginx來處理客戶端連接部分。負載均衡服務器,像 HAProxy或者Nginx能輕松處理成千上萬條并發(fā)的連接,并使Apache能夠真正的僅作為后端應用程序工作,來處理32個或是更多的進程。

        第二種方案,也是最通用的辦法就是用Nginx替換Apache,同時使用PHP-PFM作為應用服務器。就像之前所提到的,這將分割前端客戶端通信部分和后端應用程序部分。Nginx處理HTTP通訊協(xié)議,同時FPM處理后端應用程序部分,和那32個進程進行交互。



二、Nginx相對于apache的優(yōu)缺點是什么?


1、Nginx相對于apache的優(yōu)點:

       輕量級,同樣起web 服務,比apache 占用更少的內(nèi)存及資源;
       抗并發(fā),nginx 處理請求是異步非阻塞的,而apache 則是阻塞型的,在高并發(fā)下nginx 能保持低資源低消耗高性;
       作為 Web 服務器:相比 Apache,Nginx 使用更少的資源,支持更多的并發(fā)連接,體現(xiàn)更高的效率,這點使 Nginx 尤其受到虛擬主機提供商的歡迎。在高連接并發(fā)的情況下,Nginx是Apache服務器不錯的替代品: Nginx在美國是做虛擬主機生意的老板們經(jīng)常選擇的軟件平臺之一. 能夠支持高達 50,000 個并發(fā)連接數(shù)的響應。
        Nginx 靜態(tài)處理性能比 Apache 高 3倍以上
       高度模塊化的設計,編寫模塊相對簡單;
      社區(qū)活躍,各種高性能模塊出品迅速。

2、apache 相對于nginx 的優(yōu)點

本帖隱藏的內(nèi)容

    rewrite ,比nginx 的rewrite 強大 ,模塊超多,基本想到的都可以找到
        少bug ,nginx 的bug 相對較多 ;
       超穩(wěn)定 ,一般來說,需要性能的web 服務,用nginx 。如果不需要性能只求穩(wěn)定,那就apache 吧。
       Nginx作為負載均衡服務器: Nginx 既可以在內(nèi)部直接支持 Rails 和 PHP 程序?qū)ν膺M行服務, 也可以支持作為 HTTP代理 服務器對外進行服務.              Nginx采用C進行編寫, 不論是系統(tǒng)資源開銷還是CPU使用效率都比 Perlbal 要好很多.
       作為郵件代理服務器: Nginx 同時也是一個非常優(yōu)秀的郵件代理服務器(最早開發(fā)這個產(chǎn)品的目的之一也是作為郵件代理服務器), Last.fm 描述了成功并且美妙的使用經(jīng)驗.
       Nginx 是一個安裝非常的簡單 , 配置文件非常簡潔(還能夠支持perl語法), Bugs 非常少的服務器: Nginx 啟動特別容易, 并且?guī)缀蹩梢宰龅?*24不間斷運行,即使運行數(shù)個月也不需要重新啟動. 你還能夠不間斷服務的情況下進行軟件版本的升級 .


3、Nginx 配置簡潔, Apache 復雜


      Apache 對 PHP 支持比較簡單,Nginx 需要配合其他后端用
      Apache 的組件比 Nginx 多
      現(xiàn)在 Nginx 才是 Web 服務器的首選


4、最核心的區(qū)別在于apache是同步多進程模型,一個連接對應一個進程;nginx是異步的,多個連接(萬級別)可以對應一個進程


5、nginx處理靜態(tài)文件好,耗費內(nèi)存少.但無疑apache仍然是目前的主流,有很多豐富的特性.所以還需要搭配著來.當然如果能確定nginx就適合需求,那么使用nginx會是更經(jīng)濟的方式.


6、從個人過往的使用情況來看,nginx的負載能力比apache高很多。最新的服務器也改用nginx了。而且nginx改完配置能-t測試一下配置有沒有問題,apache重啟的時候發(fā)現(xiàn)配置出錯了,會很崩潰,改的時候都會非常小心翼翼現(xiàn)在看有好多集群站,前端nginx抗并發(fā),后端apache集群,配合的也不錯。


7、nginx處理動態(tài)請求是雞肋,一般動態(tài)請求要apache去做,nginx只適合靜態(tài)和反向。


8、從個人經(jīng)驗來看,nginx是很不錯的前端服務器,負載性能好,用webbench模擬10000個靜態(tài)文件請求毫不吃力。apache對php等語言的支持很好,此外apache有強大的支持網(wǎng)絡,發(fā)展時間相對nginx更久,bug少。但是apache有先天不支持多核心處理負載的缺點,建議使用nginx做前端,后端用apache。大型網(wǎng)站建議用nginx自代的集群功能 !


9、Nginx優(yōu)于apache的主要兩點:1.Nginx本身就是一個反向代理服務器 2.Nginx支持7層負載均衡;其他的當然,Nginx可能會比apache支持更高的并發(fā),但是根據(jù)NetCraft的統(tǒng)計,2011年4月的統(tǒng)計數(shù)據(jù),Apache依然占有62.71%,而Nginx是7.35%,因此總得來說,Aapche依然是大部分公司的首先,因為其成熟的技術和開發(fā)社區(qū)已經(jīng)也是非常不錯的性能。


10、你對web server的需求決定你的選擇。大部分情況下nginx都優(yōu)于APACHE,比如說靜態(tài)文件處理、PHP-CGI的支持、反向代理功能、前端Cache、維持連接等等。在Apache+PHP(prefork)模式下,如果PHP處理慢或者前端壓力很大的情況下,很容易出現(xiàn)Apache進程數(shù)飆升,從而拒絕服務的現(xiàn)象。


11、可以看一下nginx lua模塊:https://github.com/chaoslaw...apache比nginx多的模塊,可直接用lua實現(xiàn)apache是最流行的,why?大多數(shù)人懶得更新到nginx或者學新事物


12、對于nginx,我喜歡它配置文件寫的很簡潔,正則配置讓很多事情變得簡單運行效率高,占用資源少,代理功能強大,很適合做前端響應服務器


13、Apache在處理動態(tài)有優(yōu)勢,Nginx并發(fā)性比較好,CPU內(nèi)存占用低,如果rewrite頻繁,那還是Apache吧!

    本站是提供個人知識管理的網(wǎng)絡存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導購買等信息,謹防詐騙。如發(fā)現(xiàn)有害或侵權內(nèi)容,請點擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多