PHP之Memcache和Memcached
本篇文章向大家介绍的是PHP中的Memcache和Memcached ,有兴趣的朋友可以看一下
**Memcache介绍:**Memcache是一套分布式缓存系统,分布式就是说可以在多台服务器上同时安装Memcache服务,这样可以达到很好的集群效果。高速,是因为Memcache数据都是维护在内存中的,它的读取速度比存储在硬盘中的数据的读取速度要快很多。
作用:当我们的应用访问量比较大的时候,数据库的压力也会特别大,Memcache可以在应用和数据库之间增加一个缓冲层,就是我们之前从数据库中已经读取到的数据,我们第二次或者是接下来再读取的时候,就可以直接访问Memcache去读取这些数据,从而减轻Mysql等等数据库的压力
怎样理Memcache:其实可以理解成,它是一个只有一张表的数据库,这张表有两个字段,分别是key和value,value是保存的数据,key就是这个数据的ID,用来保证查找时的唯一性
使用场景:
(1)非持久化存储:对数据存储要求不高,也就是说,如果这份数据丢失,也不会对系统造成太大的影响,因为当系统断电或被重启后内存会被清空掉,那么之前保存在Memcache中的数据也会被清空掉。所以要把Memcache当作缓存使用,而不要当成真正的数据库
(2)分布式存储:不适合单机使用,因为Memcache对内存的消耗很大,如果使用Memcache,推荐将其安装在另外一台机器上单独作为缓存系统,而不要把Memcache和数据库都装到一台机器。
(3)Key/Value存储:格式简单,不支持List、Array数据格式
Memcached和Memcache是两个版本,推荐Memcached,它有更多的改进和功能函数,是Memcache的升级版本,速度和稳定性都比较高
安装Memcached
1,Memcache服务端的安装
(1)编译安装,Libevent Memcache
先安装Libevent这个扩展,编译安装的好处就是可以在安装的过程进行一些自定义的设置,比如指定软件安装在哪儿,比如编译安装过程出现了哪些错误,而对Linux了解不是特别多的情况下,你可能处理错误的时候就会相对困难
(2)使用依赖管理工具yum、apt-get进行安装
实际安装:(操作系统是64位的Centos)
如果要编译安装,需要将安装包提前下载下来libevent、memcached
这里使用依赖管理工具安装
#yum install memcached
启动memcached
#/usr/bin/memcached -d -l 127.0.0.1 -p 11211 -m 150 -u root/* -d:守护进程的模式启动。守护进程就是,当你从终端窗口推出之后,程序依然进行 -l:指定IP地址 -p:指定端口号 -m:为memcached分配多少内存,这里是以M为单位 -u:以哪个身份去启动memcached(线上的时候最好不要用超级管理员用户)*/
可以使用ps查看memcached进程是否启动
#ps -ef | grep memcached
2,Memcache客户端的安装
1,安装前置扩展Libmemcached
下载好libmemcached和memcached,对libmemcached进行解压
这里使用编译安装,进入解压出来的文件夹
执行
#./configure --prefix=/usr/lib/libmemcached然后执行#make && makeinstall
2,为php安装memcached扩展
解压memcached,进入到解压目录当中
使用phpize的方式安装memcached扩展
#phpize此时就会做出一个configure的文件#./configure --with-php-config=/usr/local/php/bin/php-config --with-libmemcached-dir=/usr/lib/libmemcached-sasl后边是指定php的配置文件和刚安装的libmemcached的位置,大家根据自己的配置文件路径进行填写#make#make install执行完make install之后,我们会看见一个扩展目录,将该路径添加到php配置文件中 php.ini中加入 extension=memcached.so 然后重启服务器环境,查看php扩展#php -m | grep memecached
在PHP中使用memcached
系统类:addServer、addServers、getStats、getVersion
数据类:add、set、delete、flush、replace、increment、get
进阶类:setMulti、deleteMulti、getMulti、getResultCode、getResultMessage
更多关于memecached的操作,可以到php官网查看(php.net)
test.php<?php/*系统类*/$m = new Memcached();/*添加服务器*/$m->addServer('127.0.0.1', 11211);/*添加多台服务器*/$array = array( array('127.0.0.1', 11211), array('127.0.0.1', 11211) );$m->addServers($array);/*查看服务器状态*/print_r($m->getStats());/*查看服务端版本号*/print_r($m->getVersion());/*数据类*/$m->add('mkey', 'mvalue', 0);//第三个参数是数据存在的时间,0表示永久echo $m->get('mkey');//获取数据/*假设对同一个key值进行两次添加的话,后边的操作不会覆盖前边的value,如果想替换掉,就使用replace*/$m->replace('mkey', 'mvalue2');/*还可以使用set方法表添加数据,它的好处就是,当我们的数据不存在时会帮我们新建数据,如果存在,就会覆盖原值*/$m->add('mkey', 'mvalue', 600);/*删除数据*/$m->delete('mkey');/*清空memcache中的所有缓存*/$m->flush();/*对memcache中整形数据进行+1或+任意数值的操作*/$m->set('num', 5, 0);$m->increment('num', 5);//每次刷新页面,num自增5$m->get('num');/*自减decrement用法相同*//*下边的方法只支持Memcached,不支持Memcache*//*一次添加多条数据*///原始方法,多次使用set()//现在可以使用setMulti()$data = array( 'key' => 'value', 'key1'=> 'value1');$m->setMulti($data,0);$result = $m->getMulti(array('key','key1'));//获取多条数据print_r($result);//删除多条数据$m->deleteMulti(array('key','key1'));//返回上一次操作返回的编码(数字的形式存在) 可以到手册中查看每一个编码的含义 echo $m->getResultCode();//比如 成功 返回0//获取操作结果echo $m->getResultMessage();//比如 成功 返回SUCCESS
封装一个自己的Memcache类
Memcached.class.php<?php/* 封装自己的Memcached类 1,扩展性 2,可调性 3,尽量简便的操作,一个方法多种功能 *//* 通过一个s()方法实现set()、get()、delete()操作 set s($key,$value,$time) get s($key) delete s($key,NULL) */class Mem { private $type = 'Memcached';//考虑到扩展性,实例化的可能是Memcache也可能是Memcached private $m; private $time = 0; private $error; private $debug = 'true'; public function __construct() { if(!class_exists($this->type)){ $this->error="No ".$this->type; return false; }else{ $this->m=new $this->type; } } //添加服务器 public function addServer($arr) { $this->m->addServers($arr); } public function s($key, $value='', $time=NULL) { $number = func_num_args();//该函数用来判断传递过来了几个参数 if($number == 1){ return $this->get($key); }else if($number >= 2){ if($value === NULL){//一定要使用“全等于”,因为如果不是全等于,传递过来0也会通过 $this->delete($key); }else{ $this->set($key, $value, $time); } } } private function set($key, $value, $time=NULL) { if($time === NULL) $time = $this->time(); $this->m->set($key, $value, $time); if($this->debug){ if($this->m->getResultCode() != 0){ return false; } } } private function get($key){ $result = $this->m->get($key); if($this->debug){ if($this->m->getResultCode() != 0){ return false; } } return $result; } private function delete($key) { $this->m->delete($key); } public function getError() { if($this->error){ return $this->error(); }else{ return $this->m->getResultMessage(); } } }
项目中使用Memcache
1,即时生成缓存
比较适用于类似于新闻详情页,第一个人进入页面时,生成缓存,当后边的人再进入这个页面时,可以直接从缓存中获取数据,并且可以给数据设置一个过期时间,这样的话,等看这个新闻的人比较少的时候就可以及时清除缓存,这样可以达到节约内存的目的
2,提前生成缓存
这种生成缓存的方式,比较适用于访问量比较大且数据量比较多,类似于网站首页这种情况。可以使用定时脚本的方式,提前将缓存生成
3,永久缓存
这种缓存方案比较适合于关于单独的页面,它的修改频率非常低,这时可以生成永久缓存
**Memcache介绍:**Memcache是一套分布式缓存系统,分布式就是说可以在多台服务器上同时安装Memcache服务,这样可以达到很好的集群效果。高速,是因为Memcache数据都是维护在内存中的,它的读取速度比存储在硬盘中的数据的读取速度要快很多。
作用:当我们的应用访问量比较大的时候,数据库的压力也会特别大,Memcache可以在应用和数据库之间增加一个缓冲层,就是我们之前从数据库中已经读取到的数据,我们第二次或者是接下来再读取的时候,就可以直接访问Memcache去读取这些数据,从而减轻Mysql等等数据库的压力
怎样理Memcache:其实可以理解成,它是一个只有一张表的数据库,这张表有两个字段,分别是key和value,value是保存的数据,key就是这个数据的ID,用来保证查找时的唯一性
使用场景:
(1)非持久化存储:对数据存储要求不高,也就是说,如果这份数据丢失,也不会对系统造成太大的影响,因为当系统断电或被重启后内存会被清空掉,那么之前保存在Memcache中的数据也会被清空掉。所以要把Memcache当作缓存使用,而不要当成真正的数据库
(2)分布式存储:不适合单机使用,因为Memcache对内存的消耗很大,如果使用Memcache,推荐将其安装在另外一台机器上单独作为缓存系统,而不要把Memcache和数据库都装到一台机器。
(3)Key/Value存储:格式简单,不支持List、Array数据格式
Memcached和Memcache是两个版本,推荐Memcached,它有更多的改进和功能函数,是Memcache的升级版本,速度和稳定性都比较高
安装Memcached
1,Memcache服务端的安装
(1)编译安装,Libevent Memcache
先安装Libevent这个扩展,编译安装的好处就是可以在安装的过程进行一些自定义的设置,比如指定软件安装在哪儿,比如编译安装过程出现了哪些错误,而对Linux了解不是特别多的情况下,你可能处理错误的时候就会相对困难
(2)使用依赖管理工具yum、apt-get进行安装
实际安装:(操作系统是64位的Centos)
如果要编译安装,需要将安装包提前下载下来libevent、memcached
这里使用依赖管理工具安装
#yum install memcached
启动memcached
#/usr/bin/memcached -d -l 127.0.0.1 -p 11211 -m 150 -u root/* -d:守护进程的模式启动。守护进程就是,当你从终端窗口推出之后,程序依然进行 -l:指定IP地址 -p:指定端口号 -m:为memcached分配多少内存,这里是以M为单位 -u:以哪个身份去启动memcached(线上的时候最好不要用超级管理员用户)*/
可以使用ps查看memcached进程是否启动
#ps -ef | grep memcached
2,Memcache客户端的安装
1,安装前置扩展Libmemcached
下载好libmemcached和memcached,对libmemcached进行解压
这里使用编译安装,进入解压出来的文件夹
执行
#./configure --prefix=/usr/lib/libmemcached然后执行#make && makeinstall
2,为php安装memcached扩展
解压memcached,进入到解压目录当中
使用phpize的方式安装memcached扩展
#phpize此时就会做出一个configure的文件#./configure --with-php-config=/usr/local/php/bin/php-config --with-libmemcached-dir=/usr/lib/libmemcached-sasl后边是指定php的配置文件和刚安装的libmemcached的位置,大家根据自己的配置文件路径进行填写#make#make install执行完make install之后,我们会看见一个扩展目录,将该路径添加到php配置文件中 php.ini中加入 extension=memcached.so 然后重启服务器环境,查看php扩展#php -m | grep memecached
在PHP中使用memcached
系统类:addServer、addServers、getStats、getVersion
数据类:add、set、delete、flush、replace、increment、get
进阶类:setMulti、deleteMulti、getMulti、getResultCode、getResultMessage
更多关于memecached的操作,可以到php官网查看(php.net)
test.php<?php/*系统类*/$m = new Memcached();/*添加服务器*/$m->addServer('127.0.0.1', 11211);/*添加多台服务器*/$array = array( array('127.0.0.1', 11211), array('127.0.0.1', 11211) );$m->addServers($array);/*查看服务器状态*/print_r($m->getStats());/*查看服务端版本号*/print_r($m->getVersion());/*数据类*/$m->add('mkey', 'mvalue', 0);//第三个参数是数据存在的时间,0表示永久echo $m->get('mkey');//获取数据/*假设对同一个key值进行两次添加的话,后边的操作不会覆盖前边的value,如果想替换掉,就使用replace*/$m->replace('mkey', 'mvalue2');/*还可以使用set方法表添加数据,它的好处就是,当我们的数据不存在时会帮我们新建数据,如果存在,就会覆盖原值*/$m->add('mkey', 'mvalue', 600);/*删除数据*/$m->delete('mkey');/*清空memcache中的所有缓存*/$m->flush();/*对memcache中整形数据进行+1或+任意数值的操作*/$m->set('num', 5, 0);$m->increment('num', 5);//每次刷新页面,num自增5$m->get('num');/*自减decrement用法相同*//*下边的方法只支持Memcached,不支持Memcache*//*一次添加多条数据*///原始方法,多次使用set()//现在可以使用setMulti()$data = array( 'key' => 'value', 'key1'=> 'value1');$m->setMulti($data,0);$result = $m->getMulti(array('key','key1'));//获取多条数据print_r($result);//删除多条数据$m->deleteMulti(array('key','key1'));//返回上一次操作返回的编码(数字的形式存在) 可以到手册中查看每一个编码的含义 echo $m->getResultCode();//比如 成功 返回0//获取操作结果echo $m->getResultMessage();//比如 成功 返回SUCCESS
封装一个自己的Memcache类
Memcached.class.php<?php/* 封装自己的Memcached类 1,扩展性 2,可调性 3,尽量简便的操作,一个方法多种功能 *//* 通过一个s()方法实现set()、get()、delete()操作 set s($key,$value,$time) get s($key) delete s($key,NULL) */class Mem { private $type = 'Memcached';//考虑到扩展性,实例化的可能是Memcache也可能是Memcached private $m; private $time = 0; private $error; private $debug = 'true'; public function __construct() { if(!class_exists($this->type)){ $this->error="No ".$this->type; return false; }else{ $this->m=new $this->type; } } //添加服务器 public function addServer($arr) { $this->m->addServers($arr); } public function s($key, $value='', $time=NULL) { $number = func_num_args();//该函数用来判断传递过来了几个参数 if($number == 1){ return $this->get($key); }else if($number >= 2){ if($value === NULL){//一定要使用“全等于”,因为如果不是全等于,传递过来0也会通过 $this->delete($key); }else{ $this->set($key, $value, $time); } } } private function set($key, $value, $time=NULL) { if($time === NULL) $time = $this->time(); $this->m->set($key, $value, $time); if($this->debug){ if($this->m->getResultCode() != 0){ return false; } } } private function get($key){ $result = $this->m->get($key); if($this->debug){ if($this->m->getResultCode() != 0){ return false; } } return $result; } private function delete($key) { $this->m->delete($key); } public function getError() { if($this->error){ return $this->error(); }else{ return $this->m->getResultMessage(); } } }
项目中使用Memcache
1,即时生成缓存
比较适用于类似于新闻详情页,第一个人进入页面时,生成缓存,当后边的人再进入这个页面时,可以直接从缓存中获取数据,并且可以给数据设置一个过期时间,这样的话,等看这个新闻的人比较少的时候就可以及时清除缓存,这样可以达到节约内存的目的
2,提前生成缓存
这种生成缓存的方式,比较适用于访问量比较大且数据量比较多,类似于网站首页这种情况。可以使用定时脚本的方式,提前将缓存生成
3,永久缓存
这种缓存方案比较适合于关于单独的页面,它的修改频率非常低,这时可以生成永久缓存
相关推荐:
php模块memcache和memcached区别分析_PHP教程
以上是PHP之Memcache和Memcached的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

在Web开发中,我们经常需要使用缓存技术来提高网站的性能和响应速度。Memcache是一种流行的缓存技术,它可以缓存任何数据类型、支持高并发和高可用性。本文将介绍如何使用PHP开发中的Memcache,并提供具体代码示例。一、安装Memcache要使用Memcache,我们首先需要在服务器上安装Memcache扩展。在CentOS操作系统中,可以使用以下命令

随着互联网的发展,PHP应用程序在互联网应用领域中变得越来越常见。但是,PHP应用程序的高并发访问会导致服务器的CPU使用率高,从而影响应用程序的性能。为了优化PHP应用程序的性能,Memcached缓存技术成为了一种很好的选择。本文将介绍如何使用Memcached缓存技术优化PHP应用程序CPU的使用率。Memcached缓存技术简介Memcached是一

在PHP开发中,使用Memcache缓存系统可以大大提高数据读写的效率。Memcache是一种基于内存的缓存系统,它可以将数据缓存在内存中,避免频繁的读写数据库。本文将介绍如何在PHP中使用Memcache进行高效的数据读写操作,并提供具体的代码示例。一、安装和配置Memcache首先,需要在服务器上安装Memcache扩展。可以通过

PHP开发中如何使用Memcache进行高效的数据写入和查询?随着互联网应用的不断发展,对于系统性能的要求越来越高。在PHP开发中,为了提高系统的性能和响应速度,我们经常会使用各种缓存技术。而其中一个常用的缓存技术就是Memcache。Memcache是一种高性能的分布式内存对象缓存系统,可以用来缓存数据库查询结果、页面片段、会话数据等。通过将数据存储在内存

随着Web应用程序的日益复杂,性能也成为了一个关键问题。在许多应用程序中,数据库查询是最耗费时间的操作之一。为了避免频繁地从数据库中读取数据,可以使用一个缓存系统,将经常读取的数据存储在内存中,以便快速的访问。在PHP开发中,使用Memcached进行分布式缓存是一个极为常见的做法,在本文中我们将介绍如何使用Memcached进行分布式缓存。什么是Memca

如何使用Memcache优化你的PHP应用中的数据存储操作?在Web应用开发中,数据存储是一个至关重要的环节。而在PHP应用中,Memcache作为一种内存缓存系统,可以有效地提升数据存储和读取操作的效率。本文将介绍如何使用Memcache优化PHP应用中的数据存储操作,并附上具体的代码示例。第一步:安装Memcache扩展首先,你需要在PHP环境中安装Me

PHP是一种十分流行的编程语言,常用于服务器端的Web应用程序开发。随着Web应用程序用户规模的不断增长以及数据量的不断增大,高效的数据缓存和排序操作变得越来越重要。在这种情况下,Memcache是一种非常有用的工具。本文将介绍如何在PHP开发中使用Memcache实现高效的数据缓存和排序操作,并提供具体的代码示例。什么是Memcache?Memcache是

随着互联网的发展,缓存技术在Web开发中扮演着越来越重要的角色。Redis和Memcached作为两种流行的缓存服务器,被广泛应用于各种Web应用开发中。然而,对于不熟悉Linux系统的开发人员来说,安装和配置这些缓存服务器可能会带来一些麻烦。但是,在宝塔面板的帮助下,这一过程将变得相当简单。一、什么是宝塔面板?宝塔面板是一款Linux服务器管理面板,它可以
