php文件緩存效率測試,php的緩存文件是什麼格式

本文目錄一覽:

在php中memcached和利用文件緩存哪個效率更好

看情況,如果不是很大就用memcahed 如果大了的話,就是文件緩存好些!

用php語言從服務器返回數據超過80k後速度就非常非常慢!測試後發現好像是輸出緩存問題,請問怎麼解決!

對於php的輸出,貌似apache採取的策略是小段輸出直接傳輸,大段輸出就切割成chunked分段。在chunked分段沒有傳輸完成之前,apache和php一直保持連接狀態。也就是說,如果php的輸出字符串比較小,那麼apache會把這些數據暫存,等到php執行完了之後再發給瀏覽器。而當php輸出大段字符的時候,apache就不會緩存輸出,直接把輸出丟給瀏覽器,而且在此過程中會暫時停止php的執行!

所以使用緩存是解決此類問題的根本辦法。ob_start()就是啟用php的緩衝區。php還可以通過安裝xcache等緩存模塊實現。apache中開啟gzip壓縮也可以。

php 中如何使用緩存,使用哪種緩存機制最好;

php的緩存三種.有文件緩存,數據庫緩存,memcache緩存;

memcache緩存要求對服務器支持,而且它的緩存是由期限的,一般是30天。這種緩存的效率是最高的。讀存取的速度最快。

數據庫緩存

文件緩存比較簡單。適用小的項目。和php新手

怎樣提高php運行效率

1、 如果能將類的方法定義成static,就盡量定義成static,它的速度會提升將近4倍。

2、$row[’id’] 的速度是$row[id]的7倍。

3、echo 比 print快,並且使用echo的多重參數(譯註:指用逗號而不是句點)代替字符串連接,比如echo$str1,$str2。

4、在執行for循環之前確定最大循環數,不要每循環一次都計算最大值,最好運用foreach代替。

5、註銷那些不用的變量尤其是大數組,以便釋放內存。

6、盡量避免使用__get,__set,__autoload。

7、require_once()代價昂貴。

8、include文件時盡量使用絕對路徑,因為它避免了PHP去include_path里查找文件的速度,解析操作系統路徑所需的時間會更少。

9、如果你想知道腳本開始執行(譯註:即服務器端收到客戶端請求)的時刻,使用$_SERVER[‘REQUEST_TIME’]要好於 time()。

10、函數代替正則表達式完成相同功能。

11、str_replace函數比preg_replace函數快,但strtr函數的效率是str_replace函數的四倍。

12、如果一個字符串替換函數,可接受數組或字符作為參數,並且參數長度不太長,那麼可以考慮額外寫一段替換代碼,使得每次傳遞參數是一個字符,而不是只寫一行代碼接受數組作為查詢和替換的參數。

13、使用選擇分支語句(譯註:即switch case)好於使用多個if,else if語句。

14、用@屏蔽錯誤消息的做法非常低效,極其低效。

15、打開apache的mod_deflate模塊,可以提高網頁的瀏覽速度。

16、數據庫連接當使用完畢時應關掉,不要用長連接。

17、錯誤消息代價昂貴。

18、在方法中遞增局部變量,速度是最快的。幾乎與在函數中調用局部變量的速度相當。

19、遞增一個全局變量要比遞增一個局部變量慢2倍。

20、遞增一個對象屬性(如:$this-prop++)要比遞增一個局部變量慢3倍。

21、遞增一個未預定義的局部變量要比遞增一個預定義的局部變量慢9至10倍。

22、僅定義一個局部變量而沒在函數中調用它,同樣會減慢速度(其程度相當於遞增一個局部變量)。PHP大概會檢查看是否存在全局變量。

23、方法調用看來與類中定義的方法的數量無關,因為我(在測試方法之前和之後都)添加了10個方法,但性能上沒有變化。

24、派生類中的方法運行起來要快於在基類中定義的同樣的方法。

25、調用帶有一個參數的空函數,其花費的時間相當於執行7至8次的局部變量遞增操作。類似的方法調用所花費的時間接近於15次的局部變量遞增操作。

