返回顶部
首页 > 资讯 > 精选 >深入理解分布式系统中的缓存架构(上)
  • 539
分享到

深入理解分布式系统中的缓存架构(上)

2023-06-02 21:06:13 539人浏览 安东尼
摘要

本文主要介绍大型分布式系统中缓存的相关理论,常见的缓存组件以及应用场景。1 缓存概述缓存概述2 缓存的分类缓存主要分为以下四类缓存的分类1 CDN缓存基本介绍CDN(Content Delivery Network 内容分发网络)的基本原理

本文主要介绍大型分布式系统缓存的相关理论,常见的缓存组件以及应用场景。

1 缓存概述

深入理解分布式系统中的缓存架构(上)

缓存概述

2 缓存的分类

缓存主要分为以下四类

深入理解分布式系统中的缓存架构(上)

缓存的分类

1 CDN缓存

基本介绍

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

应用场景

主要缓存静态资源,例如图片,视频

应用图

深入理解分布式系统中的缓存架构(上)

未使用CDN缓存

深入理解分布式系统中的缓存架构(上)

使用CDN缓存

优点

深入理解分布式系统中的缓存架构(上)

优点

2 反向代理缓存

基本介绍

反向代理位于应用服务器机房,处理所有对WEB服务器的请求。

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

应用场景

一般只缓存体积较小静态文件资源,如CSSjs、图片

应用图

深入理解分布式系统中的缓存架构(上)

反向代理缓存应用图

开源实现

深入理解分布式系统中的缓存架构(上)

开源实现

3 本地应用缓存

基本介绍

指的是在应用中的缓存组件,其最大的优点是应用和cache是在同一个进程内部,请求缓存非常快速,没有过多的网络开销等,在单应用不需要集群支持或者集群情况下各节点无需互相通知的场景下使用本地缓存较合适;

同时,它的缺点也是应为缓存跟应用程序耦合,多个应用程序无法直接的共享缓存,各应用或集群的各节点都需要维护自己的单独缓存,对内存是一种浪费。

应用场景

缓存字典等常用数据

缓存介质

深入理解分布式系统中的缓存架构(上)

缓存介质

实现

编程直接实现

深入理解分布式系统中的缓存架构(上)

编程直接实现

Ehcache

基本介绍

Ehcache是??一种基于标准的开源缓存,可提高性能,卸载数据库并简化可伸缩性。

它是使用最广泛的基于Java的缓存,因为它功能强大,经过验证,功能齐全,并与其他流行的库和框架集成。Ehcache可以从进程内缓存扩展到使用TB级缓存的混合进程内/进程外部署

应用场景

深入理解分布式系统中的缓存架构(上)

Ehcache应用场景

Ehcache架构

深入理解分布式系统中的缓存架构(上)

Ehcache架构图

Ehcache主要特征

深入理解分布式系统中的缓存架构(上)

Ehcache主要特征

Ehcache缓存数据过期策略

深入理解分布式系统中的缓存架构(上)

缓存数据过期策略.png

Ehcache过期数据淘汰机制

懒淘汰机制:每次往缓存放入数据的时候,都会存一个时间,在读取的时候要和设置的时间做TTL比较来判断是否过期

Guava Cache

4 分布式缓存

基本介绍

Guava Cache是Google开源的Java重用工具集库Guava里的一款缓存工具

特点与功能

深入理解分布式系统中的缓存架构(上)

Guava Cache特点与功能.png

应用场景

深入理解分布式系统中的缓存架构(上)

Guava Cache应用场景.png

数据结构

深入理解分布式系统中的缓存架构(上)

Guava Cache数据结构图

深入理解分布式系统中的缓存架构(上)

Guava Cache结构特点.png

缓存更新策略

深入理解分布式系统中的缓存架构(上)

Guava Cache 缓存更新策略

缓存回收策略

深入理解分布式系统中的缓存架构(上)

Guava Cache缓存回收策略.png

4 分布式缓存

指的是与应用分离的缓存组件或服务,其最大的优点是自身就是一个独立的应用,与本地应用隔离,多个应用可直接的共享缓存。

主要应用场景

深入理解分布式系统中的缓存架构(上)

分布式缓存应用场景.png

主要接入方式

深入理解分布式系统中的缓存架构(上)

分布式缓存接入方式.png

下面介绍分布式缓存常见的2大开源实现Memcached和Redis

Memcached

基本介绍

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

特点

深入理解分布式系统中的缓存架构(上)

Memcached特点

基本架构

深入理解分布式系统中的缓存架构(上)

Memcached基本架构

缓存数据过期策略

LRU(最近最少使用)到期失效策略,在Memcached内存储数据项时,可以指定它在缓存的失效时间,默认为永久。当Memcached服务器用完分配的内时,失效的数据被首先替换,然后也是最近未使用的数据。

数据淘汰内部实现

懒淘汰机制:每次往缓存放入数据的时候,都会存一个时间,在读取

的时候要和设置的时间做TTL比较来判断是否过期

分布式集群实现

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

