您的位置:首页 > 数据库 > Memcache

使用Memcache在PHP中调试方法的介绍及应用

2016-01-04 12:47 891 查看
使用Memcache在PHP中调试方法的介绍及应用

如果我们在网络开发中,特别是大访问量的web项目开发中,为了提高响应速度,减少数据查询运算,那么我们都会选用memcahce。首先我们必须要安装,接下来如何使用memcache,在这里介绍下在linux下安装和windows下安装如下及配置:

一、 linux下的Memcache安装:

1.下载memcache的linux版本,注意 memcached 用 libevent 来作事件驱动,所以要先安装有 libevent。

2. 安装 pecl::memcache。

用 pecl 命令行工具安装:

pecl install memcache

或直接从源码安装:

phpize

./configure

make

make install

二、Windows下的Memcache安装:

1. 下载memcache的windows稳定版,解压放某个盘下面,比如在c:\memcached

2. 在终端(也即cmd命令界面)下输入 ‘c:\memcached\memcached.exe -d install’ 安装

3. 再输入: ‘c:\memcached\memcached.exe -d start’ 启动。NOTE: 以后memcached将作为windows的一个服务每次开机时自动启动。这样服务器端已经安装完毕了。

4.下载http://pecl4win.php.net/ext.php/php_memcache.dll,请自己查找对应的php版本的文件

5. 在C:\winnt\php.ini 加入一行 ‘extension=php_memcache.dll’

6.重新启动Apache,然后查看一下phpinfo,如果有memcache,那么就说明安装成功!

三、memcached的基本设置:

-p 监听的端口

-l 连接的IP地址, 默认是本机

-d start 启动memcached服务

-d restart 重起memcached服务

-d stop|shutdown 关闭正在运行的memcached服务

-d install 安装memcached服务

-d uninstall 卸载memcached服务

-u 以的身份运行 (仅在以root运行的时候有效)

-m 最大内存使用,单位MB。默认64MB

-M 内存耗尽时返回错误,而不是删除项

-c 最大同时连接数,默认是1024

-f 块大小增长因子,默认是1.25-n 最小分配空间,key+value+flags默认是48

-h 显示帮助

四、php.ini中的配置:

[Memcache]

一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨大的hash表,它能够用来存储各种格式的数据,包括图像、视频、文件以及数据库检索的结果等。

是否在遇到错误时透明地向其他服务器进行故障转移。

memcache.allow_failover = On

接受和发送数据时最多尝试多少个服务器,只在打开memcache.allow_failover时有效。memcache.max_failover_attempts = 20

数据将按照此值设定的块大小进行转移。此值越小所需的额外网络传输越多。如果发现无法解释的速度降低,可以尝试将此值增加到32768。

memcache.chunk_size = 8192

连接到memcached服务器时使用的默认TCP端口。

memcache.default_port = 11211

控制将key映射到server的策略。默认值"standard"表示使用先前版本的老hash策略。

设为"consistent"可以允许在连接池中添加/删除服务器时不必重新计算key与server之间的映射关系。

memcache.hash_strategy = "standard";

控制将key映射到server的散列函数。默认值"crc32"使用CRC32算法,而"fnv"则表示使用FNV-1a算法。 FNV-1a比CRC32速度稍低,但是散列效果更好。

memcache.hash_function = "crc32"

memcache也可以作为session的存储模块,具体参看:memcache PHP 的 session.save_handler.

1. $memcache = new Memcache;

2. $memcache->connect('localhost', 11211) or die ("Could not connect");

3.

4. $version = $memcache->getVersion();

5. echo "Server's version: ".$version."<BR>\n";

6.

7. $tmp_object = new stdClass;

8. $tmp_object->str_attr = 'test';

9. $tmp_object->int_attr = 123;

10.

11. $memcache->set('key', $tmp_object, false, 10) or die ("Failed to save data at the server");

12. echo "Store data in the cache (data will expire in 10 seconds)<BR>\n";

13.

14. $get_result = $memcache->get('key');

15. echo "Data from the cache:<BR>\n";

16.

17. var_dump($get_result);

我们已经安装好了,也配置好了memcache,现在接下来如何调试memcache.

来做个测试。

  先搞个表:

