亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > CMS > PhpCMS > 正文

php數組被濫用于緩存的問題——以phpcms v9的pc標簽緩存為例

2024-09-10 07:15:41
字體:
來源:轉載
供稿:網友

php數組的方便性,很容易令人過度使用,其中一種過度使用的場合,就是做緩存時不區分場合濫用數組,導致性能不高,主要是集中在對CPU性能的高占用消耗上[1],以下以phpcms v9舉例說明.

phpcms v9中,作為模塊設計的pc標簽[2]其實是不錯的,易于讓人理解而且功能強大,但偏偏在關乎效率的緩存上似乎沒有意識到一個問題,絕大部分的開發者使用pc標簽的緩存參數,其實質是希望將該pc標簽包圍的模塊進行緩存,故而從緩存實現來講,作為一個視圖層而言,應該緩存最終渲染的html才對;但phpcms卻只是緩存了數據數組,每次讀取緩存并還原為數組后,仍然要進行渲染運算,這樣的結果,導致了pc標簽的緩存效率,其實沒有設計者想象的那么高.

比如如下pc標簽:

  1. {pc:content action=”position” posid=”1″ thumb=”1″ order=”listorder DESC” num=”5″ cache=”500″} 
  2. <div class=”content” id=”main-slide”> 
  3. <div class=”changeDiv”> 
  4. {loop $data $r
  5. <a href=”{$r['url']}” title=”{str_cut($r['title'],30)}”><img src=”{thumb($r['thumb'],310,260)}” alt=”{$r['title']}” width=”310″ height=”260″ /></a> 
  6. {/loop} 
  7. </div> 
  8. </div> 
  9. {/pc} 

其本意應該是為了緩存該pc標簽包圍的焦點圖片模塊,但是生成的最終代碼發現,緩存的是中間從數據庫讀取出來的數組,仍需要每次渲染:

  1. <?php if(defined(‘IN_ADMIN’) && !defined(‘HTML’)) {echo “<div class=/”admin_piao/” pc_action=/”content/” data=/”op=content&tag_md5=2e957216affd4b95207c8d8eabcfb7b8&action=position&posid=1&thumb=1&order=listorder+DESC&num=5&cache=500&htmlblockcache=1/”><a href=/”javascript:void(0)/” class=/”admin_piao_edit/”>編輯</a>”;}$tag_cache_name = md5(implode(‘&’,array(‘posid’=>’1′,’thumb’=>’1′,’order’=>’listorder DESC’,'htmlblockcache’=>’1′,)).’2e957216affd4b95207c8d8eabcfb7b8′);if(!$data = tpl_cache($tag_cache_name,500)){$content_tag = pc_base::load_app_class(“content_tag”, “content”);if (method_exists($content_tag, ‘position’)) {$data = $content_tag->position(array(‘posid’=>’1′,’thumb’=>’1′,’order’=>’listorder DESC’,'htmlblockcache’=>’1′,’limit’=>’5′,));}if(!emptyempty($data)){setcache($tag_cache_name$data, ‘tpl_data’);}}?> 
  2. <div class=”content” id=”main-slide”> 
  3. <div class=”changeDiv”> 
  4. <?php $n=1;if(is_array($data)) foreach($data AS $r) { ?> 
  5. <a href=”<?php echo $r['url'];?>” title=”<?php echo str_cut($r['title'],30);?>”><img src=”<?php echo thumb($r['thumb'],310,260);?>” alt=”<?php echo $r['title'];?>” width=”310″ height=”260″ /></a> 
  6. <?php $n++;}unset($n); ?> //Vevb.com 
  7. </div> 
  8. </div> 
  9. <?php if(defined(‘IN_ADMIN’) && !defined(‘HTML’)) {echo ‘</div>’;}?> 

解決這種效率問題,最直接的方法是增加參數,允許改為存儲整塊最終渲染的HTML模塊,為此,改造了phpcms,允許增加一個htmlblockcache=”1″參數,前提是cache參數必須大于0,以解決此問題:

  1. {pc:content action=”position” posid=”1″ thumb=”1″ order=”listorder DESC” num=”5″ cache=”500″ htmlblockcache=”1″} 
  2. {/pc} 

受條件所限,ab測試只能在本機實驗。測試環境為:Win 2003 + IIS 6 + php 5.2,沒有安裝任何opcode緩存擴展。測試方法是:后臺更新(刪除)所有緩存后,在瀏覽器刷新首頁一次,以便重新生成所需緩存;首次兩輪-n 10 -c 10預熱,接著兩輪-n 600 -c 15正式測試,取第二次作對比。