深入理解分布式系统中的缓存架构(上)

数据读写流程图

深入理解分布式系统中的缓存架构(上)

Memcached分布式集群实现

Redis

基本介绍

Redis是一个远程内存数据库(非关系型数据库),性能强劲,具有复制特性以及解决问题而生的独一无二的数据模型。它可以存储键值对与5种不同类型的值之间的映射,可以将存储在内存的键值对数据持久化到硬盘,可以使用复制特性来扩展读性能,

Redis还可以使用客户端分片来扩展写性能。内置了 复制(replication),lua脚本(Lua scripting),LRU驱动事件(LRU eviction),事务(transactions) 和不同级别的 磁盘持久化(persistence), 并通过 Redis哨兵(Sentinel)和自动分区(Cluster)提供高可用性(high availability)。

数据模型

深入理解分布式系统中的缓存架构(上)

Redis数据模型

数据淘汰策略

深入理解分布式系统中的缓存架构(上)

Redis数据淘汰策略

数据淘汰内部实现

深入理解分布式系统中的缓存架构(上)

Redis数据淘汰内部实现.png

持久化方式

深入理解分布式系统中的缓存架构(上)

Redis持久化方式

底层实现部分解析

启动的部分过程图解

深入理解分布式系统中的缓存架构(上)

启动的部分过程

server端持久化的部分操作图解

深入理解分布式系统中的缓存架构(上)

server端持久化的部分操作

底层哈希表实现(渐进式Rehash)

初始化字典

深入理解分布式系统中的缓存架构(上)

初始化字典

新增字典元素图解

深入理解分布式系统中的缓存架构(上)

新增字典元素图解

Rehash执行流程

深入理解分布式系统中的缓存架构(上)

Rehash执行流程

缓存设计原则

深入理解分布式系统中的缓存架构(上)

Redis缓存设计原则.png

迎工作一到五年的Java工程师朋友们加入Java架构开发:860113481

群内提供免费的Java架构学习资料(里面有高可用、高并发、高性能及分布式、JVM性能调优、Spring源码mybatisNetty,Redis,kafka,Mysql,ZooKeeper,Tomcat,Docker,dubbo,Nginx等多个知识点的架构资料)合理利用自己每一分每一秒的时间来学习提升自己,不要再用"没有时间“来掩饰自己思想上的懒惰!趁年轻,使劲拼,给未来的自己一个交代!

Redis与Memcached比较

深入理解分布式系统中的缓存架构(上)

深入理解分布式系统中的缓存架构(上)

--结束END--

本文标题: 深入理解分布式系统中的缓存架构(上)

