久久99久久人婷婷精品综合_超碰aⅴ人人做人人爽欧美_亚洲电影第三页_日韩欧美一中文字暮专区_波多野结衣的一区二区三区_婷婷在线播放_人人视频精品_国产精品日韩精品欧美精品_亚洲免费黄色_欧美性猛交xxxxxxxx

PHP的運行模式小結

<

興安網站制作公司哪家好,找成都創新互聯!從網頁設計、網站建設、微信開發、APP開發、響應式網站建設等網站項目制作,到程序開發,運營維護。成都創新互聯成立于2013年到現在10年的時間,我們擁有了豐富的建站經驗和運維經驗,來保證我們的工作的順利進行。專注于網站建設就選成都創新互聯
div>PHP運行模式有4鐘: 1)cgi 通用網關接口(Common Gateway Interface)) 2) fast-cgi 常駐 (long-live) 型的 CGI 3) cli 命令行運行 (Command Line Interface) 4)web模塊模式 (apache等web服務器運行的模塊模式)
1.CGI(Common Gateway Interface) CGI即通用網關接口(Common Gateway Interface),它是一段程序, 通俗的講CGI就象是一座橋,把網頁和WEB服務器中的執行程序連接起來,它把HTML接收的指令傳遞給服務器的執行程序,再把服務器執行程序的結果返還給HTML頁。CGI 的跨平臺性能極佳,幾乎可以在任何操作系統上實現。 CGI已經是比較老的模式了,這幾年都很少用了。 每有一個用戶請求,都會先要創建cgi的子進程,然后處理請求,處理完后結束這個子進程,這就是fork-and-execute模式。 當用戶請求數量非常多時,會大量擠占系統的資源如內存,CPU時間等,造成效能低下。所以用cgi方式的服務器有多少連接請求就會有多少cgi子進程,子進程反復加載是cgi性能低下的主要原因。 如果不想把 PHP 嵌入到服務器端軟件(如 Apache)作為一個模塊安裝的話,可以選擇以 CGI 的模式安裝。或者把 PHP 用于不同的 CGI 封裝以便為代碼創建安全的 chroot 和 setuid 環境。這樣每個客戶機請求一個php文件,Web服務器就調用php.exe(win下是php.exe,linux是php)去解釋這個文件,然后再把解釋的結果以網頁的形式返回給客戶機。 這種安裝方式通常會把 PHP 的可執行文件安裝到 web 服務器的 cgi-bin 目錄。CERT 建議書 CA-96.11 建議不要把任何的解釋器放到 cgi-bin 目錄。 這種方式的好處是把web server和具體的程序處理獨立開來,結構清晰,可控性強,同時缺點就是如果在高訪問需求的情況下,cgi的進程fork就會成為很大的服務器負擔,想 象一下數百個并發請求導致服務器fork出數百個進程就明白了。這也是為什么cgi一直背負性能低下,高資源消耗的惡名的原因。 CGI模式安裝: CGI已經是比較老的模式了,這幾年都很少用了,所以我們只是為了測試。 安裝CGI模式需要注釋掉 LoadModule php5_module modules/libphp5.so 這行。如果不注釋這行會一直走到handler模式。也就是模塊模式。 然后在增加action: Action application/x-httpd-php /cgi-bin/ 如果在/cgi-bin/目錄找不到php-cgi.可自行從php的bin里面cp一個。 然后重啟apache,再打開測試頁面發現Server API變成:CGI/FastCGI。說明成功切換為cgi模式。 問題: 1) 如果cgi程序放在/usr/local/httpd/cgi-bin/里無法執行,遇到403或500錯誤的話 打開apache錯誤日志 有如下提示: Permission denied: exec of 可以檢查cgi程序的屬性,按Linux contexts文件 里定義的,/usr/local/httpd/cgi-bin/里必須是httpd_sys_script_exec_t 屬性。 通過ls -Z查看,如果不是則通過如下命令更改: chcon -t httpd_sys_script_exec_t /var/www/cgi-bin/*.cgi 如果是虛擬主機里的cgi,則參考問題2使之能正常使用普通的功能后,再通過chcon設置cgi文件的context為 httpd_sys_script_exec_t即可。chcon -R -t httpd_sys_script_exec_t cgi-bin/ 2) apache錯誤提示:.... malformed header from script. Bad header= 根據提示說明有header有問題,查看文件輸出的第一句話是什么,應該類似于如下 Content-type: text/plain; charset=iso-8859-1nn 或者Content-type:text/htmlnn 注意:聲明好Content-type后要輸出兩個空行。 3)apache錯誤提示: Exec format error 腳本解釋器設置錯誤。腳本第一行應該以\'#!解釋器路徑\'的形式, 填寫腳本解釋器的路徑,如果是PERL程序,常見的路徑為: #!/usr/bin/perl 或 #!/usr/local/bin/perl 如果是PHP程序,不需要填寫解釋器路徑,系統會自動找到PHP。 2. Fastcgi模式 fast-cgi 是cgi的升級版本,FastCGI 像是一個常駐 (long-live) 型的 CGI,它可以一直執行著,只要激活后,不會每次都要花費時間去 fork 一次 (這是 CGI 最為人詬病的 fork-and-execute 模式)。 FastCGI的工作原理是: (1)、Web Server啟動時載入FastCGI進程管理器【PHP的FastCGI進程管理器是PHP-FPM(php-FastCGI Process Manager)】(IIS ISAPI或Apache Module); (2)、FastCGI進程管理器自身初始化,啟動多個CGI解釋器進程 (在任務管理器中可見多個php-cgi.exe)并等待來自Web Server的連接。 (3)、當客戶端請求到達Web Server時,FastCGI進程管理器選擇并連接到一個CGI解釋器。Web server將CGI環境變量和標準輸入發送到FastCGI子進程php-cgi。 (4)、FastCGI子進程完成處理后將標準輸出和錯誤信息從同一連接返回Web Server。當FastCGI子進程關閉連接時,請求便告處理完成。FastCGI子進程接著等待并處理來自FastCGI進程管理器(運行在 WebServer中)的下一個連接。在正常的CGI模式中,php-cgi.exe在此便退出了。 在CGI模式中,你可以想象 CGI通常有多慢。每一個Web請求PHP都必須重新解析php.ini、重新載入全部dll擴展并重初始化全部數據結構。使用FastCGI,所有這些都只在進程啟動時發生一次。一個額外的好處是,持續數據庫連接(Persistent database connection)可以工作。 Fastcgi的優點: 1)從穩定性上看, fastcgi是以獨立的進程池運行來cgi,單獨一個進程死掉,系統可以很輕易的丟棄,然后重新分 配新的進程來運行邏輯. 2)從安全性上看,Fastcgi支持分布式運算. fastcgi和宿主的server完全獨立, fastcgi怎么down也不會把server搞垮. 3)從性能上看, fastcgi把動態邏輯的處理從server中分離出來, 大負荷的IO處理還是留給宿主server, 這樣宿主server可以一心一意作IO,對于一個普通的動態網頁來說, 邏輯處理可能只有一小部分, 大量的圖片等靜態 FastCGI缺點:說完了好處,也來說說缺點。從我的實際使用來看,用FastCGI模式更適合生產環境的服務器。但對于開發用機器來說就不太合適。因為當使用 Zend Studio調試程序時,由于 FastCGI會認為 PHP進程超時,從而在頁面返回 500錯誤。這一點讓人非常惱火,所以我在開發機器上還是換回了 ISAPI模式。 安裝fastcgi模式: 安裝apache路徑是/usr/local/httpd/ 安裝php路徑是/usr/local/php/ 1)安裝mod_fastcgi wget tar zxvf mod_fastcgi-2.4.6.tar.gz cd mod_fastcgi-2.4.6 cp Makefile.AP2 Makefile vi Makefile,編輯top_dir = /usr/local/httpd make make install 安裝完后, /usr/local/httpd/modules/多出一個文件:mod_fcgid.so 2)重新編譯php ./configure --prefix=/usr/local/php --enable-fastcgi --enable-force-cgi-redirect --disable-cli make make install 這樣編譯后,在PHP的bin目錄下的php-cgi就是fastcgi模式的php解釋器了 安裝成功后,執行 php -v 輸出 PHP 5.3.2 (cgi-fcgi). 這里輸出帶了cgi-fcgi 注意: 1.編譯參數不能加 –with-apxs=/usr/local/httpd/bin/apxs 否則安裝出來的php執行文件是cli模式的 2 如果編譯時不加--disable-cli則輸出 PHP 5.3.2(cli) 3)配置apache 需要配置apache來以fastcgi模式運行php程序 vi 我們使用虛擬機的方式實現:   復制代碼 代碼如下:   #加載fastcgi模塊 LoadModule fastcgi_module modules/mod_fastcgi.so #//以靜態方式執行fastcgi 啟動了10進程 FastCgiServer /usr/local/PHP/bin/PHP-cgi -processes 10 -idle-timeout 150 -pass-header HTTP_AUTHORIZATION # DocumentRoot /usr/local/httpd/fcgi-bin ServerName ScriptAlias /fcgi-bin/ /usr/local/php/bin/ #定義目錄映射 /fcgi-bin/ 代替 /usr/local/php/bin/ Options +ExecCGI AddHandler fastcgi-script .php .fcgi #.php結尾的請求都要用php-fastcgi來處理 AddType application/x- #增加MIME類型 Action application/x-httpd-php /fcgi-bin/php-cgi #設置php-fastcgi的處理器: /usr/local/php/bin/php-cgi Options Indexes ExecCGI Order allow,deny allow from all 或者   復制代碼 代碼如下:   ScriptAlias /fcgi-bin/ "/usr/local/php/bin" #定義目錄映射FastCgiServer /usr/local/php/bin/php-cgi -processes 10 #配置fastcgi server,SetHandler fastcgi-scriptOptions FollowSymLinksOrder allow,denyAllow from allAddType application/x- #增加MIME類型AddHandler php-fastcgi .php #.php結尾的請求都要用php-fastcgi來處理Action php-fastcgi /fcgi-bin/php-cgi #設置php-fastcgi的處理器 4).restart 下apache,查看phpinfo,如果服務器信息是: Apache/2.2.11 (Unix) mod_fastcgi/2.4.6之類的就說明安裝成功了。 如果出現403的錯誤,查看下/usr/local/httpd/fcgi-bin/是否有足夠的權限。 或者   復制代碼 代碼如下:    Options FollowSymLinks AllowOverride None Order deny,allow Deny from all 改為:   復制代碼 代碼如下:    Options FollowSymLinks AllowOverride None Order allow,deny Allow from all 就可以了。 ps -ef|grep php-cgi可以看見10個fastcgi進程在跑。 3. CLI模式 cli是php的命令行運行模式,大家經常會使用它,但是可能并沒有注意到(例如:我們在linux下經常使用 "php -m"查找PHP安裝了那些擴展就是PHP命令行運行模式;有興趣的同學可以輸入php -h去深入研究該運行模式) 1.讓 PHP 運行指定文件。 php script.php php -f script.php 以上兩種方法(使用或不使用 -f 參數)都能夠運行腳本的script.php。您可以選擇任何文件來運行,您指定的 PHP 腳本并非必須要以 .php 為擴展名,它們可以有任意的文件名和擴展名。 2.在命令行直接運行 PHP 代碼。 php -r "print_r(get_defined_constants());" 在使用這種方法時,請您注意外殼變量的替代及引號的使用。 注: 請仔細閱讀以上范例,在運行代碼時沒有開始和結束的標記符!加上 -r 參數后,這些標記符是不需要的,加上它們會導致語法錯誤。 3.通過標準輸入(stdin)提供需要運行的 PHP 代碼。 以上用法給我們提供了非常強大的功能,使得我們可以如下范例所示,動態地生成 PHP 代碼并通過命令行運行這些代碼: $ some_application | some_filter | php | sort -u >final_output.txt 4. 模塊模式 模塊模式是以mod_php5模塊的形式集成,此時mod_php5模塊的作用是接收Apache傳遞過來的PHP文件請求,并處理這些請求,然后將處理后的結果返回給Apache。如果我們在Apache啟動前在其配置文件中配置好了PHP模塊(mod_php5), PHP模塊通過注冊apache2的ap_hook_post_config掛鉤,在Apache啟動的時候啟動此模塊以接受PHP文件的請求。 除了這種啟動時的加載方式,Apache的模塊可以在運行的時候動態裝載,這意味著對服務器可以進行功能擴展而不需要重新對源代碼進行編譯,甚至根本不需要停止服務器。我們所需要做的僅僅是給服務器發送信號HUP或者AP_SIG_GRACEFUL通知服務器重新載入模塊。但是在動態加載之前,我們需要將模塊編譯成為動態鏈接庫。此時的動態加載就是加載動態鏈接庫。 Apache中對動態鏈接庫的處理是通過模塊mod_so來完成的,因此mod_so模塊不能被動態加載,它只能被靜態編譯進Apache的核心。這意味著它是隨著Apache一起啟動的。 Apache是如何加載模塊的呢?我們以前面提到的mod_php5模塊為例。首先我們需要在Apache的配置文件中添加一行: 該運行模式是我們以前在windows環境下使用apache服務器經常使用的,而在模塊化(DLL)中,PHP是與Web服務器一起啟動并運行的。(是apache在CGI的基礎上進行的一種擴展,加快PHP的運行效率)   復制代碼 代碼如下:   LoadModule php5_module modules/mod_php5.so 這里我們使用了LoadModule命令,該命令的第一個參數是模塊的名稱,名稱可以在模塊實現的源碼中找到。第二個選項是該模塊所處的路徑。如果需要在服務器運行時加載模塊,可以通過發送信號HUP或者AP_SIG_GRACEFUL給服務器,一旦接受到該信號,Apache將重新裝載模塊,而不需要重新啟動服務器。 5.php在Nginx中運行模式(Nginx+ PHP-FPM) 使用FastCGI方式現在常見的有兩種stack:ligthttpd+spawn-fcgi;另外一種是nginx+PHP-FPM(也可以用spawn-fcgi)。 A、如上面所說該兩種結構都采用FastCGI對PHP支持,因此HTTPServer完全解放出來,可以更好地進行響應和并發處理。因此lighttpd和nginx都有small, but powerful和efficient的美譽。 B、該兩者還可以分出一個好壞來,spawn-fcgi由于是lighttpd的一部分,因此安裝了lighttpd一般就會使用spawn-fcgi對php支持,但是目前有用戶說ligttpd的spwan-fcgi在高并發訪問的時候,會出現上面說的內存泄漏甚至自動重啟fastcgi。即:PHP腳本處理器當機,這個時候如果用戶訪問的話,可能就會出現白頁(即PHP不能被解析或者出錯)。 另一個:首先nginx不像lighttpd本身含帶了fastcgi(spawn-fcgi),因此它完全是輕量級的,必須借助第三方的FastCGI處理器才可以對PHP進行解析,因此其實這樣看來nginx是非常靈活的,它可以和任何第三方提供解析的處理器實現連接從而實現對PHP的解析(在nf中很容易設置)。nginx可以使用spwan-fcgi(需要一同安裝lighttpd,但是需要為nginx避開端口,一些較早的blog有這方面安裝的教程),但是由于spawn-fcgi具有上面所述的用戶逐漸發現的缺陷,現在慢慢減少使用nginx+spawn-fcgi組合了。 C、由于spawn-fcgi的缺陷,現在出現了新的第三方(目前還是,聽說正在努力不久將來加入到PHP core中)的PHP的FastCGI處理器,叫做PHP-FPM(具體可以google)。它和spawn-fcgi比較起來有如下優點: 由于它是作為PHP的patch補丁來開發的,安裝的時候需要和php源碼一起編譯,也就是說編譯到php core中了,因此在性能方面要優秀一些; 同時它在處理高并發方面也優于spawn-fcgi,至少不會自動重啟fastcgi處理器。具體采用的算法和設計可以google了解。 因此,如上所說由于nginx的輕量和靈活性,因此目前性能優越,越來越多人逐漸使用這個組合:nginx+PHP/PHP-FPM 6.總結 目前在 HTTPServer這塊基本可以看到有三種stack比較流行: (1)Apache+mod_php5 (2)lighttp+spawn-fcgi (3)nginx+PHP-FPM 三者后兩者性能可能稍優,但是Apache由于有豐富的模塊和功能,目前來說仍舊是老大。有人測試nginx+PHP-FPM在高并發情況下可能會達到Apache+mod_php5的5~10倍,現在nginx+PHP-FPM使用的人越來越多。 互聯網+時代,時刻要保持學習,攜手千鋒PHP,Dream It Possible。

文章名稱:PHP的運行模式小結
文章網址:http://www.js-pz168.com/article18/chdcdp.html

成都網站建設公司_創新互聯,為您提供網站收錄App開發定制網站小程序開發外貿建站移動網站建設

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

猜你還喜歡下面的內容

商城網站建設

網站設計知識

同城分類信息

久久99久久人婷婷精品综合_超碰aⅴ人人做人人爽欧美_亚洲电影第三页_日韩欧美一中文字暮专区_波多野结衣的一区二区三区_婷婷在线播放_人人视频精品_国产精品日韩精品欧美精品_亚洲免费黄色_欧美性猛交xxxxxxxx
国产成人三级在线观看| 国产伦精品一区二区三区照片91| 国产精品日韩欧美一区二区| 日韩av电影免费在线观看| 欧美日韩不卡视频| 中文一区一区三区高中清不卡| 丝袜亚洲精品中文字幕一区| 成人毛片视频在线观看| 欧美精品久久久| 欧美一区二区三区在线观看视频| 中文字幕日韩av资源站| 九九在线精品视频| 国产成人一区二区三区免费看| 宅男一区二区三区| 国产亚洲精品中文字幕| 日韩av高清在线观看| 51精品国产人成在线观看 | 日本在线观看一区二区三区| 欧美日韩的一区二区| 中文字幕日韩一区| 国产乱人伦偷精品视频免下载 | 色婷婷精品大视频在线蜜桃视频| 亚洲精品一区二区三区四区高清| 亚洲v日本v欧美v久久精品| 波多野结衣中文字幕一区 | 亚洲午夜在线视频| eeuss影院一区二区三区| 亚洲欧美日产图| 国产三级精品三级在线专区| 欧美96一区二区免费视频| 国产成人精品福利一区二区三区| 欧美性生活影院| 综合色中文字幕| 成人综合在线网站| 永久免费精品视频网站| 中文一区二区在线观看| 国产麻豆精品视频| 天堂精品一区二区三区| 国产日韩欧美高清| 国产美女精品在线| 亚洲精品久久区二区三区蜜桃臀 | 国产视频一区二区三区在线观看| 久久影院视频免费| 国产精品毛片大码女人| 国产一区二区三区精品视频| 欧洲av一区| 国产日韩欧美制服另类| 国产自产高清不卡| 亚洲春色在线| 国产精品久久久久久久久图文区| 国产精品18久久久久久久网站| 日韩精品无码一区二区三区| 国产亚洲综合色| 国产一区二区三区在线看麻豆| 日韩欧美精品一区二区| 久久久国产精品不卡| 国产一区 二区| 在线观看福利一区| 亚洲欧美偷拍三级| 51精品国产人成在线观看| 欧美美女直播网站| 日韩av网站在线观看| 欧美一区国产一区| 中文av一区二区| 波波电影院一区二区三区| 欧美日韩卡一卡二| 日韩精品亚洲专区| 欧美一区二区福利| 国产精品国产三级国产普通话99 | 久久久久久久免费视频了| 国内精品嫩模私拍在线| 色婷婷一区二区三区四区| 亚洲影院久久精品| 久久精品丝袜高跟鞋| 久久久精品tv| 成人午夜av影视| 欧美高清性hdvideosex| 免费不卡在线视频| 亚洲一卡二卡区| 亚洲自拍与偷拍| 精品欧美日韩| 国产精品乱人伦中文| 91精品久久香蕉国产线看观看| 日韩欧美区一区二| 国产成人精品一区二区三区四区 | 日本免费新一区视频| 偷拍视频一区二区| 亚洲黄网站在线观看| 久久av一区二区三区漫画| 欧美经典三级视频一区二区三区| 99热这里都是精品| 精品久久久久av影院| 成人免费视频一区二区| 91精品国产福利在线观看| 国产一区欧美二区| 欧美日韩高清一区二区| 九色综合国产一区二区三区| 欧美在线免费视屏| 毛片基地黄久久久久久天堂| 色一情一乱一乱一91av| 日韩电影在线看| 日本韩国视频一区二区| 男男成人高潮片免费网站| 色欧美88888久久久久久影院| 五月天久久比比资源色| 一区二区三区在线观看www| 首页亚洲欧美制服丝腿| 色哟哟在线观看一区二区三区| 丝袜美腿亚洲色图| 色94色欧美sute亚洲线路一久 | 亚洲综合精品自拍| 视频一区免费观看| 五月婷婷久久综合| 在线视频一区二区三| 国内精品久久久久影院色| 5月丁香婷婷综合| 成人免费av在线| 久久久99精品免费观看| 高清免费日韩| 亚洲人精品午夜| 天天综合色天天综合色hd| 日韩成人av影视| 欧美群妇大交群中文字幕| 国产suv精品一区二区6| 久久日韩精品一区二区五区| 高清视频一区二区三区| 亚洲欧美怡红院| 午夜精品一区二区在线观看的 | 中文字幕不卡每日更新1区2区| 日本不卡高清视频| 欧美精品乱码久久久久久 | 蜜桃视频在线观看一区| 欧美精品自拍偷拍| 不卡的电影网站| 中文字幕不卡在线| 日本在线一区| 美国毛片一区二区| 欧美电影精品一区二区| 国产精品久久久对白| 亚洲综合无码一区二区| 欧美天天综合网| av中文一区二区三区| 国产精品福利一区二区三区| 视频一区三区| 国内精品国产三级国产a久久| 精品国产制服丝袜高跟| 国内精品一区二区| 日韩精品高清不卡| 欧美一区二区久久久| 懂色中文一区二区三区在线视频| 亚洲黄色av一区| 欧美系列亚洲系列| 99久久99久久综合| 亚洲欧美激情小说另类| 日本伦理一区二区| 成人aa视频在线观看| 亚洲视频在线一区| 91高清在线观看| av一区二区三区| 亚洲精品乱码久久久久久日本蜜臀| 色美美综合视频| bt7086福利一区国产| 亚洲精品久久久久久国产精华液| 欧美性淫爽ww久久久久无| 99久久精品久久久久久清纯| 伊人性伊人情综合网| 欧美日韩国产精品自在自线| a级国产乱理论片在线观看99| 亚洲成人高清在线| 日韩午夜电影av| 欧美久久在线| 国产乱子轮精品视频| 中文字幕一区二区三区不卡| 色久综合一二码| 91九色蝌蚪成人| 日韩激情在线观看| 久久婷婷一区二区三区| 亚洲国产日韩综合一区| 粉嫩欧美一区二区三区高清影视| 亚洲视频一二三| 欧美美女一区二区| 九九九九九九精品| 国产一区二区影院| 亚洲视频在线观看三级| 欧美日韩国产一级| 九色视频成人porny| 精东粉嫩av免费一区二区三区| 国产精品免费视频网站| 欧美性生交片4| 国产一区二区在线网站| 国内精品伊人久久久久av一坑| 一区精品在线播放| 91精品国产一区二区三区蜜臀| 久久久精品动漫| 国产精品69久久久久水密桃| 亚洲精品视频在线观看免费| 日韩一区二区麻豆国产| 日韩中文不卡| 91猫先生在线| 久久精品国产99国产精品|