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的数据占用和步进方式
相关推荐
1. **memcached介绍**:解释memcached的作用,它是如何通过将数据存储在内存中来减少数据库的读取压力,从而提高Web应用的响应速度。 2. **安装memcached**: - **系统要求**:说明支持的操作系统(如Linux、...
**Memcached介绍** Memcached是一种高性能、分布式的内存对象缓存系统,用于在数据库和应用程序之间缓存数据,以减少对数据库的访问压力,提高应用的响应速度。它最初由Danga Interactive公司开发,现在已经成为...
1. **memcached介绍**:memcached是一种高性能的分布式内存缓存系统,最初设计用于加速动态Web应用程序,通过存储经常访问的数据到内存中,减少对数据库的依赖,提高响应速度。 2. **ASP.NET 4.0**:这是微软的.NET...
memcached介绍** `memcached`最初由Danga Interactive公司开发,现在已经成为开源社区的一个重要项目。它的设计目标是简化存储和检索数据的过程,通过将数据存储在内存中,避免了磁盘I/O操作,从而实现了快速响应...
**Memcached介绍** Memcached是一款高性能、分布式内存对象缓存系统,它被广泛应用于Web应用中,用于减轻数据库负载,提高网站性能。该系统通过在内存中存储数据,实现快速访问,尤其适用于处理高并发场景下的数据...
1. **Memcached介绍**:Memcached是一种分布式内存缓存系统,用于临时存储Web应用中的数据,减少对数据库的访问,提高系统的整体性能。 2. **Windows编译**:由于memcached原生支持Unix/Linux环境,因此在Windows上...
一、Memcached介绍 Memcached是一款分布式内存对象缓存系统,广泛应用于高性能网站和应用中。它设计的目标是简化并加速动态Web应用程序的数据存储,通过将数据存储在内存中,避免频繁读取或写入数据库,从而提高...
【Memcached介绍】 Memcached是一款高性能、分布式内存对象缓存系统,它被广泛应用于Web应用中,用于减轻数据库的负载,提高数据访问速度。通过在内存中存储常用数据,Memcached能够快速响应客户端请求,避免了频繁...
1. **memcached介绍**:memcached是一个开源的、基于内存的分布式缓存系统,设计用于提高网站数据访问速度。它通过缓存经常访问的数据来减少对数据库的读取,从而提高了系统的整体性能。 2. **Java客户端**:Java...
1. **Memcached介绍**: Memcached是一款高性能、分布式的内存对象缓存系统,用于在动态系统中减少数据库负载,提升数据读取速度。它通过存储临时数据在内存中,避免了频繁访问数据库,提高了应用程序的响应速度。 ...
二、Memcached介绍与使用 Memcached是一个分布式内存对象缓存系统,用于减少数据库负载,提升Web应用性能。在Java应用中,我们通常使用Spymemcached库来操作Memcached。首先,将Spymemcached的jar包添加到Tomcat的`...
**Memcached介绍** Memcached是一款高性能、分布式内存对象缓存系统,它被广泛应用于Web应用中,用于减轻数据库负载,提高数据访问速度。通过在内存中存储经常访问的数据,Memcached能够快速响应请求,减少对数据库...
**memcached介绍** Memcached是一种高性能的分布式内存对象缓存系统,用于减少数据库负载,提高Web应用性能。它通过在内存中存储数据来加快数据访问速度,适用于需要频繁读取但不经常修改的数据。 **在ASP.NET中的...
### Memcached介绍 Memcached是一款高性能的分布式内存对象缓存系统,它通过缓存数据和对象来减少数据库访问次数,从而提升动态Web应用的响应速度。Memcached的键/值存储方式使得其可以用来缓存各种数据,如数据库...
Memcached是一种高性能、分布式内存对象缓存系统,其设计初衷是为了加速动态Web应用程序,通过减轻数据库负载来提高网站性能。Memcached在多个大型互联网公司如Facebook、Yahoo、Amazon、LiveJournal和Mixi等中得到...
Memcached 介绍 Memcached 是一个高性能的缓存系统,通过减少数据库的查询次数和降低系统的负载来提高网站的性能。Memcached 可以与多种编程语言集成,包括 Java、PHP、Python 等。 Memcached Java 客户端 ...
**memcached介绍** Memcached是一种高性能的分布式内存对象缓存系统,用于在动态系统中减少数据库负载,提升应用性能。它通过将数据存储在内存中,使得数据访问速度大大提高,尤其适用于读取密集型的应用场景。...
1. **Memcached介绍**:Memcached是为了解决动态Web应用的数据库查询压力而设计的,它将数据存储在内存中,提供快速的访问。其特点是轻量级、高性能和分布式的特性。 2. **安装Memcached**:在服务器上安装...
1. **Memcached介绍**: - Memcached是一个高性能的分布式内存对象缓存系统,它可以存储键值对数据,用于缓解数据库负载,提高Web应用的响应速度。 - Memcached使用简单的文本协议,支持多语言客户端,且基于内存...
3. **Memcached介绍** Memcached比Memcache更现代,它提供了一个更为强大和稳定的服务。Memcached同样是一个分布式内存缓存系统,但其设计目标是简化存储和检索过程,提高性能。 4. **PHP扩展Memcached** PHP的...