memcache和memcached区别

在写这篇文章之前一直对memcache 、memcached模糊,相差一个字母,特此总结下:

Memcache是什么?

Memcache是一个自由和开放源代码、高性能、分配的内存对象缓存系统。用于加速动态web应用程序,减轻数据库负载。它可以应对任意多个连接,使用非阻塞的网络IO。由于它的工作机制是在内存中开辟一块空间,然后建立一个Hash表,Memcached自管理这些Hash表。

Memcached是简单而强大的。它简单的设计促进迅速部署,易于发展所面临的问题,解决了很多大型数据缓存。它的API可供最流行的语言。

Memcache官方网站:http://memcached.org/

Memcached又是什么?

Memcache是该系统的项目名称,Memcached是该系统的主程序文件(字母d可以理解为daemon),以守护程序方式运行于一个或多个服务器中,随时接受客户端的连接操作,使用共享内存存取数据。

memcache客户端(php)

PHP有两个memcache客户端:php memcache和php memcached。

php memcache独立用php实现,是老客户端,从我们实践中已发现有多个问题,而且功能少,属性也可设置的少;

http://pecl.php.net/package/memcache

php memcached是基于原生的c的libmemcached的扩展,更加完善,建议替换为php memcached。

http://pecl.php.net/package/memcached

memcached安装(服务端)

  1. cd /root/lnmp/src/
  2. wget http://memcached.googlecode.com/files/memcached-1.4.15.tar.gz
  3. tar xzf memcached-1.4.15.tar.gz
  4. cd memcached-1.4.15
  5. ./configure --prefix=/usr/local/memcached
  6. make && make install
  7. ln -s /usr/local/memcached/bin/memcached /usr/bin/memcached
  8. /bin/cp scripts/memcached.sysv /etc/init.d/memcached
  9. sed -i ‘[email protected]^USER=.*@USER=root@‘ /etc/init.d/memcached
  10. sed -i ‘[email protected]@#[email protected]‘ /etc/init.d/memcached
  11. sed -i ‘[email protected]/var/run/memcached/[email protected]/var/run/[email protected]‘ /etc/init.d/memcached
  12. sed -i ‘[email protected]^prog=.*@prog="/usr/local/memcached/bin/memcached"@‘ /etc/init.d/memcached #前面有软链接,这里可以省略
  13. chmod +x /etc/init.d/memcached
  14. chkconfig --add memcached
  15. chkconfig memcached on
  16. cd ..

启动memcached:

  1. service memcached start  #或者执行下面
  2. memcached -p 11211 -l 127.0.0.1 -d -u root -P /var/run/memcached.pid -m 64M -c 1024

几个参数的解释:

  • -p memcached监听的TCP端口
  • -l 监听的ip地址,127.0.0.1是本机,当然也可以写上你的服务器IP,如:10.0.0.10,这是我服务器的IP地址,如果你需要多个服务器都能够读取这台memcached的缓存数据,那么就必须设定这个ip
  • -d 以daemon方式运行,将程序放入后台
  • -u memcached的运行用户,我设定的是nobody
  • -P memcached的pid文件路径
  • -m memcached可以使用的最大内存数量
  • -c memcached同时可以接受的最大的连接数

如果你希望以socket方式来访问memcached,那么在启动的时候就必须去掉 -l和-p参数,并加上-s参数:

  • -s memcached的socket文件路径

php中memcache扩展组件的安装:

  1. tar xzf memcache-2.2.7.tgz
  2. cd memcache-2.2.7
  3. /usr/local/php/bin/phpize
  4. ./configure --with-php-config=/usr/local/php/bin/php-config
  5. make && make install
  6. cd ../

按照我的环境,编译出来的memcache.so自动生成在/usr/local/php/lib/php/extensions/no-debug-non-zts-20121212/ 目录下,如果你的环境不一样,你得根据自己情况修改你的php.ini了。

接着要做的工作就是让php加载这个扩展,编辑你的php.ini,在适当位置(通常是最后,也可以是独立的一个ini文件)加入如下行:

  1. extension=memcache.so

然后重启php或者apache,运行一个phpinfo()来确认一下,正常的话你应该可以看到这个了:memcache

php-memcache的简单使用举例:

  1. <?php
  2. $memcache = new Memcache;
  3. $memcache->connect(‘127.0.0.1‘,‘11211‘);
  4. $memcache->setCompressThreshold(20000, 0.2);    // 设置压缩
  5. echo $memcache->getVersion();                   // 输出memcached版本
  6. $test = array(1,2,3,4,5,‘abcde‘);               //生成一个数组
  7. if($memcache->get(‘test‘)){
  8. print_r($memcache->get(‘test‘));        //获取数据
  9. echo "\n";
  10. echo ‘cached‘;
  11. echo "\n";
  12. }else{
  13. $memcache->set(‘test‘,$test,0,30);      //写入数据
  14. echo ‘no cache‘;
  15. echo "\n";
  16. }
  17. ?>

php中memcached扩展组件的安装(LNMP一键安装包):

最新版ibmemcached-1.0.17.tar.gz可能会报错error:
‘HAVE_MEMCACHED_BINARY’ was not declared in this scope

用libmemcached-1.0.16.tar.gz没问题

