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 ,如需转载请自行联系原作者

相关文章
|
SQL 分布式计算 关系型数据库
Hive 数仓迁移 JindoFS/OSS 数据湖最佳实践
Hive 数仓是大多数迁移客户都会遇到的场景。在迁移过程中,不建议同时在新集群进行业务升级(比如从 Hive on MR 迁移到 Hive on Tez 或 Spark SQL等),这些业务升级可以在迁移完成后进行。1. 元数据同步Hive 元数据是对于 Hive 表来说非常关键,除了表结构信息,里面还记录着 Hive 表与底层文件系统的关联关系,许多上层服务都依赖 Hive 元数据提供服务。a.
1125 0
|
小程序 前端开发 应用服务中间件
nginx,uwsgi get方法请求参数过长怎么办
nginx,uwsgi get方法请求参数过长怎么办
380 0
|
机器学习/深度学习 传感器 监控
智能汽车中人工智能算法应用及其安全综述
智能汽车中人工智能算法应用及其安全综述
智能汽车中人工智能算法应用及其安全综述
|
机器学习/深度学习 人工智能 搜索推荐
TextRCNN、TextCNN、RNN…你都掌握了吗?一文总结文本分类必备经典模型(二)
TextRCNN、TextCNN、RNN…你都掌握了吗?一文总结文本分类必备经典模型(一)
1075 0
|
Web App开发 网络协议 网络架构
|
Ubuntu Linux pouch
Docker容器管理工具
文章介绍了Docker容器管理工具,以及早期使用的LXC容器管理工具,包括它们的安装、使用和相关技术特点。
506 10
Docker容器管理工具
|
算法 计算机视觉
图像处理之错切变换
图像处理之错切变换
479 1
|
消息中间件 缓存 负载均衡
5种限流算法,7种限流方式,挡住突发流量?(三)
5种限流算法,7种限流方式,挡住突发流量?
1052 0
|
存储 算法 C语言
数据结构学习笔记——串的基本知识以及顺序存储结构实现串
数据结构学习笔记——串的基本知识以及顺序存储结构实现串
数据结构学习笔记——串的基本知识以及顺序存储结构实现串
|
存储 Android开发 网络协议
浅谈OkHttp
本来想看看源码提高下自己的水平,以前也有看过某些框架的源码,但是基本都是只看某段,这次打算好好的研究一遍。本来是想拿RecyclerView的源码来开刀的,但是好像RecyclerView的代码没那么容易看懂,而且变量还贼多,还大量用了设计模式,讲真,看起来还真觉得挺费劲的。
1462 0

热门文章

最新文章

下一篇
开通oss服务