如上圖,因為google被牆,我們需要vpn翻牆才能訪問google.com。
vpn對於"我們"來說,是可以感知到的(我們連接vpn)。
vpn對於"google伺服器"來說,是不可感知的(google只知道有http請求過來)。
對於人來說可以感知到,但對伺服器來說感知不到的,我們叫他正向代理伺服器。
反向代理:通過反向代理實現負載均衡
如上圖,我們訪問baidu.com的時候,baidu有一個代理伺服器,通過這個代理伺服器,可以做負載均衡,路由到不同的server。
此代理伺服器,對於「我們」來說是不可感知的(我們只能感知到訪問的是百度的伺服器,不知道中間還有代理伺服器來做負載均衡)。
此代理伺服器,對於"server1 server2 server3"是可感知的(代理伺服器負載均衡路由到不同的server)
對於人來說不可感知,但對於伺服器來說是可以感知的,我們叫他反向代理伺服器
To have a summary
說白了:「正向」、「反向」是相對於人的感知來說的。
人能感受到的代理就是正向代理,人感受不到的代理就是反向代理。
Nginx是什麼Nginx ("engine x") 是一個高性能的HTTP和反向代理伺服器,也是一個IMAP/POP3/SMTP伺服器。
Php-fpm是什麼1、cgi、fast-cgi協議cgi的歷史早期的webserver只處理html等靜態文件,但是隨著技術的發展,出現了像php等動態語言。
webserver處理不了了,怎麼辦呢?那就交給php解釋器來處理吧!
交給php解釋器處理很好,但是,php解釋器如何與webserver進行通信呢?
為了解決不同的語言解釋器(如php、python解釋器)與webserver的通信,於是出現了cgi協議。只要你按照cgi協議去編寫程序,就能實現語言解釋器與webwerver的通信。如php-cgi程序。
有了cgi協議,解決了php解釋器與webserver通信的問題,webserver終於可以處理動態語言了。但是,webserver每收到一個請求,都會去fork一個cgi進程,請求結束再kill掉這個進程。這樣有10000個請求,就需要fork、kill php-cgi進程10000次。
有沒有發現很浪費資源?
於是,出現了cgi的改良版本,fast-cgi。fast-cgi每次處理完請求後,不會kill掉這個進程,而是保留這個進程,使這個進程可以一次處理多個請求。這樣每次就不用重新fork一個進程了,大大提高了效率。
php-fpm即php-Fastcgi Process Manager.
php-fpm是 FastCGI 的實現,並提供了進程管理的功能。
進程包含 master 進程和 worker 進程兩種進程。
master 進程只有一個,負責監聽埠,接收來自 Web Server 的請求,而 worker 進程則一般有多個(具體數量根據實際需要配置),每個進程內部都嵌入了一個 PHP 解釋器,是 PHP 代碼真正執行的地方。
上面我們說了,Nginx不只有處理http請求的功能,還能做反向代理。Nginx通過反向代理功能將動態請求轉向後端Php-fpm。
下面我們來配置一個全新的Nginx+Php-fpm
1、配置nginx.conf文件
進入nginx目錄下,編輯 nginx.conf文件。
如圖,在nginx.conf最後一行,添加include文件
進入上面include的路徑,添加一個server.
總而言之:當我們訪問www.example.com的時候,處理流程是這樣的:
下面我們啟用php的php-fpm來處理這個請求
打開php-fpm.conf文件,我們看到如下配置:
即:php-fpm模塊監聽127.0.0.1:9000埠,等待請求到來去處理。
nginx與php-fpm的結合,完整的流程是這樣的。
如上圖,有一個master進程,3個worker進程。
我們編輯文件如下圖:
更多精彩,請關注公眾號「聊聊代碼」,讓我們一起聊聊「左手代碼右手詩」的事兒。