您现在的位置是:主页 > 数据库技术 > 数据库技术

Linux系统Memcached服务该如何理解

IDCBT2021-12-29服务器技术人已围观

简介本篇文章为大家展示了Linux系统Memcached服务该如何理解,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。 Linux系统Memcached服务 什么是M

本篇文章为大家展示了Linux系统Memcached服务该如何理解,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

Linux系统Memcached服务
什么是Memcached?  

Memcached是一个免费开源的、高性能的、具有分布式内存对象缓存系统,它通过减轻数据库负载来提高WEB的访问性能,Memcached是服务端的主程序,这些缓存一般是用来保存一些经常存取的对象或数据(比如浏览器会缓存常访问的网页缓存一样),最终用户通过请求缓存数据提高访问体验。

Memcached是一种内存缓存,把常存取的对象或数据缓存在内存中,内存中的缓存的这些数据通过API的方式被存取,数据就像一张巨大的HASH表,以key-value对的方式存在。

Memcache工作流程  

1、检查客户端请求的数据是否在Memcache中存在,如果存在,直接把相关数据返回,不再对数据进行任何操作

2、如果数据不在Memcache中,会去数据库进行查询,把从数据库中获取的数据返回给客户端,同时将数据缓存到Memcache中

3、数据库更新(更新或删除数据)的同时也会更新Memcache中的数据,从而保持数据一致

工作逻辑图如下:

4、如果分配给Memcache的内存使用完,会使用LRU(最近最少使用)和过期策略,失效的数据就会被替换掉,然后替换掉最近未使用的数据

Memcache的特点  

1、协议简单

     使用基于文本行的协议,能直接通过telnet在Memcached服务器上存取数据,实现比较简单

2、基于Libevent的事件处理

    libevent是基于C开发的程序库,Memcached利用这个库进行异步事件处理

3、内置内存管理方式

    Memcached有一套自己的管理内存方式,而且非常高效,所有数据都保存在Memcached内置的内存中,当存入的数据占满空间时,会使用LRU算法来清除不使用的缓存数据,从而来重用过期数据的内存空间,但重启服务器数据将丢失

4、各Memcached服务器间互不通信具有分存式特点

    各个Memcached服务器之间互不通信,都是独立存取数据,通过客户端的设计让其具有分存式特点,支持大量缓存和大规模应用

Memcached的安装  

Memcached的安装很简单,首先需要下载libevent与Memcached软件,下载过程就不再介绍了

安装libevent命令如下(也可直接Yum安装):

tar zxf libevent-1.4.13-stable.tar.gz

cd libevent-1.4.13-stable

标签:

很赞哦! ()

本栏推荐