好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

Memcache php提高mysql负载有效方法 - php高级应用

Memcache php提高mysql负载有效方法

在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 />' ;  }  //开源代码phpfensi.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可以不用修改.

查看更多关于Memcache php提高mysql负载有效方法 - php高级应用的详细内容...

  阅读:40次