安装如下:

  1. wget https://launchpad.net/libmemcached/1.0/1.0.16/+download/libmemcached-1.0.16.tar.gz
  2. wget http://pecl.php.net/get/memcached-2.1.0.tgz
  3. tar xzf libmemcached-1.0.16.tar.gz
  4. cd libmemcached-1.0.16
  5. ./configure --with-memcached=/usr/local/memcached
  6. make && make install
  7. cd ..
  8. tar xzf memcached-2.1.0.tgz
  9. cd memcached-2.1.0
  10. /usr/local/php/bin/phpize
  11. ./configure --with-php-config=/usr/local/php/bin/php-config
  12. make && make install

按照我的环境,编译出来的memcached.so自动生成在 /usr/local/php/lib/php/extensions/no-debug-non-zts-20121212/ 目录下,如果你的环境不一样,你得根据自己情况修改你的php.ini了。

接着要做的工作就是让php加载这个扩展,编辑你的php.ini,在适当位置(通常是最后,也可以是独立的一个ini文件)加入如下行:

  1. extension=memcached.so

然后重启php或者apache,运行一个phpinfo()来确认一下,正常的话你应该可以看到这个了:memcached

总结:

其实很简单,memcache是php的一个扩展,用于php管理memcached(服务端),php-memcache.dll。

如果安装了memcached(服务端)不安装扩展,那么php无法操控memcached,但是命令行使用起来没有问题

如果安装了PHP memcache客户端(php memcache和php memcached)。但是没有安装memcached(服务端)服务,那么这个就无法使用

只有同时安装了memcached(服务端)和PHP memcache客户端扩展才可以提高动态网站性能

转自:点击打开链接

原文地址:https://www.cnblogs.com/jpfss/p/9444320.html

时间: 2024-10-08 21:20:08

memcache和memcached区别的相关文章

memcache和memcached的区别

关于PHP扩展memcache和memcached的区别 Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的速度.Memcached基于一个存储键/值对的hashmap.其守护进程(daemon )是用C写的,但是客户端可以用任何语言来编写,并通过memcached协议与守护进程通信. PHP的客户端目前常用的有两个,一个是memcache,另一个是memcached,两

php的memcache和memcached扩展区别

老生长谈的问题了.我这里就整理一下. memcache的文档在:http://pecl.php.net/package/memcache memcached的文档在:http://pecl.php.net/package/memcached 首先看下时间,memcache最早是在2004年2月开发的,最后更新是在2013年4月,而memcached最早是在2009年1月开发的,最后更新是在2014年1月更新的.所以memcache的历史比memcached早. 在安装memcache扩展的时候并

memcache与memcached的区别

其实到底说成什么无所谓,只要你真正理解和知道使用就可以了!但是介于有和我一样学习时遇到的这个疑惑,在此分享下其中的缘由: Memcache是一个软件 Memcache是一个自由和开放源代码.高性能.分配的内存对象缓存系统.用于加速动态web应用程序,减轻数据库负载. 它可以应对任意多个连接,使用非阻塞的网络IO.由于它的工作机制是在内存中开辟一块空间,然后建立一个HashTable,Memcache这个软件项目一般叫Memcache,但项目的主程序文件叫memcached.exe,是靠服务端的这

memcache memcached 区别

1.目前大多数php环境里使用的都是不带d的memcache版本,这个版本出的比较早,是一个原生版本,完全在php框架内开发的.与之对应的带d的memcached是建立在libmemcached的基础上,所以相对来说,memcached版本的功能更全一些. memcache:http://cn2.php.net/manual/en/book.memcache.php memcached:http://cn2.php.net/manual/en/book.memcached.php 2.Memca

Memcache与Memcached介绍及安装配置

Memcache学习总结1-Memcache与Memcached介绍及安装配置 也许大家一看到Memcache和Memcached会有点晕,这两者有什么关系又有什么区别呢,下面先给大家说下Memcached,Memcached是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的速度. 想必大家也听说过Memcached,就是一个缓存系统,我们可以把一些经常要查询的数据放到缓存中,避免每次要使用

redis 缓存技术与memcache的最大区别

1 什么是redis redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合)和zset(有序集合).这些数据类型都支持push/pop.add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的.在此基础上,redis支持各种不同方式的排序.与memcached一样,为了保证效率,数据都是缓存在内存中.区别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写

探究php的memcache和memcached扩展读写数组数据不相兼容原因

最近公司许多团队进行升级php7,目前支持php7读取mc的扩展只有memcached. 但是公司许多项目都会共用一个mc集群来存取用户session数据,存的时候是登陆时用memcache扩展以array的形式写进去,读的时候自然是用memcache扩展以array的形式读出来. 但是现在只能使用memcached进行读取.但是据我所知两者读取array形式的数据是互不兼容的,因此想探究一下究竟是为什么. 验证memcache扩展和memcached扩展读写数组数据是否不相兼容 测试脚本: <

php扩展memcache和memcached安装

首先简单介绍下memcache和memcached的区别 两个不同版本的php的memcached的客户端new memcache是pecl扩展库版本new memcached是libmemcached版本 memcache最早是在2004年2月开发的,最后更新是在2013年4月,而memcached最早是在2009年1月开发的,最后更新是在2014年1月更新的.所以memcache的历史比memcached早. 在安装memcache扩展的时候并不要求安装其他东东,但是在安装memcached

Memcache和memcached

引用自:http://kimi.it/259.html Memcache是danga.com的一个项目,最早是为 LiveJournal 服务的,目前全世界不少人使用这个缓存项目来构建自己大负载的网站,来分担数据库的压力.它可以应对任意多个连接,使用非阻塞的网络IO.由于它的工作机制是在内存中开辟一块空间,然后建立一个HashTable,Memcached自管理这些HashTable.Memcache官方网站:http://www.danga.com/memcached,更多详细的信息可以来这里