create table t(id char(36) not null primary key, username varchar(20) not null);

  插点数据:

insert into t values (uuid(),'Livia'),(uuid(),'Lucy'),(uuid(),'Sivia'),(uuid(),'david');

  写个简单脚本测试一下。

<?php

$host = '192.168.1.21:3306';

$user = 'webuser';

$passwd = '123456';

$db = 'test';

$conn = mysql_connect($host,$user,$passwd);

mysql_select_db($db,$conn);

$sql = 'select * from t order by id desc';

$result = mysql_query($sql,$conn);

while ($row = mysql_fetch_array($result,MYSQL_ASSOC)){

$test_key[] = $row;

}

$sql = md5($sql);

$mem = new Memcache;

$mem->connect("192.168.1.21", 11211);

$mem->set($sql,$test_key, MEMCACHE_COMPRESSED, 600);

print_r($mem->get($sql));

?>

  看看结果出来了。

C:\>php -f "d:/lamp/web2/phpinfo.php"

Array

(

[0] => Array

(

[id] => d8f1ec2a-c033-11dd-bd1a-002215c94322

[username] => david

)

[1] => Array

(

[id] => d8f1eb9e-c033-11dd-bd1a-002215c94322

[username] => Sivia

)

[2] => Array

(

[id] => d8f1ea9a-c033-11dd-bd1a-002215c94322

[username] => Lucy

)

[3] => Array

(

[id] => d8f1e658-c033-11dd-bd1a-002215c94322

[username] => Livia

)

)

现在我们已经介绍Memcache安装,不再赘述。再次着重介绍memcache的一些常用方法。

Memcache::add // 添加一个值,如果已经存在,则返回false

Memcache::addServer // 添加Memcache地址

Memcache::close // 关闭一个Memcache的连接

Memcache::connect // 打开一个到Memcache的连接

Memcache::decrement // 对保存的某个key中的值进行减法操作

Memcache::delete // 删除一个Memcache上的key值

Memcache::flush // 刷新所有Memcache上保存的项目(类似于删除所有的保存的项目)

Memcache::get // 从Memcache上获取一个key值

Memcache::getExtendedStats // 获取进程池中所有进程的运行系统统计

Memcache::getServerStatus // 获取运行服务器的参数

Memcache::getStats //获取当前Memcache服务器运行的状态

Memcache::getVersion // 返回运行的Memcache的版本信息

Memcache::increment // 对保存的某个key中的值进行加法操作

Memcache::pconnect // 打开一个到Memcache的长连接

Memcache::replace // 替换一个已经存在Memcache服务器上的项目(功能类似Memcache::set)

Memcache::set // 向Memcache添加一个值,如果已经存在,则覆写

Memcache::setCompressThreshold // 对大于某一大小的数据进行压缩

Memcache::setServerParams // 在运行时修改服务器的参数

下面是一些简单的用法实例,仅供参考:

<?php

$mem = new Memcache;

$mem->connect("127.0.0.1", 12000);

//Memcache::set方法有四个参数,第一个参数是key,第二个参数是value,第三个参数可选,表示是否压缩保存,第四个参数可选,用来设置一个过期自动销毁的时间。

$mem->set('test','123',0,60);

//Memcache::add方法的作用和Memcache::set方法类似,区别是如果 Memcache::add方法的返回值为false,表示这个key已经存在,而Memcache::set方法则会直接覆写。

$mem->add('test','123',0,60);

//Memcache::get方法的作用是获取一个key值,Memcache::get方法有一个参数,表示key。

$mem->get('test');//输出为'123'

//Memcache::replace 方法的作用是对一个已有的key进行覆写操作,Memcache::replace方法有四个参数,作用和Memcache::set方法的相同。

$mem->replace('test','456',0,60);

//Memcache::delete方法的作用是删除一个key值,Memcache::delete方法有两个参数,第一个参数表示key,第二个参数可选,表示删除延迟的时间。

$mem->delete('test',60);

?>

肖承湖

PHP缓存应用:PHP MEMCACHE 详解

2010-01-28 09:38:44 来源:中国站长站综合 【 评论:0 条 我要投稿 收藏本文 分享至微博

