Ubuntu 9.04 下 Memcache 的简单应用

本文介绍了Memcached的原理及优势,并提供了详细的安装步骤,包括Libevent和Memcached本身的安装配置,以及如何安装PHP的Memcache扩展。最后,通过一个简单的PHP示例展示了如何使用Memcached进行数据缓存。
摘要由CSDN通过智能技术生成


一,相关概念:

 

memcached是什么?
memcached是由Danga Interactive开发的,高性能的,分布式的内存对象缓存系统,用于在动态应用中减少数据库负载,提升访问速度。

 

memcached能缓存什么?
通过在内存里维护一个统一的巨大的hash表,Memcached能够用来存储各种格式的数据,包括图像、视频、文件以及数据库检索的结果等。

 

memcached快么?
非常快。memcached使用了libevent(如果可以的话,在linux下使用epoll)来均衡任何数量的打开链接,使用非阻塞的网络 I/O,对内部对象实现引用计数(因此,针对多样的客户端,对象可以处在多样的状态), 使用自己的页块分配器和哈希表,因此虚拟内存不会产生碎片并且虚拟内存分配的时间复杂度可以保证为O(1).

Danga Interactive为提升Danga Interactive的速度研发了memcached。目前,LiveJournal.com每天已经在向一百万用户提供多达两千万次的页面访问。而这些,是由一个由web服务器和数据库服务器组成的集群完成的。memcached几乎完全放弃了任何数据都从数据库读取的方式,同时,它还缩短了用户查看页面的速度、更好的资源分配方式,以及memcache失效时对数据库的访问速度。

 

memcached的特点
memcached的缓存是一种分布式的,可以让不同主机上的多个用户同时访问, 因此解决了共享内存只能单机应用的局限,更不会出现使用数据库做类似事情的时候,磁盘开销和阻塞的发生。

 

以上信息来源:http://developer.51cto.com/art/200902/108601.htm

Memcached 官方介绍:http://www.danga.com/memcached/

 

二,安装Memcached

 

下载 Memcached:http://www.danga.com/memcached/download.bml
下载 Libevent:http://www.monkey.org/~provos/libevent/

 

1,安装Libevent
# tar -zxvf libevent-1.4.12-stable.tar.gz
# cd libevent-1.4.12-stable
# ./configure --prefix=/Data/apps/libevent
# make
# make install

 

2,Memcached安装
# ./configure --prefix=/Data/apps/memcached
# ./configure --prefix=/Data/apps/memcached
# make
# make install

 

3,链接 libevent 到 /usr/lib
#ls -s /Data/apps/libevent/lib/libevent-1.4.so.2 /usr/lib/

 

三,安装php的Memcache扩展

 

下载 php memcache 扩展:http://pecl.php.net/package/memcache

 

# tar -vxzf memcache-3.0.4.tar
# cd memcache-3.0.4
# /Data/apps/php/bin/phpize
# ./configure --enable-memcache --with-php-config=/Data/apps/php/bin/php-config
# make
# make install

 

提示信息如下:
Installing shared extensions:/Data/apps/php/lib/php/extensions/no-debug-non-zts-20060613/
复制冒号后面的部分,接下来要用到

 

***关于phpize***
phpize 命令是用来准备 PHP 扩展库的编译环境的,如果系统没有该命令,可用如下命令安装:
# apt-get install autoconf
或者
# yum install php-devel

 

编辑php.ini,加入如下语句:
extension_dir = "/Data/apps/php/lib/php/extensions/no-debug-non-zts-20060613/"
extension=memcache.so

 

重启Apache.

 

四,使用Memcache

 

启动memcached进程


#/Data/apps/memcached/bin/memcached -d -m 10 -u root -l 127.0.0.1 -p 11211

 

-d选项是启动一个守护进程,
-m是分配给Memcache使用的内存数量,单位是MB,
-u是运行Memcache的用户,
-l是监听的服务器IP地址,
-p是设置Memcache监听的端口,默认是11211,
-c选项是最大运行的并发连接数,默认是1024,
-P是设置保存Memcache的pid文件

 

测试代码:

 

启动和停止memcached, stop似乎无效
#/Data/apps/memcached/bin/memcached -d start
#/Data/apps/memcached/bin/memcached -d stop

 

结束 memcached进程
#pkill memcached

 

五,结束语

 

Memcache 无非是将频繁访问的数据缓存到内存中,从而达到加快访问速度和减轻数据库压力的效果。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值