一、MemCache简介
MemCache是一个自由、源码开放、高性能、分布式的分布式内存对象缓存系统,用于动态Web应用以减轻数据库的负载。它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高了网站访问的速度。MemCaChe是一个存储键值对的HashMap,在内存中对任意的数据(比如字符串、对象等)所使用的key-value存储,数据可以来自数据库调用、API调用,或者页面渲染的结果。MemCache设计理念就是小而强大,它简单的设计促进了快速部署、易于开发并解决面对大规模的数据缓存的许多难题,而所开放的API使得MemCache能用于Java、C/C++/C#、Perl、Python、PHP、Ruby等大部分流行的程序语言。
二、Memcache工作流程
1、检查客户端的请求数据是否在memcached中,如果有,直接把请求数据返回,不再对数据库进行任何操作,路径操作为。
2、如果请求的数据不在memcached中,就去查数据库,把从数据库中获取的数据返回给客户端,同时把数据缓存一份到memcached中(memcached客户端不负责,需要程序明确实现),路径操作为。
3、每次更新数据库的同时更新memcached中的数据,保证一致性。
4、当分配给memcached内存空间用完之后,会使用LRU(Least Recently Used,最近最少使用)策略加上到期失效策略,失效数据首先被替换,然后再替换掉最近未使用的数据。
三、Memcache特征:
协议简单:
基于文本行的协议,直接通过telnet在memcache服务器上了进行存取数据操作。
基于libevent事件处理:
Libevent是一套基于用C开发的程序库,他将BSD系统的kqueue,Linux系统的epoll等时间处理
功能封装成一个接口,与传统的select相比,提高了性能。
内置的内存管理方式:
所有数据都保存在内存中,存取数据比硬盘快,当内存满后,通过LRU算法自动删除不使用的缓
存,但没有考虑数据的容灾问题,重启服务,所有数据会丢失。
分布式:
各个memcached服务器之间互不通信,各自独立存取数据,不共享任何信息。服务器并不具有
分布式功能,分布式部署取决于memcache客户端。
四、环境部署(Centos 7.2)
Nginx+PHP+MemCache+Mysql环境
1.安装Memcached服务依赖库libevent
yum -y install libevent libevent-devel gcc gcc-c++
2.安装Memcache
[root@Memcached ~] tar -zxvf memcached-1.5.3.tar.gz
[root@Memcahced ~] cd memcached-1.5.3
[root@localhost memcached-1.5.3]# ./configure --prefix=/usr/local/memcached --with-libevent=/usr/lib64/
[root@localhost Memcached-1.5.3]#make && make -j 4 install #编译安装Memcached服务
[root@localhost Memcached-1.5.3]#cd /root
[root@Memcached ~]#vim .bash_profile
MEMCACHED_HOME=/usr/local/memcached
LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$MEMCACHED_HOME/lib
[root@Memcached ~]#source .bash_profile
[root@Memcached ~]#./memcached -d -u root -P /usr/local/memcached/memcached.pid #启动Memcache并生成pid文件
启动参数说明:
-d 选项是启动一个守护进程。
-m 分配给Memcache使用的内存数量,单位是MB,默认64MB。
-l 监听的IP地址。(默认:INADDR_ANY,所有地址)
-p 设置Memcache的TCP监听的端口,最好是1024以上的端口。
-u 运行Memcache的用户,如果当前为root的话,需要使用此参数指定用户。
-c 选项是最大运行的并发连接数,默认是1024。
-P 设置保存Memcache的pid文件。
-M内存耗尽时返回错误,而不是删除项
-f块大小增长因子,默认是1.25
-n最小分配空间,key+value+flags默认是48
-h显示帮助
[root@Memcached ~]#netstat -lntp |grep memcached
tcp 0 0 0.0.0.0:11211 0.0.0.0:* LISTEN 14399/./memcached
tcp6 0 0 :::11211 :::* LISTEN 14399/./memcached
3.安装Memcahce客户端,PHP服务上安装
#/usr/local/php5.6/bin/pecl install memcache
提示:
Build process completed successfully
Installing '/usr/local/php5.6/lib/php/extensions/no-debug-zts-20131226/memcache.so'
install ok: channel://pecl.php.net/memcache-2.2.7
configuration option "php_ini" is not set to php.ini location
You should add "extension=memcache.so" to php.ini
4.修改php.ini配置文件
# vim /etc/php.ini
添加 extension='/usr/local/php5.6/lib/php/extensions/no-debug-zts-20131226/memcache.so“
# systemctl restart php-fpm
5.Memcache实现session共享
配置/etc/php.ini文件
session.save_handler = memcache
session.save_path = "tcp://ip:11211,tcp://ip:11211" #多个memcache服务器用“,”隔开。
6.Memcache做mysql缓存
7.Memcache日常管理
treeNMS 基于Java的memcache管理平台 www.treesoft.cn/dms.html