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高级应用的详细内容...
声明:本文来自网络,不代表【好得很程序员自学网】立场,转载请注明出处:http://www.haodehen.cn/did30073