`
isiqi
  • 浏览: 16824158 次
  • 性别: Icon_minigender_1
  • 来自: 济南
社区版块
存档分类
最新评论
阅读更多

http://nio.infor96.com/php-memcached/

肖理达 (KrazyNio AT hotmail.com), 2006.04. 06, 转载请注明出处

一、memcached 简介

在很多场合,我们都会听到 memcached 这个名字,但很多同学只是听过,并没有用过或实际了解过,只知道它是一个很不错的东东。这里简单介绍一下,memcached 是高效、快速的分布式内存对象缓存系统,主要用于加速 WEB 动态应用程序。

二、memcached 安装

首先是下载 memcached 了,目前最新版本是 1.1.12,直接从官方网站即可下载到 memcached-1.1.12.tar.gz。除此之外,memcached 用到了 libevent,我下载的是 libevent-1.1a.tar.gz

接下来是分别将 libevent-1.1a.tar.gz 和 memcached-1.1.12.tar.gz 解开包、编译、安装:

# tar -xzf libevent-1.1a.tar.gz
# cd libevent-1.1a
# ./configure --prefix=/usr
# make
# make install
# cd ..
# tar -xzf memcached-1.1.12.tar.gz
# cd memcached-1.1.12
# ./configure --prefix=/usr
# make
# make install

安装完成之后,memcached 应该在 /usr/bin/memcached。

三、运行 memcached 守护程序

运行 memcached 守护程序很简单,只需一个命令行即可,不需要修改任何配置文件(也没有配置文件给你修改 :) ):

/usr/bin/memcached -d -m 128 -l 192.168.1.1 -p 11211 -u httpd

参数解释:

-d 以守护程序(daemon)方式运行 memcached;
-m 设置 memcached 可以使用的内存大小,单位为 M;
-l 设置监听的 IP 地址,如果是本机的话,通常可以不设置此参数;
-p 设置监听的端口,默认为 11211,所以也可以不设置此参数;
-u 指定用户,如果当前为 root 的话,需要使用此参数指定用户。

当然,还有其它参数可以用,man memcached 一下就可以看到了。

四、memcached 的工作原理

首先 memcached 是以守护程序方式运行于一个或多个服务器中,随时接受客户端的连接操作,客户端可以由各种语言编写,目前已知的客户端 API 包括 Perl/PHP/Python/Ruby/Java/C#/C 等等。PHP 等客户端在与 memcached 服务建立连接之后,接下来的事情就是存取对象了,每个被存取的对象都有一个唯一的标识符 key,存取操作均通过这个 key 进行,保存到 memcached 中的对象实际上是放置内存中的,并不是保存在 cache 文件中的,这也是为什么 memcached 能够如此高效快速的原因。注意,这些对象并不是持久的,服务停止之后,里边的数据就会丢失。

image001.png

三、PHP 如何作为 memcached 客户端

有两种方法可以使 PHP 作为 memcached 客户端,调用 memcached 的服务进行对象存取操作。

第一种,PHP 有一个叫做 memcache 的扩展,Linux 下编译时需要带上 –enable-memcache[=DIR] 选项,Window 下则在 php.ini 中去掉 php_memcache.dll 前边的注释符,使其可用。

除此之外,还有一种方法,可以避开扩展、重新编译所带来的麻烦,那就是直接使用 php-memcached-client

本文选用第二种方式,虽然效率会比扩展库稍差一些,但问题不大。

四、PHP memcached 应用示例

首先 下载 memcached-client.php,在下载了 memcached-client.php 之后,就可以通过这个文件中的类“memcached”对 memcached 服务进行操作了。其实代码调用非常简单,主要会用到的方法有 add()、get()、replace() 和 delete(),方法说明如下:

add ($key, $val, $exp = 0)
往 memcached 中写入对象,$key 是对象的唯一标识符,$val 是写入的对象数据,$exp 为过期时间,单位为秒,默认为不限时间;

get ($key)
从 memcached 中获取对象数据,通过对象的唯一标识符 $key 获取;

replace ($key, $value, $exp=0)
使用 $value 替换 memcached 中标识符为 $key 的对象内容,参数与 add() 方法一样,只有 $key 对象存在的情况下才会起作用;

delete ($key, $time = 0)
删除 memcached 中标识符为 $key 的对象,$time 为可选参数,表示删除之前需要等待多长时间。

下面是一段简单的测试代码,代码中对标识符为 'mykey' 的对象数据进行存取操作:


<pre>
<?php
//包含memcached类文件
require_once('memcached-client.php');
//选项设置
$options=array(
'servers'=>array('192.168.1.1:11211'),//memcached服务的地址、端口,可用多个数组元素表示多个memcached服务
'debug'=>true,//是否打开debug
'compress_threshold'=>10240,//超过多少字节的数据时进行压缩
'persistant'=>false//是否使用持久连接
);
//创建memcached对象实例
$mc=newmemcached($options);
//设置此脚本使用的唯一标识符
$key='mykey';
//往memcached中写入对象
$mc->add($key,'somerandomstrings');
$val=$mc->get($key);
echo"n'.str_pad('$mc->add()',60,'_')."n';
var_dump($val);
//替换已写入的对象数据值
$mc->replace($key,array('some'=>'haha','array'=>'xxx'));
$val=$mc->get($key);
echo"n'.str_pad('$mc->replace()',60,'_')."n';
var_dump($val);
//删除memcached中的对象
$mc->delete($key);
$val=$mc->get($key);
echo"n'.str_pad('$mc->delete()',60,'_')."n';
var_dump($val);
?>
</pre>

是不是很简单,在实际应用中,通常会把数据库查询的结果集保存到 memcached 中,下次访问时直接从 memcached 中获取,而不再做数据库查询操作,这样可以在很大程度上减轻数据库的负担。通常会将 SQL 语句 md5() 之后的值作为唯一标识符 key。下边是一个利用 memcached 来缓存数据库查询结果集的示例(此代码片段紧接上边的示例代码):


<?php
$sql='SELECT*FROMusers';
$key=md5($sql);//memcached对象标识符
if(!($datas=$mc->get($key))){
//在memcached中未获取到缓存数据,则使用数据库查询获取记录集。
echo"n'.str_pad('ReaddatasfromMySQL.',60,'_')."n';
$conn=mysql_connect('localhost','test','test');
mysql_select_db('test');
$result=mysql_query($sql);
while($row=mysql_fetch_object($result))
$datas[]=$row;
//将数据库中获取到的结果集数据保存到memcached中,以供下次访问时使用。
$mc->add($key,$datas);
}else{
echo"n'.str_pad('Readdatasfrommemcached.',60,'_')."n';
}
var_dump($datas);
?>

可以看出,使用 memcached 之后,可以减少数据库连接、查询操作,数据库负载下来了,脚本的运行速度也提高了。

之前我曾经写过一篇名为《PHP 实现多服务器共享 SESSION 数据》文章,文中的 SESSION 是使用数据库保存的,在并发访问量大的时候,服务器的负载会很大,经常会超出 MySQL 最大连接数,利用 memcached,我们可以很好地解决这个问题,工作原理如下:

  • 用户访问网页时,查看 memcached 中是否有当前用户的 SESSION 数据,使用 session_id() 作为唯一标识符;如果数据存在,则直接返回,如果不存在,再进行数据库连接,获取 SESSION 数据,并将此数据保存到 memcached 中,供下次使用;
  • 当前的 PHP 运行结束(或使用了 session_write_close())时,会调用 My_Sess::write() 方法,将数据写入数据库,这样的话,每次仍然会有数据库操作,对于这个方法,也需要进行优化。使用一个全局变量,记录用户进入页面时的 SESSION 数据,然后在 write() 方法内比较此数据与想要写入的 SESSION 数据是否相同,不同才进行数据库连接、写入数据库,同时将 memcached 中对应的对象删除,如果相同的话,则表示 SESSION 数据未改变,那么就可以不做任何操作,直接返回了;
  • 那么用户 SESSION 过期时间怎么解决呢?记得 memcached 的 add() 方法有个过期时间参数 $exp 吗?把这个参数值设置成小于 SESSION 最大存活时间即可。另外别忘了给那些一直在线的用户延续 SESSION 时长,这个可以在 write() 方法中解决,通过判断时间,符合条件则更新数据库数据。

五、相关资源

<!-- You can start editing here. -->
分享到:
评论

相关推荐

    官网 linux libevent & memcached 安装包

    安装完成后,你可以通过`memcached`命令启动服务,并通过`memcached-client`或者编程接口(如PHP、Python等)与memcached交互,存储和获取数据。 在实际应用中,libevent常被用于构建高并发的网络服务器,例如HTTP...

    php7 的memcached扩展php_memcached.dll扩展

    **PHP7的Memcached扩展与`php_memcached.dll`** PHP7中的Memcached扩展是一个用于与Memcached缓存服务器通信的客户端库。Memcached是一种分布式内存对象缓存系统,广泛应用于Web应用程序,以提高数据读取速度,减轻...

    php-memcached-3.1.3.tar.gz

    安装php-memcached扩展 https://github.com/php-memcached-dev/php-memcached tar -zxvf php-memcached-3.1.3.tar.gz && cd /root/php-memcached-3.1.3 && /usr/local/php7/bin/phpize && ./configure --with-...

    php memcached安装文档以及Memcached扩展

    **PHP与Memcached扩展安装详解** 在Web开发中,PHP是一种广泛应用的开源脚本语言,而Memcached则是一个高性能的分布式内存对象缓存系统。两者结合可以极大地提高网站的性能,减少数据库负载。本文将详细介绍如何在...

    php_memcached for windows(是“php_memcached”,最后带有“d”)

    windows 操作系统的 php_memcached 扩展。包含适用于php7.0、php7.1、php7.2、php7.3、php7.4,NTS和TS,x86和x86_64各种版本。 重要说明: 1. 安装说明详见“install for windows.pdf”文档; 2. 该资源是...

    memadmin+php_memcached+memcached1.4.5

    标题中的"memadmin+php_memcached+memcached1.4.5"暗示了这是一个关于内存缓存管理系统、PHP扩展以及memcached服务器的组合。这里的关键技术包括`memadmin`(一个用于管理memcached的工具)、`php_memcached`(PHP...

    linux下 php安装memcached扩展

    ### Linux 下 PHP 安装 Memcached 扩展详解 #### 一、Memcached与PHP扩展简介 Memcached 是一种高性能的分布式内存对象缓存系统,用于通过缓存数据库查询结果和任何其他结果来减少数据库负载并加快动态 Web 应用...

    PHP安装memcached

    ### PHP安装memcached知识点 #### 一、理解Memcached与PHP的关系 - **Memcached**:是一种高性能的分布式内存对象缓存系统,用于通过缓存数据库查询结果减少数据库负载,加速动态Web应用,提高网站访问速度。 - **...

    php memcached缓存操作类

    在PHP开发中,缓存是提高网站性能的关键技术之一,Memcached是一款广泛应用的分布式内存对象缓存系统。这个“php memcached缓存操作类”旨在简化开发者对Memcached的使用,提供一个方便、高效的接口来处理数据缓存。...

    memcached1.4.12的32,64版本以及php7的32,64扩展

    PHP7中的Memcache扩展提供了与Memcached服务器交互的一系列函数,如`memcache_connect()`用于建立连接,`memcache_set()`用于存储数据,`memcache_get()`用于获取数据,以及`memcache_close()`用于关闭连接等。...

    php5.2.17关于memcached1.4.3及php_memcache扩展

    《PHP5.2.17与Memcached 1.4.3及php_memcache扩展的集成详解》 在Web开发领域,PHP作为一种广泛使用的服务器端脚本语言,常常需要与各种缓存系统协同工作,以提升网站性能。Memcached就是一个高效、分布式的内存...

    PHP100视频教程74:PHP.MemCached.高级缓存应用.rar

    【PHP与Memcached高级缓存应用】 在现代Web开发中,高效的缓存策略是提高网站性能的关键。PHP作为广泛使用的服务器端脚本语言,结合Memcached这种高性能的分布式内存对象缓存系统,可以显著提升数据读取速度,降低...

    php操作memcached类

    php操作memcached类 简单实用

    Memcached_程序与php中应用

    **Memcached程序与PHP中的应用** Memcached是一种高性能的分布式内存对象缓存系统,用于减少数据库负载,提高网站性能。它简单而强大,通过在内存中存储数据来加速动态Web应用。在PHP中,我们可以使用PHP Memcached...

    php 5.3.10安装memcached资源包

    这个资源包包含了安装PHP Memcached扩展所需的组件,特别是`php_memcache.dll`文件,这是一个Windows平台上的动态链接库,它使PHP能够理解和处理Memcached协议。在Linux或其他Unix-like系统上,这个文件可能是`...

    memcached php 各版本的dll

    标题"memcached php 各版本的dll"表明了本文将讨论的是PHP与Memcached扩展之间的关系,特别是针对不同PHP版本的动态链接库(dll)文件。Memcached是一个高性能的分布式内存对象缓存系统,常用于加速Web应用程序。在...

    php memcached 缓存

    **PHP与Memcached缓存** Memcached是一款高性能、分布式内存对象缓存系统,它被广泛应用于Web应用中,用于减轻数据库的负载,提高网站的响应速度。PHP与Memcached的结合,使得开发者能够轻松地在PHP应用中实现数据...

    搭建linux+php+memcached架构的网站.zip

    搭建一个基于Linux、PHP和Memcached的网站架构是一项常见的任务,尤其对于那些希望提升网站性能、减少数据库压力的开发者来说。这个压缩包包含了搭建这样一个架构所需的一些关键组件和指南。 首先,我们来看一下...

    Memcached与php_memcache.dll

    Memcached和`php_memcache.dll`是Web开发中常见的缓存解决方案,特别是在PHP环境中。Memcached是一个高性能的分布式内存对象缓存系统,用于减少数据库负载,通过在内存中存储数据来提高应用程序的性能。`...

Global site tag (gtag.js) - Google Analytics