在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 'Cache SQL:'.$sql.' } else { echo 'Flash SQL:'.$sql.' } $this->querynum ; return $query; } 4.将需要使用Memcache缓存的SQL查询的代码由 $db->query( 修改为
|