为什么要使用分布式缓存

高并发环境下,例如典型的淘宝双11秒杀,几分钟内上亿的用户涌入淘宝,这个时候如果访问不加拦截,让大量的读写请求涌向数据库,由于磁盘的处理速度与内存显然不在一个量级,服务器马上就要宕机。从减轻数据库的压力和提高系统响应速度两个角度来考虑,都会在数据库之前加一层缓存,访问压力越大的,在缓存之前就开始CDN拦截图片等访问请求。

并且由于最早的单台机器的内存资源以及承载能力有限,如果大量使用本地缓存,也会使相同的数据被不同的节点存储多份,对内存资源造成较大的浪费,因此,才催生出了分布式缓存。

分布式缓存应用场景

  1. 页面缓存.用来缓存Web 页面的内容片段,包括HTML、CSS 和图片等;
  2. 应用对象缓存.缓存系统作为ORM 框架的二级缓存对外提供服务,目的是减轻数据库的负载压力,加速应用访问;
  3. 解决分布式Web部署的session同步问题,状态缓存.缓存包括Session 会话状态及应用横向扩展时的状态数据等,这类数据一般是难以恢复的,对可用性要求较高,多应用于高可用集群。
  4. 并行处理.通常涉及大量中间计算结果需要共享;
  5. 云计算领域提供分布式缓存服务。

本文介绍缓存的原理,缓存的分类,缓存的设计,CDN缓存(原理,架构参考和技术实践),反向代理缓存(原理,Squid架构实践和常用代理缓存之间的比较)等。

目录

  1. 缓存概述
  2. CDN缓存
  3. 反向代理缓存
  4. 分布式缓存
  5. 本地缓存
  6. 缓存架构示例

1. 缓存概述

缓存是分布式系统中的重要组件,主要解决高并发,大数据场景下,热点数据访问的性能问题。提供高性能的数据快速访问。

1.1 缓存原理

  1. 将数据写入/读取速度更快的存储(设备);
  2. 将数据缓存到离应用最近的位置;
  3. 将数据缓存到离用户最近的位置。

1.2 缓存分类

在分布式系统中,缓存的应用非常广泛,从部署角度有以下几个方面的缓存应用。

  • CDN缓存;
  • 反向代理缓存;
  • 分布式Cache;
  • 本地应用缓存;

1.3 缓存媒介

  • 常用中间件:Varnish,Ngnix,Squid,Memcache,Redis,Ehcache等;
  • 缓存的内容:文件,数据,对象;
  • 缓存的介质:CPU,内存(本地,分布式),磁盘(本地,分布式)

1.4 缓存设计

缓存设计需要解决以下几个问题:

(1)缓存什么?哪些数据需要缓存:1.热点数据;2.静态资源;(2)缓存的位置?CDN,反向代理,分布式缓存服务器,本机(内存,硬盘)(3)如何缓存的问题?- 过期策略1. 固定时间:比如指定缓存的时间是30分钟;2. 相对时间:比如最近10分钟内没有访问的数据;- 同步机制1. 实时写入(PUSH)2. 异步刷新(PUSH & PULL)

2. CDN缓存

CDN主要解决将数据缓存到离用户最近的位置,一般缓存静态资源文件(页面,脚本,图片,视频,文件等)。国内网络异常复杂,跨运营商的网络访问会很慢。为了解决跨运营商或各地用户访问问题,可以在重要的城市,部署CDN应用。使用户就近获取所需内容,降低网络拥塞,提高用户访问响应速度和命中率。

2.1 CDN原理

CDN的基本原理是广泛采用各种缓存服务器,将这些缓存服务器分布到用户访问相对集中的地区或网络中,在用户访问网站时,利用全局负载技术将用户的访问指向距离最近的工作正常的缓存服务器上,由缓存服务器直接响应用户请求。

  1. 未部署CDN应用前

未部署CDN应用前应用架构

网络路径:

  • 请求:本机网络(局域网)--> 运营商网络 --> 应用服务器机房
  • 响应:应用服务器机房 --> 运营商网络 --> 本机网络(局域网)