本文链接: https://lsjlt.com/news/231352.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 深入理解分布式系统中的缓存架构(上)
    本文主要介绍大型分布式系统中缓存的相关理论,常见的缓存组件以及应用场景。1 缓存概述缓存概述2 缓存的分类缓存主要分为以下四类缓存的分类1 CDN缓存基本介绍CDN(Content Delivery Network 内容分发网络)的基本原理...
    99+
    2023-06-02
  • 分布式系统中的缓存架构如何实现?
    分布式系统中的缓存架构如何实现? 在分布式系统中,缓存被广泛应用于提高系统性能和减少数据访问延迟。缓存是一种用于存储和管理数据的技术,它可以将数据存储在快速存储介质中,以便快速访问和检索。在这篇文章中,我们将探讨分布式系统中的缓存架构如何实...
    99+
    2023-10-05
    缓存 分布式 编程算法
  • 架构解析:Go WaitGroup在分布式系统中的应用
    在分布式系统中,Go的WaitGroup可以用于协调并发任务的执行。WaitGroup是一个计数信号量,可以用于等待一组并发任务完成...
    99+
    2023-10-08
    Golang
  • php中的分布式架构怎么理解
    这篇“php中的分布式架构怎么理解”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“php中的分布式架构怎么理解”文章吧。在PH...
    99+
    2023-06-29
  • PHP 分布式架构中的缓存优化:如何提高并发处理能力?
    PHP分布式架构中的缓存优化:如何提高并发处理能力? 在现代的大型Web应用程序中,处理并发请求是一个非常重要的问题。为了满足大量请求的需求,许多应用程序都采用了分布式架构,其中缓存是一个非常重要的组成部分。在本文中,我们将讨论如何在PHP...
    99+
    2023-09-22
    分布式 并发 缓存
  • PHP 分布式架构中的并发问题与缓存优化探究
    随着互联网的快速发展,分布式架构已成为众多企业的首选架构方式。而在分布式架构中,如何解决并发问题和优化缓存成为了一个需要重点关注的问题。本文将深入探究 PHP 分布式架构中的并发问题与缓存优化,帮助读者更好地理解和应用这些技术。 一、并发...
    99+
    2023-09-22
    分布式 并发 缓存
  • 详解Java分布式缓存系统中必须解决的四大问题
    目录缓存穿透缓存击穿缓存雪崩缓存一致性分布式缓存系统是三高架构中不可或缺的部分,极大地提高了整个项目的并发量、响应速度,但它也带来了新的需要解决的问题,分别是: 缓存穿透、缓存击穿、...
    99+
    2024-04-02
  • 深入理解分布式之数据库和缓存双写一致性方案解析
    引言 为什么写这篇文章? 首先,缓存由于其高并发和高性能的特性,已经在项目中被广泛使用。在读取缓存方面,大家没啥疑问,都是按照下图的流程来进行业务操作。 但是在更新缓存方面,对于...
    99+
    2024-04-02
  • 深入了解PHP缓存:分布式接口的实现方法和技巧
    PHP缓存作为一种优化方式已经被广泛使用,尤其是在分布式接口系统中,缓存的使用更是不可或缺。本文将深入介绍PHP缓存在分布式接口中的实现方法和技巧。 一、基本概念 在介绍PHP缓存之前,我们需要先了解一些基本概念。 缓存 缓存是指将一些...
    99+
    2023-09-06
    缓存 分布式 接口
  • PHP 缓存技术在分布式系统中的应用研究
    随着互联网的快速发展,分布式系统的应用越来越广泛。在分布式系统中,如何快速响应用户请求成为了一个重要的问题。PHP 缓存技术可以有效地提高系统的响应速度和性能。本文将介绍 。 一、什么是 PHP 缓存技术? PHP 缓存技术是指将 PHP...
    99+
    2023-09-22
    分布式 并发 缓存
  • 如何在分布式系统中保证缓存的一致性?
    随着分布式系统的不断发展,缓存的使用越来越普遍。但是,缓存的一致性问题也越来越受到关注。在分布式系统中,缓存的一致性是非常关键的一个问题,因为缓存的一致性直接影响到系统的性能和可靠性。本文将介绍如何在分布式系统中保证缓存的一致性。 一、缓存...
    99+
    2023-10-05
    缓存 分布式 编程算法
  • 服务器中分布式系统缓存的特征是什么
    本篇内容介绍了“服务器中分布式系统缓存的特征是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1、缓存的意义说到分布式系统基本上就离不开缓...
    99+
    2023-06-04
  • GO语言分布式系统架构设计,你了解吗?
    随着互联网的快速发展,分布式系统逐渐成为了现代软件开发中的热门话题。GO语言是一门高效、强类型、支持并发编程的开源编程语言,由于其天生的并发能力,越来越多的开发者开始使用GO语言来构建分布式系统。在本文中,我们将探讨GO语言分布式系统的架...
    99+
    2023-06-29
    分布式 面试 教程
  • 深度解析:主流分布式架构的前世今生
    【本文转自博客园  作者:阿豪聊干货  原文链接:https://www.cnblogs.com/hafiz/p/9236664.html】一、前言...
    99+
    2023-06-05
  • 如何理解java中的分布式系统
    要理解分布式系统,主要需要明白一下2个方面:1、分布式系统一定是由多个节点组成的系统。其中,节点指的是计算机服务器,而且这些节点一般不是孤立的,而是互通的。2、这些连通的节点上部署了我们的节点,并且相互的操作会有协同。分布式系统对于用户而言...
    99+
    2015-12-03
    java基础 java 分布式系统 理解
  • PHP 微服务架构:解锁分布式系统的强大力量
    什么是 PHP 微服务架构? PHP 微服务架构是一种将大型单体应用程序分解为一组较小的、相互独立的服务的体系结构。这些服务称为微服务,每个服务都负责应用程序的特定功能。微服务通常通过轻量级协议(如 HTTP 或 gRPC)进行通信。 ...
    99+
    2024-02-16
    PHP 微服务 分布式系统 可扩展性 敏捷性 可靠性
  • 分布式与服务化的ERP系统架构设计分析
    本篇内容主要讲解“分布式与服务化的ERP系统架构设计分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“分布式与服务化的ERP系统架构设计分析”吧!ERP之痛曾几何时,我混迹于电商、珠宝行业4年多...
    99+
    2023-06-02
  • Java分布式缓存系统中必须解决的四大问题是什么
    这篇文章主要介绍了Java分布式缓存系统中必须解决的四大问题是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Java分布式缓存系统中必须解决的四大问题是什么文章都会有所收获,下面我们一起来看看吧。分布式缓存...
    99+
    2023-06-30
  • kafka分布式消息系统基本架构及功能详解
    目录什么是Kafka一、Kafka的基本功能二、Kafka基本架构三、Kafka的实现方法1 发布/订阅模式2 分区四、Kafka的优势和劣势优势劣势Kafka的部署方法Kafka的...
    99+
    2023-03-03
    kafka分布式消息系统架构 kafka 分布式
  • 分布式 - 服务器Nginx:一小时入门系列之代理缓冲与缓存
    官方文档:https://nginx.org/en/docs/http/ngx_http_proxy_module.html 1. 代理缓冲 proxy_buffer 代理缓冲用于临时存储从后端服务器返回的响应数据。通过使用代理缓冲,Ngi...
    99+
    2023-08-20
    分布式 服务器 nginx
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作