測試結果發現,改造后的響應速度有提高不小,但是由于更新緩存時需要進行ob緩沖,其響應會偶爾偏高.

改造前(沒有htmlblockcache)的首頁測試結果:

  1. Document Path: /phpcmsv9/index.php 
  2. Document Length: 41900 bytes 
  3.  
  4. Concurrency Level: 15 
  5. Time taken for tests: 33.891 seconds 
  6. Complete requests: 600 
  7. Failed requests: 0 
  8. Write errors: 0 
  9. Total transferred: 25286400 bytes 
  10. HTML transferred: 25140000 bytes 
  11. Requests per second: 17.70 [#/sec] (mean) 
  12. Time per request: 847.266 [ms] (mean) 
  13. Time per request: 56.484 [ms] (mean, across all concurrent requests) 
  14. Transfer rate: 728.63 [Kbytes/sec] received 
  15.  
  16. Connection Times (ms) 
  17. min mean[+/-sd] median max 
  18. Connect: 0 0 1.9 0 16 
  19. Processing: 156 843 361.4 906 1875 
  20. Waiting: 141 839 360.8 906 1875 
  21. Total: 156 843 361.5 906 1875 
  22.  
  23. Percentage of the requests served within a certain time (ms) 
  24. 50% 906 
  25. 66% 1031 
  26. 75% 1109 
  27. 80% 1156 
  28. 90% 1281 
  29. 95% 1344 
  30. 98% 1453 
  31. 99% 1516 
  32. 100% 1875 (longest request) 
  33.  
  34. 改造后(有htmlblockcache)的首頁測試結果: 
  35.  
  36. Document Path: /phpcmsv9/index.php 
  37. Document Length: 41328 bytes 
  38.  
  39. Concurrency Level: 15 
  40. Time taken for tests: 23.156 seconds 
  41. Complete requests: 600 
  42. Failed requests: 0 
  43. Write errors: 0 
  44. Total transferred: 24943200 bytes 
  45. HTML transferred: 24796800 bytes 
  46. Requests per second: 25.91 [#/sec] (mean) 
  47. Time per request: 578.906 [ms] (mean) 
  48. Time per request: 38.594 [ms] (mean, across all concurrent requests) 
  49. Transfer rate: 1051.92 [Kbytes/sec] received 
  50.  
  51. Connection Times (ms) 
  52. min mean[+/-sd] median max 
  53. Connect: 0 1 5.9 0 109 
  54. Processing: 94 570 177.5 547 2297 
  55. Waiting: 94 563 177.7 547 2297 
  56. Total: 94 571 177.3 547 2297 
  57.  
  58. Percentage of the requests served within a certain time (ms) 
  59. 50% 547 
  60. 66% 594 
  61. 75% 625 
  62. 80% 641 
  63. 90% 703 
  64. 95% 813 
  65. 98% 1016 
  66. 99% 1266 
  67. 100% 2297 (longest request) 

而實際服務器也支持這種測試結果——由于響應速度的提高,phpcgi的線程數也少了,CPU占用的疊加程度有所減少,負荷有所減輕.

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲乱码一区av黑人高潮| 91免费的视频在线播放| 日韩在线视频播放| 成人性生交大片免费观看嘿嘿视频| 国产91精品高潮白浆喷水| 另类色图亚洲色图| 久久精品国产久精国产一老狼| 欧美高清性猛交| 国产成人精品国内自产拍免费看| 日韩中文字幕av| 欧美性猛交xxxx富婆弯腰| 97国产成人精品视频| 欧美激情区在线播放| 91久久久久久| 国产精品久久久久久久久久| 91精品国产91久久久久久| 久久99久久99精品中文字幕| 国产精品久久久久久一区二区| 亚洲人成网站在线播| 国产精品黄色影片导航在线观看| 一区二区三区四区在线观看视频| 亚洲欧洲日本专区| 亚洲国产精久久久久久| 欧美成人免费视频| 精品久久久久久久久中文字幕| 国产午夜精品视频| 91日韩在线视频| 精品人伦一区二区三区蜜桃免费| 国产精品视频免费观看www| 国内偷自视频区视频综合| 国产欧美va欧美va香蕉在| 久久精品中文字幕一区| 国产视频精品va久久久久久| 精品视频久久久久久久| 国产精品久久久久久久天堂| 久久亚洲精品成人| 欧美电影免费观看网站| 日韩精品福利在线| 高清日韩电视剧大全免费播放在线观看| 欧美黑人巨大xxx极品| 亚洲第一区第二区| 亚洲欧美日韩国产成人| 97视频在线播放| 欧美电影《睫毛膏》| 亚洲跨种族黑人xxx| 日韩一区二区三区国产| 欧美国产日韩一区| 91a在线视频| 成人午夜高潮视频| 欧美猛交ⅹxxx乱大交视频| 国产精品人成电影| 久久国产精品久久久| 在线看片第一页欧美| 国产亚洲精品va在线观看| 国产一区二区三区中文| 亚洲日本欧美中文幕| 亚洲欧美国产一区二区三区| 亚洲va电影大全| 中文字幕日韩欧美精品在线观看| 国产精品黄页免费高清在线观看| 97色在线观看| 日韩精品在线视频| 正在播放亚洲1区| 大胆人体色综合| 亚洲黄页视频免费观看| 国产99久久精品一区二区| 日本精品久久电影| 国产精品美女av| 成人欧美一区二区三区在线湿哒哒| 亚洲图片欧美午夜| 97视频人免费观看| 国产精品尤物福利片在线观看| 欧美中文在线观看国产| 国产999在线| 久久久久久久久久久av| 日韩欧美中文字幕在线观看| 精品国产乱码久久久久酒店| 亚洲国产精品成人av| 日韩久久午夜影院| 亚洲国产精品久久久久秋霞蜜臀| 久久久亚洲网站| 国内外成人免费激情在线视频网站| 久久久久久91香蕉国产| 久久精品国产精品亚洲| 久久99国产精品自在自在app| 成人免费福利视频| 免费97视频在线精品国自产拍| 欧美午夜女人视频在线| 亚洲国产精品va在看黑人| 日韩精品高清在线| 97欧美精品一区二区三区| 成人久久久久久| 欧美国产视频一区二区| 成人免费视频97| 亚洲欧洲第一视频| 久久久免费av| 国产亚洲精品久久久久久| 中文字幕自拍vr一区二区三区| yellow中文字幕久久| 欧美肥臀大乳一区二区免费视频| 色综合久综合久久综合久鬼88| 欧美专区第一页| 欧美精品做受xxx性少妇| 国产一区二区日韩| 亚洲色图17p| 午夜精品福利在线观看| 日韩成人av在线| 久久亚洲综合国产精品99麻豆精品福利| 欧美激情欧美激情| 欧美另类在线播放| 国产欧美日韩中文字幕在线| 国产精品一区av| 国产91色在线|免| 国产精品高潮粉嫩av| 日韩欧美第一页| 深夜福利国产精品| 亚洲在线免费看| 国产精品男人的天堂| 俺去亚洲欧洲欧美日韩| 日韩精品亚洲元码| 亚洲国产精品成人va在线观看| 久久久久久久久久久久av| 91po在线观看91精品国产性色| 91av在线免费观看| 亚洲美女在线观看| 一区二区三区高清国产| 国模极品一区二区三区| 九九九热精品免费视频观看网站| 国产有码在线一区二区视频| 国产成人免费av| 精品欧美aⅴ在线网站| 一区二区中文字幕| 国产精品99久久久久久久久| 一区二区三区亚洲| 日韩av在线免播放器| 欧美亚洲另类制服自拍| 欧美日韩一区二区三区在线免费观看| 国产97在线观看| 亚洲第一区第一页| 成人激情在线播放| 亚洲国产日韩一区| www.精品av.com| 不卡在线观看电视剧完整版| 亚洲精品一区二三区不卡| 亚洲精品视频免费在线观看| 欧美午夜性色大片在线观看| 久久精品国产2020观看福利| 亚洲影院色在线观看免费| 欧美视频在线观看 亚洲欧| 欧洲美女免费图片一区| 日韩欧美国产激情| 欧美日本啪啪无遮挡网站| 久久在线观看视频| 久久久最新网址| 91人成网站www| 日韩极品精品视频免费观看| 久久精品久久久久| 中文字幕精品一区久久久久| 亚洲成人激情在线| 欧美精品激情在线观看| 日韩亚洲综合在线| 亚洲精品电影网站| 欧美巨大黑人极品精男| 欧美成人中文字幕|