查閱了資料后, 有一個籠統(tǒng)的理解, 請指正:
在一個計算機上運行著一個網(wǎng)站, 有如下分工.
1. Nginx 監(jiān)聽計算機的某一個端口(比如80), 等待用戶的request
2. 遠程有一個用戶執(zhí)行了一個request, Nginx監(jiān)聽到了, 然后把這個請求傳給CGI程序(比如Python的WSGI)
3. CGI程序接受請求, 運行對應(yīng)的代碼, 然后返回一個response
上面的理解對嗎? 如果是對的, Nginx為什么要存在呢? 因為好像就算沒有Nginx, 直接用CGI接受請求也是可以的樣子, 僅僅是為了負載平衡嗎?
謝謝.
蟹妖。一股知乎范兒
首先把問題修正為為什么CGI與WebServer不能互相替代?
因為CGI
是一種標準,Nginx
則是一種應(yīng)用。兩者不是同類,所以下面用WebServer
代替Nginx
。
CGI
是一種標準,Nginx
則是一種應(yīng)用。
從瀏覽器
的角度來看,瀏覽器只負責發(fā)送請求,接收來自WebServer
的返回結(jié)果并渲染之。對于WebServer
來講,它需要做的僅僅是接收請求,尋找瀏覽器
請求的文件并且發(fā)送回去。如果僅僅是這樣,世界就很完美了。
但是后來發(fā)生的事情大家都知道了。。我們不光要瀏覽靜態(tài)網(wǎng)頁,我們還要登陸論壇、發(fā)帖罵人灌水踩答案點贊刷聲望等等。這些行為是靜態(tài)的Html沒法完成的。所以有了JS、Flash等等基于前端的交互技術(shù)。WebServer
把包含了這些代碼的文件發(fā)給瀏覽器
,后者把它解析稱它應(yīng)該有的樣子(或者不應(yīng)該有的樣子,比如IE6),我們可以在頁面上看看動畫什么的,這些稱之為前段交互技術(shù)。
但是有些交互前端做不了, 比如我上次發(fā)了一個高清無碼套圖,我要看到大家的反應(yīng),點個贊啊樓主好人啊之類的,那么這個技術(shù)就要用到數(shù)據(jù)庫,但是數(shù)據(jù)庫本身是需要另外一種語言來操作的,這種語言可以是python、prel、Ruby、PHP等等,我們稱之為動態(tài)語言
。他們對數(shù)據(jù)庫進行增刪查改四大操作,并且返回結(jié)果給WebServer
,后者再傳給瀏覽器。
由于有很多動態(tài)語言和很多種Web服務(wù)器,他們彼此之間互不兼容,給程序員造成了很大的麻煩。那么,CGI
應(yīng)運而僧。CGI
的定義是統(tǒng)一網(wǎng)關(guān)接口。從此WebServer
收到后臺動態(tài)交互請求就直接發(fā)給CGI
,CGI
發(fā)給動態(tài)語言,動態(tài)語言把結(jié)果發(fā)回給CGI
,CGI
再發(fā)回給WebServer
,后面的事情你都清楚了。。。。
那么結(jié)論就是,CGI
是一個翻譯層,它的功能不是直接提供結(jié)果給瀏覽器,而是翻譯來自WebServer的請求并轉(zhuǎn)給后臺的應(yīng)用程序,并且把執(zhí)行結(jié)果翻譯成靜態(tài)網(wǎng)頁返回給WebServer
,所以,是不能互換的。
最后,寫的比較倉促,很多表述有不嚴謹?shù)牡胤剑瑲g迎拍磚。
太多了,我覺得仔細想想以后我還能列出至少和上面一樣長的nginx的其他好處
瀏覽器跟 Web 服務(wù)器間的通信是 HTTP 協(xié)議。瀏覽器不支持 CGI/FastCGI 協(xié)議,所以無法拋棄 Nginx 直接跟 FPM 、PHP-CGI 等通信。
Nginx本質(zhì)是個web server,如果直接用CGI,那么這個CGI就成了web server,邏輯又混亂了。
CGI是為了處理動態(tài)的邏輯。
web server僅僅是一個HTTP服務(wù)的實現(xiàn),只管收一個請求,然后回復(fù)一個相應(yīng)的響應(yīng)(通常是一個HTML頁面,根據(jù)請求的不同,也可以是其它的文件),不管任何邏輯。所有的邏輯處理,都是扔給CGI的。比如用戶登錄的驗證等。
可以把Nginx想像為傳令兵,主要的活不是他做的,但是如果沒有他,
實際干活的人就是親自跑去接任務(wù)、交任務(wù)。
不是不能做,而是干活的人只愿意關(guān)心工作如何做好,
不愿意做跑腿那堆事兒,把自己的功能弄成大雜燴。
靜態(tài)文件,基本都交給nginx去處理了。
動態(tài)的請求的話,nginx相當于一層路由了,想轉(zhuǎn)到哪兒就轉(zhuǎn)到哪兒,cgi只需要專注處理具體的業(yè)務(wù)邏輯即可
微信掃碼
關(guān)注PHP中文網(wǎng)服務(wù)號
QQ掃碼
加入技術(shù)交流群
Copyright 2014-2025 http://www.miracleart.cn/ All Rights Reserved | php.cn | 湘ICP備2023035733號