在不考虑复杂网络的情况下,从请求到响应需要经过3个节点,6个步骤完成一次用户访问操作。

  1. 部署CDN应用后

网络路径:

  • 请求:本机网络(局域网)--> 运营商网络
  • 响应:运营商网络 --> 本机网络(局域网)

在不考虑复杂网络的情况下,从请求到响应需要经过2个节点,2个步骤完成一次用户访问操作。

与不部署CDN服务相比,减少了1个节点,4个步骤的访问。极大的提高的系统的响应速度。

2.2 CDN优缺点

  1. 优点

    • 本地Cache加速:提升访问速度,尤其含有大量图片和静态页面站点;
    • 镜像服务:消除了不同运营商之间互联的瓶颈造成的影响,实现了跨运营商的网络加速,保证不同网络中的用户都能得到良好的访问质量;
    • 远程加速:远程访问用户根据DNS负载均衡技术智能自动选择Cache服务器,选择最快的Cache服务器,加快远程访问的速度;
    • 带宽优化:自动生成服务器的远程Mirror(镜像)cache服务器,远程用户访问时从cache服务器上读取数据,减少远程访问的带宽、分担网络流量、减轻原站点WEB服务器负载等功能。
    • 集群抗攻击:广泛分布的CDN节点加上节点之间的智能冗余机制,可以有效地预防黑客入侵以及降低各种D.D.o.S攻击对网站的影响,同时保证较好的服务质量。
  2. 缺点

    • 动态资源缓存,需要注意实时性;

      解决办法:主要缓存静态资源,动态资源建立多级缓存或准实时同步等。

    • 如何保证数据的一致性和实时性需要权衡考虑。

      解决办法:设置缓存失效时间;数据版本号等。

2.3 CDN架构参考

CDN架构参考

2.4 CDN技术实践

目前,中小型互联网公司,综合成本考虑,一般租用第三方CDN服务,大型互联网公司,采用自建或第三方结合的方式。比如淘宝刚开始使用第三方的,当流量很大后,第三方公司无法支撑其CDN流量,淘宝最后采用自建CDN的方式实现。

例如淘宝的CDN架构,如下图所示:

淘宝CDN架构

3. 反向代理缓存

反向代理是指在网站服务器机房部署代理服务器,实现负载均衡,数据缓存,安全控制等功能。

3.1 反射代理缓存原理

反向代理位于应用服务器机房,处理所有对WEB服务器的请求。如果用户请求的页面在代理服务器上有缓冲的话,代理服务器直接将缓冲内容发送给用户。如果没有缓冲则先向WEB服务器发出请求,取回数据,本地缓存后再发送给用户。通过降低向WEB服务器的请求数,从而降低了WEB服务器的负载。

反射代理缓存原理

反向代理一般缓存静态资源,动态资源转发到应用服务器处理。常用的缓存应用服务器有Varnish,Ngnix,Squid。

3.2 SQUID反向代理示例

Squid 反向代理一般只缓存静态资源,动态程序默认不缓存。根据从 WEB 服务器返回的 HTTP 头标记来缓冲静态页面。有四个最重要 HTTP 头标记:

  • Last-Modified: 告诉反向代理页面什么时间被修改
  • Expires: 告诉反向代理页面什么时间应该从缓冲区中删除
  • Cache-Control: 告诉反向代理页面是否应该被缓冲
  • Pragma: 用来包含实现特定的指令,最常用的是 Pragma:no-cache

image

Squid 反向代理加速网站实例

  1. 通过DNS的轮询技术,将客户端的请求分发给其中一台 Squid 反向代理服务器处理;
  2. 如果这台 Squid 缓存了用户的请求资源,则将请求的资源直接返回给用户;
  3. 否则这台 Squid 将没有缓存的请求根据配置的规则发送给邻居 Squid 和后台的 WEB 服务器处理;
  4. 这样既减轻后台 WEB 服务器的负载,又提高整个网站的性能和安全性。

3.3 代理缓存比较

常用的代理缓存有Varnish,Squid,Ngnix,简单比较如下:

