一,相关概念:
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 无非是将频繁访问的数据缓存到内存中,从而达到加快访问速度和减轻数据库压力的效果。