nginx與apache的對比
今天準備較詳細的對比一下apache httpd與nginx兩個web伺服器的異同點、優缺點。由於我並不是做web開發的,所以有什麼理解錯誤還請指出,想要了解它們是因為工作中有時候會用到它,有系統中用到了nginx+apache。本文絕大多數資料都是摘抄網上,自己做的只就是整合網上零散的資源然後加上自己的一點見解。簡單的說apache httpd和nginx都是web伺服器,但兩者適應的場景不同,也就是兩者專注於解決不同的問題。apache httpd:穩定、對動態請求處理強,但同時高併發時效能較弱,耗費資源多。nginx:高併發處理能力強、擅長處理靜態請求、反向**、均衡負載。在 這篇文章詳細列出了apache與nginx的13個異同點,下面我們來一一分析其原理
1、nginx相對於apache的優點: 輕量級,同樣起web 服務,比apache 占用更少的記憶體及資源 ,抗併發,nginx 處理請求是非同步非阻塞的,而apache 則是阻塞型的,在高併發下nginx 能保持低資源低消耗高效能,高度模組化的設計,編寫模組相對簡單 ,社群活躍,各種高效能模組出品迅速啊
apache 相對於nginx 的優點: rewrite ,比nginx 的rewrite 強大 ,模組超多,基本想到的都可以找到 少bug ,nginx 的bug 相對較多 超穩定。存在就是理由,一般來說,需要效能的web 服務,用nginx 。如果不需要效能只求穩定,那就apache 吧。後者的各種功能模組實現得比前者,例如ssl 的模組就比前者好,可配置項多。這裡要注意一點,epoll(freebsd 上是 kqueue )網路io 模型是nginx 處理效能高的根本理由,但並不是所有的情況下都是epoll 大獲全勝的,如果本身提供靜態服務的就只有寥寥幾個檔案,apache 的select 模型或許比epoll 更高效能。當然,這只是根據網路io 模型的原理作的乙個假設,真正的應用還是需要實測了再說的。
##這個應該與前面說的幾點都有關係:nginx採用epoll io復用模型;非同步處理請求;執行緒與請求是一對多關係。
6、從個人過往的使用情況來看,nginx的負載能力比apache高很多。最新的伺服器也改用nginx了。而且nginx改完配置能-t測試一下配置有沒有問題,apache重啟的時候發現配置出錯了,會很崩潰,改的時候都會非常小心翼翼現在看有好多集群站,前端nginx抗併發,後端apache集群,配合的也不錯。
##在這點裡面,我們主要關注這點:nginx+apache結合使用。既然兩者各有優勢,那我們就揚長避短,nginx做前端負責進行抗併發、負載均衡、做靜態檔案快取,後端採用apache處理動態請求。
7、nginx處理動態請求是雞肋,一般動態請求要apache去做,nginx只適合靜態和反向。
##nginx處理動態請求是雞肋的原因誰能從原理方面幫解釋一下?是不是由於對php這種語言支援不夠好?對nginx適合做的就是靜態請求和反向**,反向**是什麼東東?簡單的說是客戶端將這nginx伺服器就作為自己的目標機器,將請求發給nginx機器,至於nginx機器是將客戶端需要的資源從**獲得,客戶端不在意(這就有區別與正向**,在正向**中是我不能訪問目標機器,因為我將請求發給你**機器,然後以你的名義去獲得我需要的資源)。
8、從我個人的經驗來看,nginx是很不錯的前端伺服器,負載效能很好,在老奔上開nginx,用webbench模擬10000個靜態檔案請求毫不吃力。apache對php等語言的支援很好,此外apache有強大的支援網路,發展時間相對nginx更久,bug少但是apache有先天不支援多核心處理負載雞肋的缺點,建議使用nginx做前端,後端用apache。大型網站建議用nginx自代的集群功能
這個還是在說nginx+apache結合是乙個不錯的選擇。
9、nginx優於apache的主要兩點:1.nginx本身就是乙個反向**伺服器 2.nginx支援7層負載均衡;其他的當然,nginx可能會比apache支援更高的併發,但是根據netcraft的統計,2023年4月的統計資料,apache依然占有62.71%,而nginx是7.35%,因此總得來說,aapche依然是大部分公司的首先,因為其成熟的技術和開發社群已經也是非常不錯的效能。
##apache早出現,當初人們沒選擇,況且小壓力的**也用apache就足夠應付請求壓力,所以兩者市場占有率是有差距的。
10、你對web server的需求決定你的選擇。大部分情況下nginx都優於apache,比如說靜態檔案處理、php-cgi的支援、反向**功能、前端cache、維持連線等等。在apache+php(prefork)模式下,如果php處理慢或者前端壓力很大的情況下,很容易出現apache程序數飆公升,從而拒絕服務的現象。
##apache的缺陷,抗壓不行,且由於執行緒數飆公升,資源需求量也是極大
11、可以看一下nginx lua模組:比nginx多的模組,可直接用lua實現apache是最流行的,why?大多數人懶得更新到nginx或者學新事物
##…12、對於nginx,我喜歡它配置檔案寫的很簡潔,正則配置讓很多事情變得簡單執行效率高,占用資源少,**功能強大,很適合做前端響應伺服器
##看了一下,nginx的配置檔案確實更簡潔,也容易理解
13、apache在處理動態有優勢,nginx併發性比較好,cpu記憶體占用低,如果rewrite頻繁,那還是apache吧
希望對於剛接觸apahce和nginx的人有一定的幫助。使用乙個產品不能糊里糊塗的使用,我們需要了解其優點和缺點,這樣才能更好的使用它們。
Apache和Nginx的優缺點
nginx相對於apache的優點 1 輕量級,同樣起web 服務,比apache占用更少的記憶體及資源 2 抗併發,nginx 處理請求是非同步非阻塞的,而apache 則是阻塞型的,在高併發下nginx 3 能保持低資源低消耗高效能 4 高度模組化的設計,編寫模組相對簡單 5 社群活躍,各種高效...
轉 Nginx和Apache 優缺點
目前單位的web服務才從windows轉向linux,很多服務還不是很熟悉,而且目前還不需要處理高併發,這裡做個記錄,以備將來所用。nginx 相對 apache 的優點 apache 相對nginx 的優點 存在就是理由,一般來說,需要效能的web 服務,用nginx 如果不需要效能只求穩定,那就...
Apache和Nginx的優缺點比較
nginx優點 輕量級,同樣的web 服務,比apache 占用更少的記憶體及資源 抗併發,nginx 處理請求是非同步非阻塞的,而apache 則是阻塞型的,在高併發下nginx 能保持低資源低消耗高效能 高度模組化的設計,編寫模組相對簡單 apache 的優點 rewrite 強大 模組多,功能...