memcache与memcached的区别与安装

简介:

Memcache是什么? 
Memcache是一个自由和开放源代码、高性能、分配的内存对象缓存系统。用于加速动态web应用程序,减轻数据库负载。 
它可以应对任意多个连接,使用非阻塞的网络IO。由于它的工作机制是在内存中开辟一块空间,然后建立一个HashTable,Memcached自管理这些HashTable。
Memcached是简单而强大的。它简单的设计促进迅速部署,易于发展所面临的问题,解决了很多大型数据缓存。它的API可供最流行的语言。
Memcache的知名用户有:LiveJournal、Wikipedia、Flickr、Bebo、Twitter、Typepad、Yellowbot、Youtube 等。
Memcache官方网站:http://memcached.org/

Memcached又是什么?
Memcache是该系统的项目名称,Memcached是该系统的主程序文件,以守护程序方式运行于一个或多个服务器中,随时接受客户端的连接操作,使用共享内存存取数据。

那PHP中的Memcache是什么? 
php中的所讲的memcache是用于连接Memecached的客户端组件。

Memcache如何安装?

Memcached 服务端安装:(源码包官方网站下载)

系统命令
  1. tar xvf memcached-1.2.6.tar.gz   
  2. cd memcached-1.2.6   
  3. ./configure --prefix=/usr/local/memcached   
  4. make    
  5. make install  

然后就可以启动memcached的守护进程了:

系统命令
  1. /usr/local/memcached/bin/memcached -p 11211 -l 127.0.0.1 -d -u nobody -P /var/run/memcached.pid -m 64M -c 1024  

几个参数的解释:

-p memcached监听的TCP端口
-l 监听的ip地址,127.0.0.1是本机,当然也可以写上你的服务器IP,如:61.150.91.26,这是我服务器的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 xvf memcache-3.0.3.tgz   
  2. cd memcache-3.0.3   
  3. /usr/local/php5/bin/phpize   
  4. ./configure --with-php-config=/usr/local/php5/bin/php-config --enable-memcache   
  5. make   
  6. make install  

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

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

 extension=memcache.so

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

php-memcache的简单使用举例:

<?php  


 


$memcache = new Memcache;  


$memcache->connect('127.0.0.1','11211');  


$memcache->setCompressThreshold(20000, 0.2);   


echo $memcache->getVersion();                  


 


$test = array(1,2,3,4,5,'abcde');              


 


if($memcache->get('test')){  


        print_r($memcache->get('test'));      


        echo "\n";  


        echo 'cached';  


        echo "\n";  


}else{  


        $memcache->set('test',$test,0,30);     


        echo 'no cache';  


        echo "\n";  


}  


?> 


















本文转自leonardos51CTO博客,原文链接:http://blog.51cto.com/leomars/395417 ,如需转载请自行联系原作者

相关文章
|
6月前
|
存储 NoSQL Redis
11- Redis 和 Memcached 的区别有哪些?
Redis与Memcached的主要区别在于:Redis提供复杂数据结构和丰富的操作,而Memcached只支持简单字符串;Redis原生支持集群,Memcached不支持;Memcached数据无法持久化,重启会丢失,但Redis支持持久化并能在重启后恢复数据。
124 12
|
6月前
|
Linux Memcache
Linux - 安装memcached
Linux - 安装memcached
106 0
Linux - 安装memcached
|
4月前
|
存储 缓存 NoSQL
Redis问题之Redis与Memcached的主要区别是什么
Redis问题之Redis与Memcached的主要区别是什么
|
5月前
|
缓存 Java Spring
SpringBoot配置第三方专业缓存技术Memcached 下载 安装 整合测试 2024年5000字详解
SpringBoot配置第三方专业缓存技术Memcached 下载 安装 整合测试 2024年5000字详解
44 0
|
6月前
|
NoSQL Redis 数据库
【后端面经】【缓存】36|Redis 单线程:为什么 Redis 用单线程而 Memcached 用多线程?-- Memcache + Redis 多线程
【5月更文挑战第20天】Redis采用单线程模式以避免上下文切换和资源竞争,简化调试,且其性能瓶颈在于网络IO和内存,而非多线程。相比之下,Memcache使用多线程能更好地利用多核CPU,但伴随上下文切换和锁管理的开销。尽管Redis单线程性能不俗,6.0版本引入多线程以提升高并发下的IO处理能力。启用多线程后,Redis结合Reactor和epoll实现并发处理,提高系统性能。
73 0
|
12月前
|
Docker 容器
Docker下安装memcached
Docker下安装memcached
154 0
|
Shell C语言
脚本用源码来安装 memcached 服务器
脚本用源码来安装 memcached 服务器
51 1
|
存储 缓存 NoSQL
Memcached 和 Redis 的区别?
Memcached 和 Redis 的区别?
76 0
|
缓存 NoSQL Redis
Redis 和 Memcached 的区别
Redis和Memcached是两种常用的内存缓存系统,尽管它们都被用于提高应用程序的性能和扩展性,但它们在一些方面有所不同。
91 0
|
Java 程序员
【memcached】下载、安装、、出错一分钟全搞定
【memcached】下载、安装、、出错一分钟全搞定
199 0