Memcached的内存分配原理介绍

在这里插入图片描述

What is Memcached?

Free & open source, high-performance, distributed memory object caching system, generic in nature, but intended for use in speeding up dynamic web applications by alleviating database load.

Memcached is an in-memory key-value store for small chunks of arbitrary data (strings, objects) from results of database calls, API calls, or page rendering.

Memcached is simple yet powerful. Its simple design promotes quick deployment, ease of development, and solves many problems facing large data caches. Its API is available for most popular languages.

Memcached是什么?

免费和开源、高性能、分布式内存对象缓存系统,本质上是通用的,但旨在通过减轻数据库负载来加速动态web应用程序。

Memcached是一个内存中的键值存储,用于存储来自数据库调用、API调用或页面呈现结果的小块任意数据(字符串、对象)。

Memcached简单而强大。其简单的设计促进了快速部署、易于开发,并解决了大型数据缓存面临的许多问题。它的API可用于大多数流行的语言。

为何要用Memcached?

设计web应用的时候,高并发与海量数据的处理一直是比较棘手的问题,传统的数据库都是关系型数据库,本身处理数据的过程就比较耗时,如果执行的sql和事务机制设计的不合理,一旦访问量激增,达到万级以上,那时候应用的处理性能就会直线下降,这期间如果跟其他系统还有交互,那整个应用体系都将受灾,甚至会出现雪崩。

这时候你就发现使用memcache能很好的解决这个问题。

我们可以把数据查出来保存到Memcache中,这样可以降低访问数据库的频率,从而减少数据库的负担,web应用的响应速度和可扩展性也会大大提升。

Memcached的工作就是通过一台机器将我们常用到的数据和文件放入一张hash表中,供应用程序使用,Memcached是一种内存型数据库,从而可以大大提升网站的运行效率。

Memcached的内存分配机制:

之前的内存分配大多数都是采用malloc和free来进行的,这样的方式很容易导致大量的内存碎片,时间久了就会影响内存管理器的运行。Memcached采用的是slab allocation机制分配和管理内存。Slab Allocation的基

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值