站长交易(http://jy.chinaz.com)帮站长赚钱 虚拟主机评测+IDC导航=IDC123.COM

Memcache函数库是在PECL(PHP Extension Community Library)中,主要作用是搭建大容量的内存数据的临时存放区域,在分布式的时候作用体现的非常明显,否则不建议使用。在ubuntu上安装完运行的时候报错:

/usr/local/memcached/bin/memcached: error while loading shared libraries: libevent-1.4.so.2:

cannot open shared object file: No such file or directory

按照:《libeven、memcached、libmemcache安装》中的方法,使用:

sudo ln -s /usr/local/lib/libevent-1.4.so.2 /usr/lib/libevent-1.4.so.2

可以修正这个BUG

通过新得立安装php的memcached模块,注销/etc/php5/conf.d/memcached.ini里面的“;”,重启apache,调用phpinfo()出现memcached的信息。

<?php

$memcache = new Memcache;

$memcache->connect('localhost', 11211) or die ("Could not connect");

$version = $memcache->getVersion();

echo "Server's version: ".$version."\n";

?>

1. <?php

2. $memcache = new Memcache;

3. $memcache->connect('localhost', 11211) or die ("Could not connect");

4. print_r($memcache->getStats());

5. /**

6. * Array

7. * (

8. * [pid] => 8052

9. * [uptime] => 9205

10. * [time] => 1205898428

11. * [version] => 1.2.5

12. * [pointer_size] => 32

13. * [rusage_user] => 0.008000

14. * [rusage_system] => 0.000000

15. * [curr_items] => 1

16. * [total_items] => 17

17. * [bytes] => 57

18. * [curr_connections] => 2

19. * [total_connections] => 15

20. * [connection_structures] => 3

21. * [cmd_get] => 9

22. * [cmd_set] => 23

23. * [get_hits] => 5

24. * [get_misses] => 4

25. * [evictions] => 0

26. * [bytes_read] => 671

27. * [bytes_written] => 850

28. * [limit_maxbytes] => 10485760

29. * [threads] => 1

30. * )

31. */

32. ?>

01.<?php

02.$memcache = new Memcache;

03.$memcache->connect('localhost', 11211) or die ("Could not connect");

04.$memcache->set( 'name', 'leo', 0, 30);

05.if(!$memcache->add( 'name', 'susan', 0, 30))

06.{

07. echo 'susan is exist';

08.};

09.$memcache->replace( 'name', 'lion', 0, 300);

10.echo $memcache->get( 'name');

11.$memcache->delete( 'name', 5);

12.?>

01.<?php

02.function _callback_memcache_failure($host, $port) {

03. print "memcache '$host:$port' failed";

04.}

05.$memcache = new Memcache;

06.$memcache->addServer('192.168.1.116', 11211);

07.$memcache->setServerParams('192.168.1.116', 11211, 1, 15, true,

08.

09.'_callback_memcache_failure');

10.echo $memcache->getServerStatus('192.168.1.116', 11211);

11.?>

PHP缓存应用:PHP MEMCACHE 详解(2)

2010-01-28 09:38:44 来源:中国站长站综合 【 评论:0 条 我要投稿 收藏本文 分享至微博

站长交易(http://jy.chinaz.com)帮站长赚钱 虚拟主机评测+IDC导航=IDC123.COM

memcached的服务正式启动

建议用面向对象的方式来测试这个库:

Memcache::getVersion方法的作用是返回运行的Memcache的版本信息。

Memcache::getStats 方法的作用是返回服务器的一些运行统计信息。Memcache::getStats方法有三个参数,第一个
参数表示要求返回的类型:reset, malloc, maps, cachedump, slabs, items, sizes;第二个参数和第三
个参数是在第一个参数设置“cachedump”时使用的。Memcache::getExtendedStats方法的作 用是获取进程池中所有进程的
运行系统统计。

memcache_debug()函数的作用是控制调试功能,前提是php在编译的时候使用了–enable-debug选项,否则这个函数不会有作用。

Memcache::addServer 方法的作用是添加一个可供使用的服务器地址,Memcache::addServer方法有8个参数,除
了第一个参数意外,其他都是可选的,第一个参数表 示服务器的地址,第二个参数表示端口,第三个参数表示是否是一个持久连接,第四个参数表示这台服务器在
所有服务器中所占的权重,第五个参数表示连接的持续 时间,第六个参数表示连接重试的间隔时间,默认为15,设置为-1表示不进行重试,第七个参数用来控
制服务器的在线状态,第8个参数允许设置一个回掉函数 来处理错误信息。

Memcache::setServerParams方法的作用是在运行时修改服务器的参
数,Memcache::setServerParams 方法有六个参数,Memcache::addServer方法少了第三和第四个参
数。 Memcache::getServerStatus方法的作用是获取运行服务器的参数,两个参数分别表示的地址和端口。

Memcache::flush方法的作用是清除所有缓存的数据,但是不会削去使用的内存空间。

Memcache::increment方法的作用是对保存的某个key中的值进行加法操作,Memcache::decremen方法的作用是对保存的某个key中的值进行减法操作。

PHP MEMCACHE高级缓存应用详解 文章录入:7747.Net 责任编辑:7747.Net 269

【字体:

01.<?php

02.$memcache = new Memcache;

03.$memcache->connect('localhost', 11211);

04.$memcache->set('test_item', 8);

05.$memcache->increment('test_item', 4);

06.echo $memcache->decrement('test_item', 7);

07.// 显示 5

08.?>

Memcache函数库是在 PECL(PHP Extension Community Library)中,主要作用是搭建大容量的内存数据的

临时存放区域,在分布式的时候作用体现的非常明显,否则不建议使用。 本人在ubuntu上安装

完运行的时候报错:

/usr/local/memcached/bin/memcached: error while loading shared libraries: libevent-1.4.so.2:

cannot open shared object file: No such file or directory

按照:《libeven、memcached、libmemcache安装》中的方法,使用:

sudo ln -s /usr/local/lib/libevent-1.4.so.2 /usr/lib/libevent-1.4.so.2

可以修正这个BUG

通过新得立安装php的memcached模块,注销/etc/php5/conf.d/memcached.ini里面的“;”,重启apache

,调用phpinfo()出现memcached的信息

执行:

<?php

$memcache = new Memcache;

$memcache->connect('localhost', 11211) or die ("Could not connect");

$version = $memcache->getVersion();

echo "Server's version: ".$version."

\n";

?>

<?php

$memcache = new Memcache;

$memcache->connect('localhost', 11211) or die ("Could not connect");

print_r($memcache->getStats());

/**

* Array

* (

* [pid] => 8052

* [uptime] => 9205

* [time] => 1205898428

* [version] => 1.2.5

* [pointer_size] => 32

* [rusage_user] => 0.008000

* [rusage_system] => 0.000000

* [curr_items] => 1

* [total_items] => 17

* [bytes] => 57

* [curr_connections] => 2

* [total_connections] => 15

* [connection_structures] => 3

* [cmd_get] => 9

* [cmd_set] => 23

* [get_hits] => 5

* [get_misses] => 4

* [evictions] => 0

* [bytes_read] => 671

* [bytes_written] => 850

* [limit_maxbytes] => 10485760

* [threads] => 1

* )

*/

?>

<?php

$memcache = new Memcache;

$memcache->connect('localhost', 11211) or die ("Could not connect");

$memcache->set( 'name', 'leo', 0, 30);

if(!$memcache->add( 'name', 'susan', 0, 30))

{

echo 'susan is exist';

};

$memcache->replace( 'name', 'lion', 0, 300);

echo $memcache->get( 'name');

$memcache->delete( 'name', 5);
?>
<?php
function _callback_memcache_failure($host, $port) {
print "memcache '$host:$port' failed";
}
$memcache = new Memcache;
$memcache->addServer('192.168.1.116', 11211);
$memcache->setServerParams('192.168.1.116', 11211, 1, 15, true,

'_callback_memcache_failure');
echo $memcache->getServerStatus('192.168.1.116', 11211);
?>
<?php
$memcache = new Memcache;
$memcache->connect('localhost', 11211);
$memcache->set('test_item', 8);
$memcache->increment('test_item', 4);
echo $memcache->decrement('test_item', 7);
// 显示 5
?>

/usr/local/bin/memcached -d -m 10 -u root -l 127.0.0.1 -p 11211 -c 256 -P

/tmp/memcached.pid

memcached的服务正式启动

Memcache::add — 添加一个值,如果已经存在,则返回false

Memcache::addServer — 添加一个可供使用的服务器地址

Memcache::close — 关闭一个Memcache对象

Memcache::connect — 创建一个Memcache对象

memcache_debug — 控制调试功能

Memcache::decrement — 对保存的某个key中的值进行减法操作

Memcache::delete — 删除一个key值

Memcache::flush — 清除所有缓存的数据

Memcache::get — 获取一个key值

Memcache::getExtendedStats — 获取进程池中所有进程的运行系统统计

Memcache::getServerStatus — 获取运行服务器的参数

Memcache::getStats — 返回服务器的一些运行统计信息

Memcache::getVersion — 返回运行的Memcache的版本信息

Memcache::increment — 对保存的某个key中的值进行加法操作

Memcache::pconnect — 创建一个Memcache的持久连接对象

Memcache::replace — R对一个已有的key进行覆写操作

Memcache::set — 添加一个值,如果已经存在,则覆写

Memcache::setCompressThreshold — 对大于某一大小的数据进行压缩Memcache::setServerParams — 在运行时修改服务器的参数

建议用面向对象的方式来测试这个库:

Memcache::getVersion方法的作用是返回运行的Memcache的版本信息。

Memcache::getStats 方法的作用是返回服务器的一些运行统计信息。Memcache::getStats方法有三个参

数,第一个参数表示要求返回的类型:reset, malloc, maps, cachedump, slabs, items, sizes;第二个

参数和第三个参数是在第一个参数设置为“cachedump”时使用的。Memcache::getExtendedStats方法的

作用是获取进程池中所有进程的运行系统统计。

Memcache::connect方法的作用是创建一个Memcache对象。Memcache::pconnect方法的作用是创建一个

Memcache的持久连接对象。Memcache::close方法的作用是关闭一个Memcache对象。

Memcache::set 方法的作用是添加一个值,Memcache::set方法有四个参数,第一个参数是key,第二个参

数是value,第三个参数可选,表示是否压缩保存,第四个参数可选,用来设置一个过期自动销毁的时间

。Memcache::add方法的作用和Memcache::set方法类似,区别是如果 Memcache::add方法的返回值为

false,表示这个key已经存在,而Memcache::set方法则会直接覆写。 Memcache::get方法的作用是获取

一个key值,Memcache::get方法有一个参数,表示key。Memcache::replace 方法的作用是对一个已有的

key进行覆写操作,Memcache::replace方法有四个参数,作用和Memcache::set方法的相同。

Memcache::delete方法的作用是删除一个key值,Memcache::delete方法有两个参数,第一个参数表示key

,第二个参数可选,表示删除延迟的时间。

memcache_debug()函数的作用是控制调试功能,前提是php在编译的时候使用了–enable-debug选项,否

则这个函数不会有作用。

Memcache::addServer 方法的作用是添加一个可供使用的服务器地址,Memcache::addServer方法有8个参

数,除了第一个参数意外,其他都是可选的,第一个参数表示服务器的地址,第二个参数表示端口,第三

个参数表示是否是一个持久连接,第四个参数表示这台服务器在所有服务器中所占的权重,第五个参数表

示连接的持续时间,第六个参数表示连接重试的间隔时间,默认为15,设置为-1表示不进行重试,第七个

参数用来控制服务器的在线状态,第8个参数允许设置一个回掉函数来处理错误信息。

Memcache::setServerParams方法的作用是在运行时修改服务器的参数,Memcache::setServerParams方法

有六个参数,Memcache::addServer方法少了第三和第四个参数。 Memcache::getServerStatus方法的作

用是获取运行服务器的参数,两个参数分别表示的地址和端口。

Memcache::flush方法的作用是清除所有缓存的数据,但是不会削去使用的内存空间。

Memcache::increment方法的作用是对保存的某个key中的值进行加法操作,Memcache::decremen方法的作

用是对保存的某个key中的值进行减法操作。

Discuz!的Memcache缓存实现

前言:

在PHP+MySQL架构的站点中,本文重点从MySQL的角度去分析如何使Discuz!论坛(或者类似的PHP+MySQL架构的程序)应对大访
问 量。同时给出一些使用Memcache去减轻MySQL压力的建议。其中很多数据是个人测试的结果,如有不同意见,敬请留言告之。另外由于个人思维的
问 题,行文比较跳跃,特此声明!

系统分析:

单纯的从MySQL的角度出发,单台MySQL的数据库负载到每天上亿次的操作(每秒大概1100次MySQL操作,然后乘以86400)应该不是非常
困 难的事情。按照这个数据也就是说一个单MySQL服务器的论坛来说可以跑到2千万PV是不成问题的,我相信国内绝大部分的论坛都不可能做到每天2千万
的 PV,但实际情况并不是如此。当论坛PV超过百万的时候一台WEB早已经不堪重负了。

就我手头的一些数据显示,目前的Discuz!论坛的基本服务器架构是前面Squid顶着,后面才是一台DB在撑着。这种架构中,web服务器压力增大
可 以通过并行增加服务器解决,而MySQL压力却无处释放,在不考虑MySQL官方服务的情况下,我们通过合理的利用Memcache是可以达到减
轻 MySQL服务器负载的。

可能会有朋友说我们可以对数据表进行分表(注:此处分表是指通过PHP程序去分表,比如pw,dv的分表)处理,但是当前的情况是一台DB服务器已经不
能 支撑当前的数据处理了,通过PHP对MySQL进行的分表依然不能减轻MySQL的负载。(注:本段文字针对已经成型的系统,如果是独立开发的系统在
架构 前期就进行数据的同步分区还是不错的。)

还可能有朋友会说利用MySQL的主从构架,如果你提出这个问题,我就很明确的告诉你,回去看看手册吧。在Mysql Master/Slave 模式
中,Slave主要是来备份数据的,只有当Master出现故障时,Slave才会接过Master的服务,对外部请求进行处理,直到Master恢 复
正常。就是说:在Master/Slave中,要么是Master在服务,要么是Slave在服务,不会Master/Slave同时提供服务。使
用 MySQL主从依然不能有效的降低MySQL的负载。

或许你又会问我为什么不使用MySQL集群(MySQL Cluster),那可是白花花的银子啊,同等金钱的付出下,获得最大的收益才是王道。PS:说句题外话,MySQL手册中将MySQL集群解释为MySQL簇,不习惯。

其实在MySQL5.1中的MySQL分区(MySQL Partition)是个很好的东西,它允许根据可以设置为任意大小的规则,跨文件系统分配单个
表的多个部分。实际上,表的不同部分在不同的位置被存储为 单独的表。我认为这个才是当前情况下,最积极有效的降低MySQL负载的解决方法之一。但是遗
憾的是,这种MySQL分区的方式我个人没有使用过的经历, 也不见有相当充分的案例表明它是稳定的或者不稳定的。所以我还在徘徊中。如果你知道,请麻烦
告之!有朋友说腾讯是在用MySQL分区,但是遗憾的是我没有 得到确切的数据。

好了分析总结了这么多种降低MySQL负载的方式之后,在用户环境需求等特定条件下,我得出结论在当前情况下,缓解Discuz!论坛的MySQL负载比较有效的方法就是使用Memcache!

使用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(

修改为

$db->query_memcache(

注意并将

while($post = $db->fetch_array($query)) {

修改为

foreach($query as $post) {

没有while的$db->fetch_array可以不用修改。

下面代码有用得着的就拿去:

preg_replace("/while[$](\w+)\s∗\=\s∗[$]db−>fetcharray\([$]query\)/is", "foreach(\$query as \$\\1)", $file);

回头放出个小工具批量替换下就可以了。

在EditPlus中可以这样替换:while[$](.∗)=[$]db−>fetcharray\([$]query\)替换为foreach($query as $\1)

5.完成了,测试吧!~

参考资料:

对Memcached有疑问的朋友可以参考下列文章:

Linux下的Memcache安装:http://www.ccvita.com/index.php/257.html

Windows下的Memcache安装:http://www.ccvita.com/index.php/258.html

Memcache基础教程:http://www.ccvita.com/index.php/259.html

Discuz!的Memcache缓存实现:http://www.ccvita.com/index.php/261.html

后记

写完之后突然发现天已经要亮了,闷骚了一个晚上。个人的一些总结,欢迎留言探讨!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: