php是一个动态脚本语言,所以为了让用户在浏览器中看到页面内容,服务器必须解析php代码从而生成想用的html代码。从上面的图中可以看出,在没有apc的时候,用户对php页面的每一次请求,服务器都需要进行对php进行解析,编译以及执行,但是很多时候,只要php代码没有发生更改,php的执行逻辑就不会改变,也就是说解析以及编译的过程就可以省略,直接执行然后将结果返回即可。这就是apc的工作,apc缓存php的可执行代码,从而去掉了解析以及编译的过程,加快了php脚本的执行速度。apc 对用户数据的缓存以及除了缓存php代码外,apc还可以进行用户数据的缓存,但是由于apc的容量很少,所以缓存的数据最好是那些很长时间都不变的数据,不变的单位应该以天位单位。所以如果数据是变化很频繁的并且数据量也比较大,那么就不要使用apc了,可以使用memcache或者redis。下面是一个apc和redis的对比测试实验,看一下apc和redis的效率对比。function gettimestamp() { $timestr = microtime(); $timestrary = explode(' ', $timestr); $result = intval($timestrary[1])*1000 + intval(floatval($timestrary[0])*1000); return $result;} $redis = new redis();$redis->connect('127.0.0.1', 6379);$key = 'key';$value ='value';$redis->set($key, $value); apc_store($key, $value, 1); $begin = gettimestamp();for($i = 0 ; $i get($key);} $cost = gettimestamp() - $begin;var_dump($cost);$redis->close();
都是简单的取数据操作,分别进行10万次,单位是毫秒。最后的运行结果redis10万次读在4-5秒之间,而apc得10万次读只有50毫秒左右。可以看到如果是简单的缓存一些数据,并且这些数据不会变化且命中的话,apc还是能带来一定的效率提升的。安装apc时会有一个apc.php的页面可以通过这个页面查看apc的命中。如下图
apc的配置配置的例子如下:extension= apc.so apc.enabled=1apc.shm_segments=1 apc.shm_size=64m ; apc内存的大小,最后的大小需要乘上segments的数量,所以这里一共为apc分配64m apc.ttl=7200 apc.user_ttl=7200apc.enable_cli=1 ; 这个如果不开启,则只可以在网页上进行apc操作,不能通过cli进行apc操作
参考http://www.inmotionhosting.com/support/website/what-is/speed-up-php-with-apc http://bbs.phpchina.com/thread-202432-1-1.html
版权声明:本文为博主原创文章,未经博主允许不得转载。
以上就介绍了php apc缓存以及与redis的对比,包括了方面的内容,希望对php教程有兴趣的朋友有所帮助。
