Memcahced是一个开源分布式内存对象缓存系统。稍微大一点的项目经常会使用 Memcached 以减少数据库的负担,从而加速web应用的响应速度。网络上有大量关于 Memcached 安装的方法以及使用介绍,本文所要说的就是其实 memcached 很简单,没有想象的那么神秘,我们可以简单的理解为它就是一个缓存服务器应用程序,就像是你装了个 Mysql 一样,装好了之后用账号密码IP地址连一下就能使用。
首页简单的介绍一下 memcached 的原理
第一次用户发送请求,PHP程序会在访问db数据库的同时,将访问的数据写入Memcached系统。
如图所示,user发送了req请求,application发送数据请求到database,database在将数据返回给application的同时,将数据缓存到了Memcached服务器。
第二次用户请求到达,会直接读取Memcached服务器的缓存,而不是数据库中的内容,从而减轻了服务器的负担。
本图显示,第二次的请求,application直接从Memcached(简称Mc)读取数据。
下面通过一个实例分享一下 memcached 的基本使用方法(类似友情链接的一个开发实例)。相信通过这个实例,你就能很清楚的理解了这个东东。
下面的案例假设你已经安装好了 memcached 服务,如果没有安装的话,请参考本站:
memcached是什么?memcache该何使用?
windows系统下安装memcache
(1)新建一个数据库
实例中使用的数据库表包含一个自增的id,一个标题和一个链接字段:
2 | id INT PRIMARY KEY AUTO_INCREMENT, |
(2)程序部分(程序的注释会让你很轻松的理解 memcached 的使用)
03 | $memcache = new Memcache; |
04 | $memcache ->connect( 'localhost' , 11211) or die ( "Could not connect" ); |
06 | $key = md5( 'www.crazyant.net' ); |
07 | $cache_result = array (); |
09 | $cache_result = $memcache ->get( $key ); |
13 | $demos_result = $cache_result ; |
17 | $v =mysql_query( "select * from demos order by id desc" ); |
18 | while ( $row =mysql_fetch_array( $v )){ |
23 | $memcache ->set( $key , $demos_result , MEMCACHE_COMPRESSED, 1200); |
26 | foreach ( $demos_result as $row ){ |
27 | echo '<a href=' . $row [ 'link' ]. '>' . $row [ 'title' ]. '</a>' ; |
下面是用于连接数据库的代码文件 db.php
2 | $mysql_hostname = "localhost" ; |
3 | $mysql_user = "username" ; |
4 | $mysql_password = "password" ; |
5 | $mysql_database = "database" ; |
6 | $bd =mysql_connect( $mysql_hostname , $mysql_user , $mysql_password ) or die ( "Opps some thing went wrong" ); |
7 | mysql_select_db( $mysql_database , $bd ) or die ( "Opps some thing went wrong" ); |