26、Apache解析一個PHP腳本的時間要比解析一個靜態HTML頁面慢2至10倍。盡量多用靜態HTML頁面,少用腳本。

27、除非腳本可以緩存,否則每次調用時都會重新編譯一次。引入一套PHP緩存機制通常可以提升25%至100%的性能,以免除編譯開銷。

28、盡量做緩存,可使用memcached。memcached是一款高性能的內存對象緩存系統,可用來加速動態Web應用程序,減輕數據庫負載。對運算碼 (OP code)的緩存很有用,使得腳本不必為每個請求做重新編譯。

29、當操作字符串並需要檢驗其長度是否滿足某種要求時,你想當然地會使用strlen()函數。此函數執行起來相當快,因為它不做任何計算,只返回在zval 結構(C的內置數據結構,用於存儲PHP變量)中存儲的已知字符串長度。但是,由於strlen()是函數,多多少少會有些慢,因為函數調用會經過諸多步驟,如字母小寫化(譯註:指函數名小寫化,PHP不區分函數名大小寫)、哈希查找,會跟隨被調用的函數一起執行。在某些情況下,你可以使用isset() 技巧加速執行你的代碼。

(舉例如下)

if (strlen($foo) 5) { echo “Foo is too short”$$ }

(與下面的技巧做比較)

if (!isset($foo{5})) { echo “Foo is too short”$$ }

調用isset()恰巧比strlen()快,因為與後者不同的是,isset()作為一種語言結構,意味着它的執行不需要函數查找和字母小寫化。也就是說,實際上在檢驗字符串長度的頂層代碼中你沒有花太多開銷。

34、當執行變量$i的遞增或遞減時,$i++會比++$i慢一些。這種差異是PHP特有的,並不適用於其他語言,所以請不要修改你的C或 Java代碼並指望它們能立即變快,沒用的。++$i更快是因為它只需要3條指令(opcodes),$i++則需要4條指令。後置遞增實際上會產生一個臨時變量,這個臨時變量隨後被遞增。而前置遞增直接在原值上遞增。這是最優化處理的一種,正如Zend的PHP優化器所作的那樣。牢記這個優化處理不失為一個好主意,因為並不是所有的指令優化器都會做同樣的優化處理,並且存在大量沒有裝配指令優化器的互聯網服務提供商(ISPs)和服務器。

35、並不是事必面向對象(OOP),面向對象往往開銷很大,每個方法和對象調用都會消耗很多內存。

36、並非要用類實現所有的數據結構,數組也很有用。

37、不要把方法細分得過多,仔細想想你真正打算重用的是哪些代碼?

38、當你需要時,你總能把代碼分解成方法。

39、盡量採用大量的PHP內置函數。

40、如果在代碼中存在大量耗時的函數,你可以考慮用C擴展的方式實現它們。

41、評估檢驗(profile)你的代碼。檢驗器會告訴你,代碼的哪些部分消耗了多少時間。Xdebug調試器包含了檢驗程序,評估檢驗總體上可以顯示出代碼的瓶頸。

42、mod_zip可作為Apache模塊,用來即時壓縮你的數據,並可讓數據傳輸量降低80%。

43、在可以用file_get_contents替代file、fopen、feof、fgets等系列方法的情況下,盡量用 file_get_contents,因為他的效率高得多!但是要注意file_get_contents在打開一個URL文件時候的PHP版本問題;

44、盡量的少進行文件操作,雖然PHP的文件操作效率也不低的;

45、優化Select SQL語句,在可能的情況下盡量少的進行Insert、Update操作;

46、儘可能的使用PHP內部函數(但是我卻為了找個PHP裡面不存在的函數,浪費了本可以寫出一個自定義函數的時間,經驗問題啊!);

47、循環內部不要聲明變量,尤其是大變量:對象(這好像不只是PHP裡面要注意的問題吧?);

48、多維數組盡量不要循環嵌套賦值;

49、在可以用PHP內部字符串操作函數的情況下,不要用正則表達式;