(1)varnish和squid是专业的cache服务,nginx需要第三方模块支持;
(2)Varnish采用内存型缓存,避免了频繁在内存、磁盘中交换文件,性能比Squid高;
(3)Varnish由于是内存cache,所以对小文件如css,js,小图片啥的支持很棒,后端的持久化缓存可以采用的是Squid或ATS;
(4)Squid功能全而大,适合于各种静态的文件缓存,一般会在前端挂一个HAProxy或nginx做负载均衡跑多个实例;
(5)Nginx采用第三方模块ncache做的缓冲,性能基本达到varnish,一般作为反向代理使用,可以实现简单的缓存。

4. 分布式缓存

CDN缓存、反向代理缓存,主要解决静态文件,或用户请求资源的缓存,数据源一般为静态文件或动态生成的文件(有缓存头标识)。

分布式缓存,主要指缓存用户经常访问数据的缓存,数据源为数据库。一般起到热点数据访问和减轻数据库压力的作用。

目前分布式缓存设计,在大型网站架构中是必备的架构要素。常用的中间件有Memcached、Redis。

4.1 Memcached缓存

Memcache是一个高性能,分布式内存对象缓存系统,通过在内存里维护一个统一的巨大的hash表,它能够用来存储各种格式的数据,包括图像、视频、文件以及数据库检索的结果等。简单的说就是将数据调用到内存中,然后从内存中读取,从而大大提高读取速度。

Memcache特性

(1)使用物理内存作为缓存区,可独立运行在服务器上。每个进程最大2G,如果想缓存更多的数据,可以开辟更多的memcache进程(不同端口)或者使用分布式memcache进行缓存,将数据缓存到不同的物理机或者虚拟机上。
(2)使用key-value的方式来存储数据,这是一种单索引的结构化数据组织形式,可使数据项查询时间复杂度为O(1)。
(3)协议简单:基于文本行的协议,直接通过telnet在memcached服务器上可进行存取操作,简单,方便多种缓存参考此协议;
(4)基于libevent高性能通信:Libevent是一套利用C开发的程序库,它将BSD系统的kqueue,Linux系统的epoll等事件处理功能封装成一个接口,与传统的select相比,提高了性能。
(5)内置的内存管理方式:所有数据都保存在内存中,存取数据比硬盘快,当内存满后,通过LRU算法自动删除不使用的缓存,但没有考虑数据的容灾问题,重启服务,所有数据会丢失。
(6)分布式:各个memcached服务器之间互不通信,各自独立存取数据,不共享任何信息。服务器并不具有分布式功能,分布式部署取决于memcache客户端。
(7)缓存策略:Memcached的缓存策略是LRU(最近最少使用)到期失效策略。在memcached内存储数据项时,可以指定它在缓存的失效时间,默认为永久。当memcached服务器用完分配的内时,失效的数据被首先替换,然后也是最近未使用的数据。在LRU中,memcached使用的是一种Lazy Expiration策略,自己不会监控存入的key/vlue对是否过期,而是在获取key值时查看记录的时间戳,检查key/value对空间是否过期,这样可减轻服务器的负载。

4.1.1 Memcached原理

Memcached工作流程

MemCached的工作流程如下

(1)先检查客户端的请求数据是否在Memcached中,如有,直接把请求数据返回,不再对数据库进行任何操作;
(2)如果请求的数据不在Memcached中,就去查数据库,把从数据库中获取的数据返回给客户端,同时把数据缓存一份到memcached中(Memcached客户端不负责,需要程序实现);
(3)每次更新数据库的同时更新Memcached中的数据,保证一致性;
(4)当分配给Memcached内存空间用完之后,会使用LRU(Least Recently Used,最近最少使用)策略加上到期失效策略,失效数据首先被替换,然后再替换掉最近未使用的数据。

4.1.2 Memcached集群

Memcached 虽然称为 “ 分布式 ” 缓存服务器,但服务器端并没有 “ 分布式 ” 功能。每个服务器都是完全独立和隔离的服务。 memcached 的分布式,是由客户端程序实现的。

当向Memcached集群存入/取出key value时,memcached客户端程序根据一定的算法计算存入哪台服务器,然后再把key value值存到此服务器中。

