当前位置:首页 > 软件开发 > 正文

memcached是什么 memcached最新版本

memcached是什么 memcached最新版本

大家好,今天来为大家解答memcached是什么这个问题的一些问题点,包括memcached最新版本也一样很多人还不知道,因此呢,今天就来为大家分析分析,现在让我们一起...

大家好,今天来为大家解答memcached是什么这个问题的一些问题点,包括memcached最新版本也一样很多人还不知道,因此呢,今天就来为大家分析分析,现在让我们一起来看看吧!如果解决了您的问题,还望您关注下本站哦,谢谢~

Redis和Memcached各有什么优缺点主要的应用场景是什么

根据我的经验,在BAT里,redis已经逐渐取代了memcached,成为分布式场景广泛使用的缓存方案。接下来,我们就分析下,redis是如何取代memcached,成为开发者的宠儿的。

支持的存储类型不同

虽然都是内存数据库,memcached不仅能够存储string,还能够存储图片,视频等形式的文件。然而对于更多的使用内存数据库做缓存以及分布式方案的程序开发者来说,memcached提供的string格式存储,应用场景有限,而存储图片视频的功能又十分鸡肋(主要是没这方面需求)。相比之下,redis提供set,hash,list等多种类型的存储结构,对于做分布式缓存实在是再适合不过了。

数据落盘

虽然大多数人使用缓存以及分布式方案都不会要求数据持久化,但是谁也不能保证不出现万一的情况。一旦发生稳定性问题,memcached挂掉后,数据是不可恢复的,而redis除了支持在配置里打开数据落盘(RDB),还能通过aof来找回数据。

内存空间与数据量

memcached可以修改最大内存,使用的是LRU算法,而redis目前底层使用了自己的VM,引入了新的特性突破了物理内存的限制。个人认为在这方面依然是redis更加优秀一些。

使用场景

基于以上提到的特点,基本我们就能分清redis与memcached的场景了。

如果对缓存数据类型超越了基本的数据结构,需要图片或者视频,多读少写,且数据量非常大的场景,那么一定要用memcached而不是redis了(比如微博大量查询好友信息,微博信息等,但是不是说微博用的是memcached方案哦)。

但是如果是对缓存的数据格式有更多的要求,且对安全性也有很高的要求的话,建议还是使用redis,这也是redis目前正在逐渐代替memcached的根本原因。

以上是我的浅见,欢迎各位在下方评论区与我沟通。

我是苏苏思量,来自BAT的Java开发工程师,每天分享科技类见闻,欢迎关注我,与我共同进步。

Guava、Memcached和Redis,选哪个比较好

简单来说,Redis就是一个数据库。

不同于传统数据库将数据保存在磁盘中,Redis将数据存在内存中,所以它也经常被叫做内存数据库;同时Redis存储也被叫做NoSQL数据库、非关系型数据库。

因为Redis将数据保存在内存中,所以读写速度会非常快,因此Redis被广泛应用做缓存或其他需要高速读写的场景。

为什么要使用Redis

软件架构中引入Redis,是因为它“又快又强”。

1.快,是指性能高

计算机硬件的速度由低到高:硬盘-网络-内存-CPU;

在传统的数据库中,如果第一次访问数据库中的某条数据,通常是比较慢的,因为数据库需要从硬盘上读取数据;而Redis中的数据保存在了内存中,所以速度会比从磁盘中读取数据快得多。

所以我们经常把Redis当做缓存:第一次从数据库中读取数据,并放入Redis,后面直接访问Redis就可以了。

2.强,是指高并发场景下的稳定性(高可用)

在高并发的场景下,Redis能够承受的访问极限,是远远大于数据库的,所以我们可以考虑把需要高并发读的数据放到Redis中;

比如秒杀功能,短短几秒内可能就会有数十万笔的访问,如果直接操作数据库的话,数据库可能瞬间就被击垮了。

哪些场景不适合放入Redis

当然,也不是说所有的场景、所有的数据都适合放进Redis中,通常我们需要考虑以下几点:

数据查询的命中率高么?如果缓存的命中率很低,没有必要放入到Redis中;数据读写操作多么?如果数据会被频繁写入(增、改、删),设置写操作次数大于读操作次数,那么也没有必要使用Redis;业务数据大小如何?如果要储存文件,那完全没有必要放入到Redis中。本地缓存orRedis

缓存分为本地缓存和分布式缓存:

1.本地缓存

比如Guava、Ehcache,甚至把缓存保存到Map中,这些都是本地缓存;

本地缓存的特点是轻量、实现简单,生命周期随着JVM的销毁而结束;但是如果程序存在多个实例(程序部署多套),每个实例中的缓存不具有一致性。

2.分布式缓存

Redis被称作分布式缓存,如果程序存在多个实例,各个实例可以共用Redis中的缓存数据,但同时因为引入了Redis,那么需要保证Redis的高可用,架构上更为复杂。

RedisorMemcached

Memcached也经常被用作缓存,也是分布式缓存的一种,那么它和Redis有什么区别呢?

Redis支持更丰富的数据类型,Memcache支持简单的数据类型String;

Redis支持数据的持久化,可以将内存中的数据保存到硬盘中,重启之后把数据加载到内存中,而Memcache只是把数据保存在内存中;

Redis目前支持集群模式,而Memcached没有原生的集群模式,需要使用方自己实现;

Redis使用单线程的多路IO复用模型(Redis在最新的6.0版本中开始支持多线程);Memcached使用的是多非阻塞IO复用的网络模型。

最后再强调一点,是否要引入Redis?使用本地缓存还是分布式缓存?都需从项目的实际情况出发;Redis丰富的数据类型和对持久化的支持,会更加适合我们的项目。

我将持续分享Java开发、架构设计、程序员职业发展等方面的见解,希望能得到你的关注;关注我后,可私信发送数字【1】,获取海量学习资料。

好了,本文到此结束,如果可以帮助到大家,还望关注本站哦!

最新文章