50、foreach效率更高,盡量用foreach代替while和for循環;

51、用單引號替代雙引號引用字符串;

52、“用i+=1代替i=i+1。符合c/c++的習慣,效率還高”;

53、對global變量,應該用完就unset()掉。

請幫助解釋一下PHP的緩存問題

PHP緩存技術 WEB程序獲取信息的方式主要是查詢數據庫,當數據庫不是很大的情況下不會有太大的問題.然而,隨着網站的發展,數據庫呈幾何級數的方式增長的時候,就會出現瓶頸.於是PHP緩存技術誕生了.PHP緩存技術工作時,當程序查詢數據的時候,會把相應的結果序列化後保存到文件中,以後同樣的查詢語句就可以不用直接查詢數據庫,而是從緩存文件中獲得。這一改進使得程序運行速度得以太幅度提升.

目前應用PHP緩存技術比較流行的方法主要是Adodb+Smarty這樣的黃金搭檔.

PHP緩存技術工作原理:

首先看看adodb提供的數據緩存功能:

1?php

2include(‘adodb.inc.php’); # load code common to ADOdb

3$ADODB_CACHE_DIR = ‘/usr/ADODB_cache’;

4$conn = ADONewConnection(‘mysql’); # create a connection

5$conn-PConnect(‘ ‘,’userid’,”,’agora’);# connect to MySQL, agora db

6$sql = ‘select CustomerName, CustomerID from customers’;

7$rs = $conn-CacheExecute(15,$sql);

8? 如上,每次查詢數據的時候,會把相應的結果序列化後保存到文件中,以後同樣的查詢語句就可以不用直接查詢數據庫,而是從緩存文件中獲得。

再來看看Smarty提供的頁面緩存功能:

1?php

2require(‘Smarty.class.php’);

3$smarty = new Smarty;

4$smarty-caching = true;

5if(!$smarty-is_cached(‘index.tpl’)) {

6 // No cache available, do variable assignments here.

7 $contents = get_database_contents();

8 $smarty-assign($contents);

9}

10$smarty-display(‘index.tpl’);

11?

12

如上,每次訪問頁面的時候,都會先檢測相應的緩存是否存在,如果不存在,就連接數據庫,得到數據,完成模板變量的賦值,顯示頁面,同時生成緩存文件,這樣下次訪問的時候緩存文件就發揮作用了,而不會再執行if塊的數據查詢語句了。當然,在實際使用中會有很多東西要考慮,比如,有效期的設置,緩存組的設置等等,具體可以查看Smarty手冊中有關緩存(caching)的相關章節。

以上兩個PHP流行組件緩存方式的側重點是不同的,對於Adodb的緩存而言,它緩存的是數據,對於Smarty的緩存而言,它緩存的是頁面。其他提供緩存功能的組件還有很多(如:PEAR::Cache_Lite等等),實際編程中使用哪個方案要具體情況具體分析,也可能會綜合使用。

使用這些組件內置的緩存方案有一個很明顯的好處是它們的實現對客戶端而言都很透明。只要進行必要的設置(如:緩存時間,緩存目錄等等)就可以了,而不用過多考慮實現緩存的細節問題,系統會根據設置自動管理緩存。但是其缺點也同樣明顯,因為每次請求仍然要用PHP解析一遍,效率和純靜態相比還是大打折扣,在大的PV面前還是不能滿足要求,在這種情況下,僅僅做動態緩存就不夠了,必須實現靜態緩存。

PHP,一門最近幾年興起的web設計腳本語言,由於它的強大和可伸縮性,近幾年來得到長足的發展,php相比傳統的asp網站,在速度上有絕對的優勢,想mssql轉6萬條數據php如需要40秒,asp不下2分鐘.但是,由於網站的數據越來越多,我們渴求能更快速的調用數據,不必要每次都從數據庫掉,我們可以從其他的地方,比方一個文件,或者某個內存地址,這就是php的緩存技術,也就是Cache技術.

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/248990.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-12 13:31
下一篇 2024-12-12 13:31

相關推薦

發表回復

登錄後才能評論