因此,存取数据分二步走:

第一步,选择服务器;
第二步,存取数据。

Memcached存取数据

分布式算法

选择服务器算法有两种,一种是根据余数来计算分布,另一种是根据散列算法来计算分布。

  • 余数算法:

    • 先求得键的整数散列值,再除以服务器台数,根据余数确定存取服务器。
    • 优点:计算简单,高效;
    • 缺点:在memcached服务器增加或减少时,几乎所有的缓存都会失效。
  • 散列算法(一致性Hash):

    • 先算出memcached服务器的散列值,并将其分布到0到2的32次方的圆上,然后用同样的方法算出存储数据的键的散列值并映射至圆上,最后从数据映射到的位置开始顺时针查找,将数据保存到查找到的第一个服务器上,如果超过2的32次方,依然找不到服务器,就将数据保存到第一台memcached服务器上。

散列算法

如果添加了一台memcached服务器,只在圆上增加服务器的逆时针方向的第一台服务器上的键会受到影响。

一致性Hash算法:解决了余数算法增加节点命中大幅额度降低的问题,理论上,插入一个实体节点,平均会影响到:虚拟节点数/2 的节点数据的命中。

4.2 Redis缓存

Redis 是一个开源(BSD许可)的,基于内存的,多数据结构存储系统。可以用作数据库、缓存和消息中间件。 支持多种类型的数据结构,如 字符串(strings), 散列(hashes), 列表(lists), 集合(sets), 有序集合(sorted sets) 与范围查询, bitmaps, hyperloglogs 和 地理空间(geospatial) 索引半径查询。

内置了复制(replication),LUA脚本(Lua scripting), LRU驱动事件(LRU eviction),事务(transactions) 和不同级别的 磁盘持久化(persistence), 并通过 Redis哨兵(Sentinel)和自动分区(Cluster)提供高可用性(high availability)。

4.2.1 Redis常用数据类型

  1. String类型

    • 常用命令:set,get,decr,incr,mget
    • 应用场景:String是最常用的一种数据类型,与Memcache的key value存储方式类似。
    • 实现方式:String在redis内部存储默认就是一个字符串,被redisObject所引用,当遇到incr,decr等操作时会转成数值型进行计算,此时redisObject的encoding字段为int。
  2. Hash类型

    • 常用命令:hget,hset,hgetall
    • 应用场景:以存储一个用户信息对象数据为例:

      image

    • 实现方式:Hash类型对应的Value,内部实际就是一个HashMap,实际这里会有2种不同实现。
      • Hash的成员比较少时Redis为了节省内存会采用类似一维数 组的方式来紧凑存储,而不会采用真正的HashMap结构,对应的value redisObject的encoding为zipmap;
      • 当成员数量增大时会自动转成真正的HashMap,此时encoding为ht。
  3. List类型

    • 常用命令:lpush,rpush,lpop,rpop,lrange
    • 应用场景:List类型的应用场景非常多,也是Redis最重要的数据结构之一,比如twitter的关注列表,粉丝列表等都可以用Redis的list结构来实现。
    • 实现方式:List的实现为一个双向链表,可以支持反向查找和遍历,方便操作。不过带来了部分额外的内存开销,Redis内部的很多实现,包括发送缓冲队列等也都是用的这个数据结构。
  4. Set类型

    • 常用命令:sadd,spop,smembers,sunion
    • 应用场景:Set类型对外提供的功能与list类似是一个列表的功能,特殊之处在于set是可以自动排重的,当你需要存储一个列表数据,又不希望出现重复数据时,set 是一个很好的选择,并且set提供了判断某个成员是否在一个set集合内的重要接口,这个也是list所不能提供的。
    • 实现方式:Set类型的内部实现是一个value永远为null的HashMap,实际就是通过计算hash的方式来快速排重的,这也是set能提供判断一个成员是否在集合内的原因。
  5. Sorted Set类型

    • 常用命令:zadd,zrange,zrem,zcard;
    • 使用场景:Sorted Set的使用场景与set类似,区别是set不是自动有序的,而sorted set可以通过用户额外提供一个优先级(score)的参数来为成员排序,并且是插入有序的,即自动排序。当你需要一个有序的并且不重复的集合列表,可以选择sorted set数据结构,比如twitter 的public timeline可以以发表时间作为score来存储,这样获取时就是自动按时间排好序的。
    • 实现方式:Sorted set的内部使用HashMap和跳跃表(SkipList)来保证数据的存储和有序,HashMap里放的是成员到score的映射,而跳跃表里存放的 是所有的成员,排序依据是HashMap里存的score,使用跳跃表的结构可以获得比较高的查找效率,并且在实现上比较简单。

