linux下php5.4添加memcache扩展

1、Memcache简介
Memcache是danga.com的一个项目,最先是为 LiveJournal 服务的,目前全世界很多人使用这个缓存项目来构建本身大负载的网站,来分担数据库的压力。它能够应对任意多个链接,使用非阻塞的网络IO。因为它的工做机制是在内存中开辟一块空间,而后创建一个HashTable,Memcached管理这些HashTable,因此速度很是快。php

2、Memcache和memcached的区别前端

为何会有Memcache和memcached两种名称?其实Memcache是这个项目的名称,而memcached是它服务器端的主程序文件名。linux


3、何时使用Memcache和Memcache的使用环境算法

使用Memcache的网站通常流量都是比较大的,为了缓解数据库的压力,让Memcache做为一个缓存区域,把部分信息保存在内存中,在前端可以迅速的进行存取。那么通常的焦点就是集中在如何分担数据库压力和进行分布式,毕竟单台Memcache的内存容量的有限的。数据库

 

分布式应用:后端

Memcache原本支持分布式,咱们客户端稍加改造,更好的支持。咱们的key能够适当进行有规律的封装,好比以user为主的网站来讲,每一个用户都有User ID,那么能够按照固定的ID来进行提取和存取,好比1开头的用户保存在第一台Memcache服务器上,以2开头的用户的数据保存在第二胎Mecache服务器上,存取数据都先按照User ID来进行相应的转换和存取。
可是这个有缺点,就是须要对User ID进行判断,若是业务不一致,或者其余类型的应用,可能不是那么合适,那么能够根据本身的实际业务来进行考虑,或者去想更合适的方法。api

 

减小数据库压力:数组

全部的数据基本上都是保存在数据库当中的,每次频繁的存取数据库,致使数据库性能极具降低,没法同时服务更多的用户,好比MySQL,特别频繁的锁表,那么让Memcache来分担数据库的压力吧。咱们须要一种改动比较小,而且可以不会大规模改变前端的方式来进行改变目前的架构。缓存

 

我考虑的一种简单方法:
后端的数据库操做模块,把全部的Select操做提取出来(update/delete/insert无论),而后把对应的SQL进行相应的hash算法计算得出一个hash数据key(好比MD5或者SHA),而后把这个key去Memcache中查找数据,若是这个数据不存在,说明还没写入到缓存中,那么从数据库把数据提取出来,一个是数组类格式,而后把数据在set到Memcache中,key就是这个SQL的hash值,而后相应的设置一个失效时间,好比一个小时,那么一个小时中的数据都是从缓存中提取的,有效减小数据库的压力。缺点是数据不实时,当数据作了修改之后,没法实时到前端显示,而且还有可能对内存占用比较大,毕竟每次select出来的数据数量可能比较巨大,这个是须要考虑的因素。服务器

 

4、Memcache的服务器端和客户端安装(安装包见附件)

分为两个过程:memcache服务器端的安装和memcached客户端的安装。

所谓服务器端的安装就是在服务器(通常都是linux系统)上安装Memcache实现数据的存储。

所谓客户端的安装就是指php(或者其余程序,Memcache还有其余不错的api接口提供)去使用服务器端的Memcache提供的函数,须要php添加扩展。这里只提供客户端的安装:
[root@showip opt]# tar zxf memcache-2.2.7.tgz
[root@showip opt]# cd memcache-2.2.7
[root@showip memcache-2.2.7]# /usr/local/php/bin/phpize
[root@showip memcache-2.2.7]# ./configure  --with-php-config=/usr/local/php/bin/php-config
[root@showip memcache-2.2.7]# make && make install
[root@showip memcache-2.2.7]# echo "extension = memcache.so" > /usr/local/php/etc/php.ini

5、重启php测试

 

wKioL1S2BT7QpqHLAAFFGhRvfvA574.jpg

wKiom1S2BHSTR2ZqAAIbqH5jfOA850.jpg

相关文章
相关标签/搜索