Memcache分布式缓冲服务

一、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

推荐阅读更多精彩内容

  • 【转】缓存在分布式系统中的应用 缓存在分布式系统中的应用 摘要 缓存是分布式系统中的重要组件,主要解决高并发,大数...
    武汉苏乞儿阅读 569评论 0 10
  • 转载地址:http://gnucto.blog.51cto.com/3391516/998509 Redis与Me...
    Ddaidai阅读 20,474评论 0 82
  • (一):基础概念 memcache是什么? Memcache 是一个高性能的分布式内存对象缓存系统,用于动态Web...
    楚江云阅读 752评论 0 5
  • 片段6《刻意联系》 P42 R: 有目的的联系:走出你的舒适去,但要以专注的方式制订明确的目标,为达到那些目标制订...
    时光书屋阅读 43评论 0 0