4.2.2 Redis集群

  1. 通过KeepAlived实现的高可用方案

通过KeepAlived实现的高可用方案

- 切换流程:1. 当Master挂了后,VIP漂移到Slave;Slave 上keepalived 通知redis 执行:slave of no one, 开始提供业务2. 当Master起来后,VIP 地址不变,Master的keepalived通知redis执行slave of slave IP host,开始作为从同步数据3. 依次类推- 主从同时宕机情况:1. 非计划性,不做考虑,一般也不会存在这种问题2. 计划性重启,重启之前通过运维手段SAVE DUMP 主库数据;需要注意顺序:1). 关闭其中一台机器上所有redis,是得master全部切到另外一台机器(多实例部署,单机上既有主又有从的情况);并关闭机器2). 依次dump主上redis服务3). 关闭主库4). 启动主库,并等待数据load完毕5). 启动从库 6). 删除DUMP文件(避免重启加载慢)
  1. 使用Twemproxy实现集群方案

Twemproxy由Twitter公司开源的c版本proxy,同时支持memcached和redis,Twitter用它主要减少前端与缓存服务间网络连接数。

  • Twemproxy方案的特点:快速、轻量级、减少后端Cache Server连接数、易配置、支持ketama、modula、random、常用hash分片算法等。

Twemproxy集群方案

注:图中使用Keepalived实现高可用主备方案,解决proxy单点问题。

  • Twemproxy方案的优点:

    1. 对于客户端而言,redis集群是透明的,客户端简单,遍于动态扩容
    2. Proxy为单点、处理一致性hash时,集群节点可用性检测不存在脑裂问题
    3. 高性能,CPU密集型,而redis节点集群多CPU资源冗余,可部署在redis节点集群上,不需要额外设备

4.3 Memcached与Redis的比较

  • 数据结构:Memcache只支持key value存储方式,Redis支持更多的数据类型,比如Key value,hash,list,set,zset;
  • 多线程:Memcache支持多线程,redis支持单线程;CPU利用方面Memcache优于redis;
  • 持久化:Memcache不支持持久化,Redis支持持久化;
  • 内存利用率:memcache高,redis低(采用压缩的情况下比memcache高);
  • 过期策略:memcache过期后,不删除缓存,会导致下次取数据数据的问题,Redis有专门线程,清除缓存数据。

5. 本地缓存

本地缓存是指应用内部的缓存,标准的分布式系统,一般有多级缓存构成。本地缓存是离应用最近的缓存,一般可以将数据缓存到硬盘或内存。

  • 硬盘缓存

将数据缓存到硬盘到,读取时从硬盘读取。原理是直接读取本机文件,减少了网络传输消耗,比通过网络读取数据库速度更快。可以应用在对速度要求不是很高,但需要大量缓存存储的场景。

  • 内存缓存

直接将数据存储到本机内存中,通过程序直接维护缓存对象,是访问速度最快的方式。

6. 缓存架构示例

缓存架构示例

  1. 职责划分:

    • CDN:存放HTML,CSS,JS等静态资源;
    • 反向代理:动静分离,只缓存用户请求的静态资源;
    • 分布式缓存:缓存数据库中的热点数据;
    • 本地缓存:缓存应用字典等常用数据;
  2. 请求过程:

    • 浏览器向客户端发起请求,如果CDN有缓存则直接返回;
    • 如果CDN无缓存,则访问反向代理服务器;
    • 如果反向代理服务器有缓存则直接返回;
    • 如果反向代理服务器无缓存或动态请求,则访问应用服务器;
    • 应用服务器访问本地缓存;如果有缓存,则返回代理服务器,并缓存数据;(动态请求不缓存)
    • 如果本地缓存无数据,则读取分布式缓存;并返回应用服务器;应用服务器将数据缓存到本地缓存(部分);
    • 如果分布式缓存无数据,则应用程序读取数据库数据,并放入分布式缓存。  

