Memcache 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载。它经过在内存中缓存数据和对象来减小读取数据库的次数,从而提升了网站访问的速度。 MemCaChe是一个存储键值对的HashMap,在内存中对任意的数据(好比字符串、对象等)所使用的key-value存储,数据能够来自数据库调用、API调用,或者页面渲染的结果。MemCache设计理念就是小而强大,它简单的设计促进了快速部署、易于开发并解决面对大规模的数据缓存的许多难题,而所开放的API使得MemCache能用于Java、C/C++/C#、Perl、Python、PHP、Ruby等大部分流行的程序语言。数据库是是将数据存放在硬盘中,所以读取的速度会相对于将数据存储在内存中的memcache来讲慢。javascript
传统的Web应用都将数据保存到RDBMS中,应用服务器从RDBMS中读取数据、处理数据并在浏览器中显示。可是随着数据量增大、访问的集中、就会出现RDBMS的负担加剧、数据库响应变慢、致使整个系统响应延迟增长。而memcached就是为了解决这个问题而出现的,memcached是一款高性能的分布式内存缓存服务器,通常目的是为了经过缓存数据库的查询命中减小数据库压力、提升应用响应速度、提升可扩展性。php
tar zxf memcache-2.2.5.tgzhtml
vim ~/.bash_profilejava
PATH=$PATH:$HOME/bin:/usr/local/lnmp/mysql/bin:/usr/local/lnmp/php/bin
source ~/.bash_profile ##刷新环境变量mysql
phpize是用来扩展php扩展模块的,经过phpize能够创建php的外挂模块,好比你想在原来编译好的php中加入memcached或者ImageMagick等扩展模块,可使用phpize。nginx
phpize工具是在php安装目录下,基于这点phpize对应了当时的php环境,因此是要根据该php的配置状况生成对应的configure文件,创建一个configure文件。必须在一个目录下去运行phpize,那么phpize就知道你的环境是哪一个目录,而且configure文件创建在该目录下。
web
cd memcache-2.2.5
phpize
Configuring for:
PHP Api Version: 20131106
Zend Module Api No: 20131226
Zend Extension Api No: 220131226
./configure ##源码编译,已经安装好了php,咱们就不用再指定新的php扩展模块路径
make && make installsql
cd /usr/local/lnmp/php/etc/
vim php.ini
873 extension=memcache.so # 将873行memcache模块的注释打开
/etc/init.d/php-fpm reload
Reload service php-fpm done
php -m ##查看php模块
php -m | grep memcache ##过滤memcache模块,发现已经有了这个模块
memcache数据库
php -m | grep mysql ##同时支持mysql
mysql
mysqli
mysqlnd
pdo_mysqlvim
yum install -y memcahce
/etc/init.d/memcached start
netstat -antlp ##查看端口信息 memcache的监听端口是(11211端口) 若是有端口信息说明工具开启成功
注意:上面显示的端口信息是,检测全部11211端口的全部主机,若是想只监控本机则进行如下修改(注意,这里只作介绍,实际只监听本机是不合理的,此步骤不用作)
vim /etc/sysconfig/memcached
PORT="11211"
USER="memcached"
MAXCONN="1024"
CACHESIZE="64"
OPTIONS="-l 127.0.0.1" ##修改此处,将信息修改成本机的回环接口的IP地址:127.0.0.1
/etc/init.d/memcached restart
Stopping memcached: [ OK ]
Starting memcached: [ OK ]
netstat -atnlp
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
tcp 0 0 127.0.0.1:11211 0.0.0.0:* LISTEN 3855/memcached ##显示只监听本机成功
tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 1251/nginx
tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN 910/sshd
tcp 0 0 127.0.0.1:25 0.0.0.0:* LISTEN 986/master
tcp 0 0 127.0.0.1:9000 0.0.0.0:* LISTEN 3807/php-fpm
tcp 0 0 :::22 :::* LISTEN 910/sshd
tcp 0 0 ::1:25 :::* LISTEN 986/master
tcp 0 0 :::3306 :::* LISTEN 1210/mysqld
cd memcache-2.2.5
cp memcache.php example.php /usr/local/lnmp/nginx/html/ ##用nginx当作web服务器,将memcache的测试页面放到相应的发布目录下面
cd /usr/local/lnmp/nginx/html/
vim memcache.php
22 define('ADMIN_USERNAME','memcache'); ##用户为memcache
23 define('ADMIN_PASSWORD','westos'); ##设置密码为westos // Admin Password
28 $MEMCACHE_SERVERS[] = '172.25.79.1:11211';
29 #$MEMCACHE_SERVERS[] = 'mymemcache-server2:11211';
yum install -y telnet ##为何须要telnet?telnet就是查看某个端口是否可访问。有时候常常要用的端口是 8080,那么你能够启动服务器,用telnet 去查看这个端口是否可用。
telnet localhost 11211 ##
浏览器输入:172.25.254.1:memcache.php
输入设置的帐户和密码
而后从新打开一个浏览器页面,输入172.25.254.1:example.php ,不断刷新
当访问屡次example.php后,查看命中状况会不断提升,最后将会达到百分之百。 以下图:
ab -c 10 -n 5000 http://172.25.254.1/index.php ## ab是性能测试的一个工具,可用于web的并发测试
ab经常使用参数的介绍:
-n :总共的请求执行数,缺省是1;
-c: 并发数,缺省是1;
-t:测试所进行的总时间,秒为单位,缺省50000s
-p:POST时的数据文件
-w: 以HTML表的格式输出结果
注意:若是没有ab这个命令,则能够安装下包:yum install httpd-tools-2.2.15-29.el6_4.x86_64 -y
能够看到所用时间为5s左右,出错个数为529个:
ab -c 10 -n 5000 http://172.25.254.1/example.php
能够看到所用时间为2s左右,出错个数为0个,速度提升了,错误率大大下降