Linux中PHP的Memcache扩展安装

  最开始我先说一句,以下很多的安装路径视每台机器的情况而定,文中的路径是我电脑的路径,大家如果跟我的不一样可以使用find来查找路径。

PHP的Memcache扩展安装分为三个步骤:

第一个步骤是:安装libevent

第二个步骤是:安装Memcached

第三个步骤是:安装PHP的Memcache模块

 

下载软件

所需软件(去以下网址中下载最新版本)

libevent-2.0.19-stable.tar.gz (http://libevent.org/)

memcache-3.0.6.tgz (http://pecl.php.net/package/memcache)

memcached-1.4.13.tar.gz (http://www.danga.com/memcached/)

将文件上传到服务器中,我存放的位置是/usr/local/src/

 

安装libevent

libevent是一个事件触发的网络库,适用于windows、linux、bsd等多种平台,内部使用select、epoll、kqueue等系统调用管理事件机制。著名分布式缓存软件memcached也是libevent based,而且libevent在使用上可以做到跨平台,而且根据libevent官方网站上公布的数据统计,似乎也有着非凡的性能。因此很多的服务器可能已经安装了libevent,所以先测试libevent是否已经安装:

# ls -al /usr/lib | grep libevent

 

lrwxrwxrwx.   1 root root       21 7?. 23 01:04 libevent-1.4.so.2 -> libevent-1.4.so.2.1.3

-rwxr-xr-x.   1 root root   108948 6?. 22 19:55 libevent-1.4.so.2.1.3

-rw-r–r–.   1 root root   133014 6?. 22 19:55 libevent.a

lrwxrwxrwx.   1 root root       26 7?. 23 01:04 libevent_core-1.4.so.2 -> libevent_core-1.4.so.2.1.3

-rwxr-xr-x.   1 root root    37080 6?. 22 19:55 libevent_core-1.4.so.2.1.3

-rw-r–r–.   1 root root    47248 6?. 22 19:55 libevent_core.a

lrwxrwxrwx.   1 root root       26 7?. 23 01:04 libevent_core.so -> libevent_core-1.4.so.2.1.3

lrwxrwxrwx.   1 root root       27 7?. 23 01:04 libevent_extra-1.4.so.2 -> libevent_extra-1.4.so.2.1.3

-rwxr-xr-x.   1 root root    84228 6?. 22 19:55 libevent_extra-1.4.so.2.1.3

-rw-r–r–.   1 root root   103130 6?. 22 19:55 libevent_extra.a

lrwxrwxrwx.   1 root root       27 7?. 23 01:04 libevent_extra.so -> libevent_extra-1.4.so.2.1.3

lrwxrwxrwx.   1 root root       21 7?. 23 01:04 libevent.so -> libevent-1.4.so.2.1.3

 

如果没有以上的内容,那么你就要安装libevent了,先解压缩libevent-2.0.19-stable.tar.gz,再编译安装:

# cd /usr/local/src

# tar zxvf libevent-2.0.19-stable.tar.gz

# cd libevent-2.0.19-stable

# ./configure –prefix=/usr/local/libevent

# make && make install

安装好可以再用上面的方式检查一下。

 

安装memcached

解压缩 memcached-1.4.13.tar.gz, 编译安装

# cd /usr/local/src

# tar zxvf memcached-1.4.13.tar.gz

# cd cd memcached-1.4.13

# ./configure –prefix=/usr/local/memchached –with-libevent=/usr/local/libevent

# make && make install

 

启动memcached

# /usr/local/memchached/bin/memcached -d start -m 128 -p 11211 -u root

附:

以下是memcache启动、关闭参数:

-p 指定端口号(默认11211)

-m 指定最大使用内存大小(默认64MB)

-t 线程数(默认4)

-l 连接的IP地址, 默认是本机

-d start 启动memcached服务

-d restart 重启memcached服务

-d stop|shutdown 关闭正在运行的memcached服务

-m 最大内存使用,单位MB。默认64MB

-M 内存耗尽时返回错误,而不是删除项

-c 最大同时连接数,默认是1024

-f 块大小增长因子,默认是1.25

-n 最小分配空间,key+value+flags默认是48

值得注意的是重启memcache:

先找到memcache的pid:

# ps -ef|grep memcache

再kill掉进程,再执行启动相关参数的memcache,可以重新设置memcache的占用的内存。

 

安装php的memcache模块

# cd /usr/local/src

# tar zxvf memcache-3.0.6.tgz# cd memcache-3.0.6# /usr/local/php/bin/phpize# ./configure –enable-memcache –with-php-config=/usr/local/php/bin/php-config –with-zlib-dir# make && make install

安装完后会有类似这样的提示:

Installing shared extensions: /usr/local/php/lib/php/extensions/no-debug-non-zts-20090626/

把这个路径记住,然后修改php.ini

添加一行

extension=/usr/local/php/lib/php/extensions/no-debug-non-zts-20090626/memcache.so

这时候就大功告成了!

 

检查memcache是否正常工作

部署好Memcached之后,需要对Memcached的使用情况进行跟踪:监控Memcached的状态信息、内存使用情况、hit/miss的值。通过对Memcached的监控不仅能立刻了解Memcached出现问题,还能够利用状态信息来分析业务数据的增长并为未来的容量规划提供依据。本文推荐使用memcache.php作为memcache监控来检查memcache是否正常工作以及跟踪使用情况:

到以下这个网址下载这个工具:

http://book.51cto.com/art/201202/314917.htm

将这个文件放到localhost下,并修改以下这部分的内容:

define(‘ADMIN_USERNAME’,’memcache’);  // Admin Username

define(‘ADMIN_PASSWORD’,’password’);   // Admin Password

define(‘DATE_FORMAT’,’Y/m/d H:i:s’);

define(‘GRAPH_SIZE’,200);

define(‘MAX_ITEM_DUMP’,50);

 

$MEMCACHE_SERVERS[] = ‘mymemcache-server1:11211’; // add more as an array

$MEMCACHE_SERVERS[] = ‘mymemcache-server2:11211’; // add more as an array

 

改成:

define(‘ADMIN_USERNAME’,’admin’);       // 我的管理用户名:admin,你可以随便设置

define(‘ADMIN_PASSWORD’,’123456′);      // 我的管理员密码:123456,你可以随便设置

define(‘DATE_FORMAT’,’Y/m/d H:i:s’);

define(‘GRAPH_SIZE’,200);

define(‘MAX_ITEM_DUMP’,50);

 

$MEMCACHE_SERVERS[] = ‘localhost:11211’; // 将前面的mymemcache-server1改成localhost

$MEMCACHE_SERVERS[] = ‘mymemcache-server2:11211’; // 这一行可以删除掉

 

最后打开http//:localhost/memcache.php,查看是否有下图的内容:

 

 

 

 

 

如果没有这内容,重启一下php或者服务器试试,重启之后一般都可以解决了。

机械硬盘、固态硬盘、内存虚拟硬盘——Memcache介绍(Tony原创)

近几年来,计算机的CPU、内存和显卡等主要配件的性能都提升得很快,而与之相对应的磁盘系统性能正越来越严重地成为整个电脑系统性能提升的瓶颈。

首先,我们看看机械硬盘、固态硬盘和内存虚拟硬盘的读写速度比较:

1.机械硬盘测试

机械硬盘的读写速度

测试使用的机械硬盘属性如下:

产品西数 WDC WD5000AAKX-001CA0 (蓝盘)

大小500 GB

转速7200 /

缓存16 MB

硬盘已使用共 117 次,累计 571 小时

固件15.01H15

接口SATA III

数据传输率600 MB/

特征S.M.A.R.T,  48-bit LBA,  NCQ

从测试的结果可以看出该机械硬盘的最快读写速度大概在110~120MB/秒左右。

2.固态硬盘测试

固态硬盘的读写速度

固态硬盘最大的特点就是读写速度快。采用闪存作为存储介质,读取速度相对机械硬盘更快。固态硬盘不用磁头,寻道时间几乎为0,持续写入的速度非常惊人。 

固态硬盘使用的是DELL XPS13D-2701 SSD固态硬盘。

可以看出固态硬盘的最快读写速度大概在300~500MB/秒左右。

3.内存虚拟硬盘测试

内存虚拟硬盘的读写速度

内存虚拟硬盘(ramdisk)是指通过软件技术,将物理内存进行分割,将一部分内存通过虚拟技术转变为硬盘以较大幅度提升计算机数据读取速度和保护硬盘。

测试使用的内存属性如下:

金士顿 DDR3 1333MHz 2GB

制造日期2011 年 07 

型号7F98 99P5471-002.A01LF

序列号:35D2268E

可以看出内存虚拟硬盘的最快读写速度在3000MB/秒以上。

4.Memcache介绍

从以上测试的结果可以看出,现在内存的读写速度比固态硬盘的读写速度快三四十倍,比如今堪称神速的固态硬盘要快10倍。现在我们很多的网站都会将数据存储在数据库中,虽然数据库有很多的优点,但数据库也有致命的缺点,例如:数据库的并发量是有限制的,如果有很多的用户访问,服务器就会瘫痪;数据库是存储在硬盘中的,数据的读写速度太慢会造成用户体验的降低。如果一个网站没有解决这两个问题,很可能造成大量的用户流失,我曾经的http://www.xiahuimingcheng.com就是因为这样的问题造成了很多用户不喜欢访问。

现在,我给大家介绍一个能减轻数据库负担的内存对象缓存系统——Memcache,以下是百度百科的解释:Memcache是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨大的hash表,它能够用来存储各种格式的数据,包括图像、视频、文件以及数据库检索的结果等。简单的说就是将数据调用到内存中,然后从内存中读取,从而大大提高读取速度。 

通过上面对硬盘和内存的存储介质的分析,不难推出Memcache的读写速度有多快。本人亲自测试过,原来使用handle socket写入数据库需要91秒的大量数据,改成使用Memcache之后,只需要8秒钟。在未来,还会详细对比MemcachettServerHandle Socket以及文件系统的读写速度,敬请关注!