分布式缓存的常见问题和挑战

1.缓存雪崩

缓存雪崩我们可以简单的理解为:由于原有缓存失效,新缓存未到期间(例如:我们设置缓存时采用了相同的过期时间,在同一时刻出现大面积的缓存过期),所有原本应该访问缓存的请求都去查询数据库了,而对数据库CPU和内存造成巨大压力,严重的会造成数据库宕机。从而形成一系列连锁反应,造成整个系统崩溃。

2.缓存穿透

缓存穿透是指用户查询数据,在数据库没有,自然在缓存中也不会有。这样就导致用户查询的时候,在缓存中找不到,每次都要去数据库再查询一遍,然后返回空(相当于进行了两次无用的查询)。这样请求就绕过缓存直接查数据库,这也是经常提的缓存***率问题。

3.缓存预热

缓存预热这个应该是一个比较常见的概念,相信很多小伙伴都应该可以很容易的理解,缓存预热就是系统上线后,将相关的缓存数据直接加载到缓存系统。这样就可以避免在用户请求的时候,先查询数据库,然后再将数据缓存的问题!用户直接查询事先被预热的缓存数据!

4.缓存更新

除了缓存服务器自带的缓存失效策略之外,我们还可以根据具体的业务需求进行自定义的缓存淘汰,常见的策略有两种:

(1)定时去清理过期的缓存;

(2)当有用户请求过来时,再判断这个请求所用到的缓存是否过期,过期的话就去底层系统得到新数据并更新缓存。

两者各有优劣,***种的缺点是维护大量缓存的key是比较麻烦的,第二种的缺点就是每次用户请求过来都要判断缓存失效,逻辑相对比较复杂!具体用哪种方案,大家可以根据自己的应用场景来权衡。

5.缓存降级

当访问量剧增、服务出现问题(如响应时间慢或不响应)或非核心服务影响到核心流程的性能时,仍然需要保证服务还是可用的,即使是有损服务。系统可以根据一些关键数据进行自动降级,也可以配置开关实现人工降级。

降级的最终目的是保证核心服务可用,即使是有损的。而且有些服务是无法降级的(如加入购物车、结算)。

在进行降级之前要对系统进行梳理,看看系统是不是可以丢卒保帅;从而梳理出哪些必须誓死保护,哪些可降级;比如可以参考日志级别设置预案:

(1)一般:比如有些服务偶尔因为网络抖动或者服务正在上线而超时,可以自动降级;

(2)警告:有些服务在一段时间内成功率有波动(如在95~100%之间),可以自动降级或人工降级,并发送告警;

(3)错误:比如可用率低于90%,或者数据库连接池被打爆了,或者访问量突然猛增到系统能承受的***阀值,此时可以根据情况自动降级或者人工降级;

(4)严重错误:比如因为特殊原因数据错误了,此时需要紧急人工降级。

