国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > PHP > 正文

Memcache php提高mysql負載有效方法

2024-05-04 21:48:11
字體:
來源:轉載
供稿:網友

在php mysql的web應用中我們經常會碰到上千萬級的數據量,為了減輕服務器的負載我們經常會使用第三個工具來減壓,下我們為你提供一款Memcache php提高mysql負載有效方法.

Memcache的理由:

1.Web Server(Lighttpd、Nginx據說都比Apache效率高好多,大家可以試用下)對CPU要求高,對內存要求低,而Memcached Server是對CPU要求低,對內存要求高,所以可以搭配使用,在對前端的Web Server上安裝Memcached Server是可行的。

2.金錢金錢金錢,最少的付出,獲得最大的收益。

3.簡單簡單簡單,對于一個架構合理的系統來說,添加Memcache的支持可能只是一個批量處理文件的過程.

Discuz!使用Memcache

1.在config.inc.php中增加如下代碼:

$memcachehost = '127.0.0.1';
$memcacheport = 11211;
$memcachelife = 60;

2.在include/common.inc.php中

$mem = new Memcache;

$mem->connect($memcachehost, $memcacheport);

3.修改include/db_mysql.class.php中的fetch_array、query這兩個方法,并添加query_mysql方法,代碼如下:

  1. function fetch_array($query$result_type = MYSQL_ASSOC) { 
  2. return is_resource($query) ? mysql_fetch_array($query$result_type) : $query[0]; 
  3.  
  4. function query_memcache($sql$type = '') { 
  5. global $mem,$memcachelife
  6.  
  7. $key = md5($sql); 
  8. if(!($query = $mem->get($key))) { 
  9. $query = $this->query($sql$type); 
  10. while($item = $this->fetch_array($query)) { 
  11. $res[] = $item
  12. $query = $res
  13. $mem->set($key$query , 0, $memcachelife); 
  14. return $query
  15.  
  16. function query($sql$type = '') { 
  17. global $debug$discuz_starttime$sqldebug$sqlspenttimes
  18.  
  19. $func = $type == 'UNBUFFERED' && @function_exists('mysql_unbuffered_query') ? 
  20. 'mysql_unbuffered_query' : 'mysql_query'
  21. if(!($query = $func($sql$this->link)) && $type != 'SILENT') { 
  22. $this->halt('MySQL Query Error'$sql); 
  23.  
  24. if(substr($sql, 0, 6) == 'SELECT') { 
  25. echo '<font color="red">Cache SQL</font>:<font color="green">'.$sql.'</font><br /><br />'
  26. else { 
  27. echo '<font color="red">Flash SQL</font>:<font color="green">'.$sql.'</font><br /><br />'
  28. //開源代碼Vevb.com 
  29. $this->querynum++; 
  30. return $query

4.將需要使用Memcache緩存的SQL查詢的代碼由 $db->query( 修改為 $db->query_memcache( 注意并將 while($post = $db->fetch_array($query)) { 修改為 foreach($query as $post) { 

沒有while的$db->fetch_array可以不用修改.

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 隆子县| 玛曲县| 嵩明县| 清徐县| 珲春市| 正镶白旗| 贵德县| 桃园市| 新源县| 仁怀市| 吉木萨尔县| 江门市| 简阳市| 雷山县| 绥滨县| 察隅县| 荣成市| 尖扎县| 合肥市| 保山市| 三河市| 乐安县| 湄潭县| 会理县| 北票市| 秀山| 周至县| 茌平县| 上杭县| 开鲁县| 四川省| 莲花县| 车致| 武功县| 牙克石市| 翁牛特旗| 当阳市| 奉新县| 新乡市| 石台县| 长兴县|