`

Memcached介绍

 
阅读更多

Memcached的主要特点

  • 基于C/S架构,协议简单
  • 基于libevent的事件处理
  • 自主内存存储处理
  • 基于客户端的Memcached分布式

1.数据存储方式:Slab Allocation

             

             Slab Allocator的基本原理是按照预先规定的大小,将分配的内存分割成特定长度的块,以完全解决内存碎片问题。
             Slab Allocation的原理相当简单。 将分配的内存分割成各种尺寸的块(chunk),并把尺寸相同的块分成组(chunk的集合)

             Page:分配给Slab的内存空间,默认是1MB。分配给Slab之后根据slab的大小切分成chunk。

             Chunk:用于缓存记录的内存空间。
             Slab Class:特定大小的chunk的组。
             memcached根据收到的数据的大小,选择最适合数据大小的slab。memcached中保存着slab内空闲chunk的列表,根据该列表选择chunk,然后将数据缓存于其中

           

              Slab Alloction 缺点:这个问题就是,由于分配的是特定长度的内存,因此无法有效利用分配的内存。例如,将100字节的数据缓存到128字节的chunk中,剩余的28字节就浪费了。

2.数据过期方式:Lazy Expiration + LRU

        Lazy Expiration:memcached内部不会监视记录是否过期,而是在get时查看记录的时间戳,检查记录是否过期。这种技术被称为lazy(惰性)expiration。因此,memcached不会在过期监视上耗费CPU时间。

        LRU:memcached会优先使用已超时的记录的空间,但即使如此,也会发生追加新记录时空间不足的情况,此时就要使用名为 Least Recently Used(LRU)机制来分配空间。顾名思义,这是删除“最近最少使用”的记录的机制。因此,当memcached的内存空间不足时(无法从slab class 获取到新的空间时),就从最近未被使用的记录中搜索,并将其空间分配给新的记录。从缓存的实用角度来看,该模型十分理想。

 

 

Memcached一些特性和限制

  • 在 Memcached 中可以保存的item数据量是没有限制的,只有内存足够
  • Memcached单进程最大使用内存为2G,要使用更多内存,可以分多个端口开启多个Memcached进程
  • 最大30天的数据过期时间, 设置为永久的也会在这个时间过期,常量REALTIME_MAXDELTA
  • 60*60*24*30 控制
  • 最大键长为250字节,大于该长度无法存储,常量KEY_MAX_LENGTH 250 控制
  • 单个item最大数据是1MB,超过1MB数据不予存储,常量POWER_BLOCK 1048576 进行控制,
  • 它是默认的slab大小
  •  最大同时连接数是200,通过 conn_init()中的freetotal 进行控制,最大软连接数是1024,通过
  • settings.maxconns=1024 进行控制
  •  跟空间占用相关的参数:settings.factor=1.25, settings.chunk_size=48, 影响slab的数据占用和步进方式

 

 

分享到:
评论

相关推荐

    memcached安装及java应用使用memcached

    1. **memcached介绍**:解释memcached的作用,它是如何通过将数据存储在内存中来减少数据库的读取压力,从而提高Web应用的响应速度。 2. **安装memcached**: - **系统要求**:说明支持的操作系统(如Linux、...

    memcached客户端文件及服务端

    **Memcached介绍** Memcached是一种高性能、分布式的内存对象缓存系统,用于在数据库和应用程序之间缓存数据,以减少对数据库的访问压力,提高应用的响应速度。它最初由Danga Interactive公司开发,现在已经成为...

    memcached+asp.net4.0

    1. **memcached介绍**:memcached是一种高性能的分布式内存缓存系统,最初设计用于加速动态Web应用程序,通过存储经常访问的数据到内存中,减少对数据库的依赖,提高响应速度。 2. **ASP.NET 4.0**:这是微软的.NET...

    memcached源代码下载.rar

    memcached介绍** `memcached`最初由Danga Interactive公司开发,现在已经成为开源社区的一个重要项目。它的设计目标是简化存储和检索数据的过程,通过将数据存储在内存中,避免了磁盘I/O操作,从而实现了快速响应...

    memcached-win64-1.4.4-14

    **Memcached介绍** Memcached是一款高性能、分布式内存对象缓存系统,它被广泛应用于Web应用中,用于减轻数据库负载,提高网站性能。该系统通过在内存中存储数据,实现快速访问,尤其适用于处理高并发场景下的数据...

    memcached-1.5.4windows下64位编译

    1. **Memcached介绍**:Memcached是一种分布式内存缓存系统,用于临时存储Web应用中的数据,减少对数据库的访问,提高系统的整体性能。 2. **Windows编译**:由于memcached原生支持Unix/Linux环境,因此在Windows上...

    韩顺平 PHP Memcached缓存技术资料源码笔记图解PPT_Ady

    一、Memcached介绍 Memcached是一款分布式内存对象缓存系统,广泛应用于高性能网站和应用中。它设计的目标是简化并加速动态Web应用程序的数据存储,通过将数据存储在内存中,避免频繁读取或写入数据库,从而提高...

    memcached linux windows 安装 使用 缓存 集群

    【Memcached介绍】 Memcached是一款高性能、分布式内存对象缓存系统,它被广泛应用于Web应用中,用于减轻数据库的负载,提高数据访问速度。通过在内存中存储常用数据,Memcached能够快速响应客户端请求,避免了频繁...

    memcachedlib.rar tomcat中要使用的memcached的jar文件

    1. **memcached介绍**:memcached是一个开源的、基于内存的分布式缓存系统,设计用于提高网站数据访问速度。它通过缓存经常访问的数据来减少对数据库的读取,从而提高了系统的整体性能。 2. **Java客户端**:Java...

    (SSM框架)memcached整合Spring基于Cache注解.

    1. **Memcached介绍**: Memcached是一款高性能、分布式的内存对象缓存系统,用于在动态系统中减少数据库负载,提升数据读取速度。它通过存储临时数据在内存中,避免了频繁访问数据库,提高了应用程序的响应速度。 ...

    nginx和memcached配置tomcat的jar包

    二、Memcached介绍与使用 Memcached是一个分布式内存对象缓存系统,用于减少数据库负载,提升Web应用性能。在Java应用中,我们通常使用Spymemcached库来操作Memcached。首先,将Spymemcached的jar包添加到Tomcat的`...

    memcached安装包win32+win64(包含msvcp71.dll,msvcr71.dll)

    **Memcached介绍** Memcached是一款高性能、分布式内存对象缓存系统,它被广泛应用于Web应用中,用于减轻数据库负载,提高数据访问速度。通过在内存中存储经常访问的数据,Memcached能够快速响应请求,减少对数据库...

    memcached 在ASP.NET网站下的应用实例代码(c#)

    **memcached介绍** Memcached是一种高性能的分布式内存对象缓存系统,用于减少数据库负载,提高Web应用性能。它通过在内存中存储数据来加快数据访问速度,适用于需要频繁读取但不经常修改的数据。 **在ASP.NET中的...

    memcached文档中文版

    ### Memcached介绍 Memcached是一款高性能的分布式内存对象缓存系统,它通过缓存数据和对象来减少数据库访问次数,从而提升动态Web应用的响应速度。Memcached的键/值存储方式使得其可以用来缓存各种数据,如数据库...

    Memcached 介绍文档

    Memcached是一种高性能、分布式内存对象缓存系统,其设计初衷是为了加速动态Web应用程序,通过减轻数据库负载来提高网站性能。Memcached在多个大型互联网公司如Facebook、Yahoo、Amazon、LiveJournal和Mixi等中得到...

    memcached缓存编程实战.pptx

    Memcached 介绍 Memcached 是一个高性能的缓存系统,通过减少数据库的查询次数和降低系统的负载来提高网站的性能。Memcached 可以与多种编程语言集成,包括 Java、PHP、Python 等。 Memcached Java 客户端 ...

    memcached服务端已经多个客户端

    **memcached介绍** Memcached是一种高性能的分布式内存对象缓存系统,用于在动态系统中减少数据库负载,提升应用性能。它通过将数据存储在内存中,使得数据访问速度大大提高,尤其适用于读取密集型的应用场景。...

    memcached php

    1. **Memcached介绍**:Memcached是为了解决动态Web应用的数据库查询压力而设计的,它将数据存储在内存中,提供快速的访问。其特点是轻量级、高性能和分布式的特性。 2. **安装Memcached**:在服务器上安装...

    Memcached spring 的集成

    1. **Memcached介绍**: - Memcached是一个高性能的分布式内存对象缓存系统,它可以存储键值对数据,用于缓解数据库负载,提高Web应用的响应速度。 - Memcached使用简单的文本协议,支持多语言客户端,且基于内存...

    php扩展memecache+memcached.exe

    3. **Memcached介绍** Memcached比Memcache更现代,它提供了一个更为强大和稳定的服务。Memcached同样是一个分布式内存缓存系统,但其设计目标是简化存储和检索过程,提高性能。 4. **PHP扩展Memcached** PHP的...

Global site tag (gtag.js) - Google Analytics