加入收藏 | 设为首页 | 会员中心 | 我要投稿 源码网 (https://www.900php.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

Memcache php提高mysql负载有效办法

发布时间:2022-02-10 00:45:44 所属栏目:PHP教程 来源:互联网
导读:在php mysql的web应用中我们经常会碰到上千万级的数据量,为了减轻服务器的负载我们经常会使用第三个工具来减压,下我们为你提供一款Memcache php提高mysql负载有效方法. Memcache的理由: 1.Web Server(Lighttpd、Nginx据说都比Apache效率高好多,大家可以试
  在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方法,代码如下:
 
  function fetch_array($query, $result_type = MYSQL_ASSOC) {
  return is_resource($query) ? mysql_fetch_array($query, $result_type) : $query[0];
  }
  
  function query_memcache($sql, $type = '') {
  global $mem,$memcachelife;
  
  $key = md5($sql);
  if(!($query = $mem->get($key))) {
  $query = $this->query($sql, $type);
  while($item = $this->fetch_array($query)) {
  $res[] = $item;
  }
  $query = $res;
  $mem->set($key, $query , 0, $memcachelife);
  }
  return $query;
  }
  
  function query($sql, $type = '') {
  global $debug, $discuz_starttime, $sqldebug, $sqlspenttimes;
  
  $func = $type == 'UNBUFFERED' && @function_exists('mysql_unbuffered_query') ?
  'mysql_unbuffered_query' : 'mysql_query';
  if(!($query = $func($sql, $this->link)) && $type != 'SILENT') {
  $this->halt('MySQL Query Error', $sql);
  }
  
  if(substr($sql, 0, 6) == 'SELECT') {
  echo '<font color="red">Cache SQL</font>:<font color="green">'.$sql.'</font><br /><br />';
  } else {
  echo '<font color="red">Flash SQL</font>:<font color="green">'.$sql.'</font><br /><br />';
  }
  //开源代码Cuoxin.com
  $this->querynum++;
  return $query;
  }
  4.将需要使用Memcache缓存的SQL查询的代码由 $db->query( 修改为 $db->query_memcache( 注意并将 while($post = $db->fetch_array($query)) { 修改为 foreach($query as $post) {
 
  没有while的$db->fetch_array可以不用修改.

(编辑:源码网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读