分布式应用之分布式缓存相关推荐

  1. 在ASP.NET Core应用程序中使用分布式缓存

    本文要点 ASP.NET Core内置了分布式缓存接口. 分布式缓存的主要好处有性能.数据共享和稳定性. Couchbase服务器是一个内存优先的数据库,非常适合作为分布式缓存. NuGet程序包使得 ...

  2. Apache Ignite——集合分布式缓存、计算、存储的分布式框架

    Apache Ignite内存数据组织平台是一个高性能.集成化.混合式的企业级分布式架构解决方案,核心价值在于可以帮助我们实现分布式架构透明化,开发人员根本不知道分布式技术的存在,可以使分布式缓存.计 ...

  3. Redis 分布式缓存 Java 框架

    https://dzone.com/articles/java-distributed-caching-in-redis 为什么要在 Java 分布式应用程序中使用缓存? 在提高应用程序速度和性能上, ...

  4. 一致性哈希算法在分布式缓存中的应用

    一.应用场景 假设我们有一个网站,最近发现随着流量增加,服务器压力越来越大,之前直接读写数据库的方式不太给力了,于是我们想引入Redis作为缓存机制.现在我们一共有三台机器可以作为Redis服务器,如 ...

  5. EhCache 分布式缓存/缓存集群

    开发环境: System:Windows JavaEE Server:tomcat5.0.2.8.tomcat6 JavaSDK: jdk6+ IDE:eclipse.MyEclipse 6.6 开发 ...

  6. 分布式缓存存储算法与实践思考

    最近遇到一个问题,可能很多人也遇到过:由于业务量的增长,缓存节点个数不够用了.现在的Redis-Cluster直接就加个节点就解决了,但是之前Redis-Cluster不稳定时,我们并不敢用这个,而是 ...

  7. 第五阶段-第五阶段高性能分布式缓存Redis

    第五阶段 大型分布式系统缓存架构进阶 文章目录 第五阶段 大型分布式系统缓存架构进阶 第一部分 Redis 快速实战 第一节 缓存原理与设计 1.1 缓存基本思想 1.11 缓存的使用场景 1.12 ...

  8. Terracotta 分布式缓存机制深入

    Terracotta已收购Ehcache 数据缓存:(无缝集成,代码注入方式,不需修改原代码) Terracotta 功能(JVM级POJO集群):DSO(jvm本地线程加锁外,JVM集群上加排它锁) ...

  9. 大数据【四】MapReduce(单词计数;二次排序;计数器;join;分布式缓存)

       前言: 根据前面的几篇博客学习,现在可以进行MapReduce学习了.本篇博客首先阐述了MapReduce的概念及使用原理,其次直接从五个实验中实践学习(单词计数,二次排序,计数器,join,分 ...

  10. 分布式缓存灵魂十连,你能坚持几个?

    点击上方蓝色"方志朋",选择"设为星标" 回复"666"获取独家整理的学习资料! 目录 前言 目前工作中用到的分布式缓存技术有redis和m ...

最新文章

  1. Swift学习总结【持续更新】
  2. 首款移动社交购物平台“商宝”上线发布
  3. c语言程序框一点数字就消失,你用C语言编程时,会犯下面的错误吗?
  4. linux脚本--输出占用内存最多的进程ID
  5. python如何测试仪器_如何测试pytest设备本身?
  6. 掌握神经网络模型的快捷方式
  7. Asp.net MVC使用Filter解除Session, Cookie等依赖
  8. 将动态路由、布局和RouteViews添加到Blazor应用程序组件
  9. 【Luogu1095】守望者的逃离
  10. pcb 布线电容 影响延时_浅谈PCB布局布线对TVS防护效果的影响
  11. 基于二进制粒子群算法的背包问题求解- 附代码
  12. c语言单链表怎么循环链表,链表之循环单链表(用C语言描述)
  13. python简明教程_07
  14. 第1-6课:绘制箱线图、饼图和直方图
  15. Zookeeper kick off
  16. Spring之DI依赖注入
  17. 微信公众号发红包 php,php微信公众号接口实现发红包的方法
  18. html怎么用wps打开pdf文件,怎么使用电脑wps对PDF文件进行修改
  19. 亚马逊云科技赋能全新基于云的安全SaaS平台——安智联365
  20. PMP-PMBOK图解项目管理(436页PPT、完整版-经典)

热门文章

  1. 【NOIP2015普及组】推销员
  2. JMeter之Ramp-up Period(in seconds)说明
  3. CSS3实现360度循环旋转
  4. Graylog 3.3.8安装笔记(yum,docker,docker-compose)
  5. c++ 11 原子操作库 (std::atomic)(三)
  6. python是猿辅导还是学而思_综合分析:猿辅导和学而思对比选哪个好,我的亲身感受...
  7. 树莓派chromium代理设置
  8. 一个漏洞潜伏54年?谁才是“潜伏界”最强王者
  9. 脸上经常长青春痘痘的青年应该多吃的食物
  10. warning: control reaches end of non-void function [-Wreturn-type]