网站建设需要的图片怎么弄/seo顾问服务公司

网站建设需要的图片怎么弄,seo顾问服务公司,温州网站建设设计,在哪个网站做视频可以赚钱缓存使用场景、一致性及常见问题解析 一、缓存的核心使用场景 1. 高频读、低频写场景 典型场景:商品详情页、新闻资讯、用户基本信息。特点:数据更新频率低,但访问量极高。策略: Cache-Aside(旁路缓存)&a…

缓存使用场景、一致性及常见问题解析


一、缓存的核心使用场景
1. 高频读、低频写场景
  • 典型场景:商品详情页、新闻资讯、用户基本信息。
  • 特点:数据更新频率低,但访问量极高。
  • 策略
    • Cache-Aside(旁路缓存):优先读缓存,未命中时查数据库并回填。
    • TTL(过期时间):设置合理过期时间(如5分钟),平衡数据新鲜度与缓存命中率。

示例

public Product getProduct(String id) {Product product = cache.get(id);if (product == null) {product = db.query("SELECT * FROM product WHERE id = ?", id);cache.set(id, product, 300); // 缓存5分钟}return product;
}
2. 热点数据加速
  • 典型场景:微博热搜、秒杀活动倒计时、直播在线人数。
  • 特点:短时间内流量突增,需快速响应。
  • 策略
    • 本地缓存 + 分布式缓存:如Guava Cache + Redis,减少网络开销。
    • Key分片:将热点Key分散到多个节点(如hot:item:123hot:item:123_{shardId})。
3. 复杂计算缓存
  • 典型场景:排行榜、聚合统计结果(如用户总积分)。
  • 特点:计算成本高,结果可复用。
  • 策略
    • 预计算+定时更新:定时任务生成结果并缓存。
    • Write-Through(直写):数据变更时同步更新缓存。
4. 会话与状态管理
  • 典型场景:用户登录状态、购物车信息。
  • 特点:临时性数据,读写频繁。
  • 策略
    • Redis Session存储:集中管理会话,支持分布式扩展。
    • TTL自动清理:设置会话过期时间(如30分钟)。

二、缓存一致性问题及解决方案
1. 一致性问题的根源
  • 数据源多副本:缓存与数据库存在两份数据。
  • 并发操作:多线程/多节点同时修改数据。
  • 网络延迟:缓存与数据库更新不同步。
2. 典型场景与解决方案
场景问题描述解决方案
先更新数据库,后删缓存删除缓存失败,后续请求读到旧数据。延迟双删:更新数据库 → 删除缓存 → 延迟几百毫秒再删一次。
先删缓存,后更新数据库删缓存后、更新数据库前,其他请求可能读到旧值并回填缓存。异步重试:删除缓存后,通过消息队列确保数据库更新成功,否则重试删除操作。
并发写导致覆盖多个线程同时更新同一数据,缓存与数据库不一致。分布式锁:更新时加锁(如Redis SETNX),串行化操作。

示例:延迟双删伪代码

public void updateProduct(Product product) {// 1. 更新数据库db.update(product);// 2. 删除缓存cache.delete(product.getId());// 3. 延迟再次删除(应对并发场景)executor.schedule(() -> cache.delete(product.getId()), 500, TimeUnit.MILLISECONDS);
}
3. 最终一致性方案
  • Binlog监听:通过Canal监听数据库变更,异步更新缓存。
  • 消息队列:数据库变更后发送MQ消息,消费者更新缓存。

三、缓存常见问题与应对策略
1. 缓存穿透(Cache Penetration)
  • 问题:大量请求查询不存在的数据(如无效ID),绕过缓存直接访问数据库。
  • 解决
    • 布隆过滤器(Bloom Filter):预存所有合法Key,拦截非法请求。
    • 缓存空值:对不存在的数据缓存NULL并设置短TTL(如30秒)。

示例

public Product getProduct(String id) {Product product = cache.get(id);if (product != null) {return product;}if (bloomFilter.mightContain(id)) { // 布隆过滤器检查product = db.query("SELECT * FROM product WHERE id = ?", id);if (product != null) {cache.set(id, product, 300);} else {cache.set(id, NULL, 30); // 缓存空值}}return product;
}
2. 缓存雪崩(Cache Avalanche)
  • 问题:大量缓存同时失效,请求直接冲击数据库。
  • 解决
    • 随机过期时间:在基础TTL上增加随机值(如TTL + random(0, 300))。
    • 热点数据永不过期:后台定时异步更新缓存。
3. 缓存击穿(Cache Breakdown)
  • 问题:热点Key过期瞬间,大量并发请求直达数据库。
  • 解决
    • 互斥锁(Mutex Lock):第一个请求重建缓存时加锁,其他请求等待。
    • 逻辑过期:缓存Value包含逻辑过期时间,异步刷新。

示例:互斥锁实现

public Product getProduct(String id) {Product product = cache.get(id);if (product == null) {Lock lock = redisLock.lock(id); // 获取分布式锁try {product = cache.get(id); // 双重检查if (product == null) {product = db.query("SELECT * FROM product WHERE id = ?", id);cache.set(id, product, 300);}} finally {redisLock.unlock(id);}}return product;
}
4. 数据漂移(Hot Key 不均)
  • 问题:某个节点缓存过多热点Key,导致负载不均。
  • 解决
    • 本地缓存:在应用层缓存热点数据,减少访问分布式缓存。
    • Key分片:将热点Key分散到多个节点(如product:123product:123_{shardId})。

四、缓存策略选择
策略适用场景优点缺点
Cache-Aside通用场景,需强一致性控制灵活,缓存与数据库解耦需处理一致性问题
Read-Through缓存作为主要数据源简化代码,自动加载数据缓存层需支持加载逻辑
Write-Through写操作频繁且需强一致性数据更新实时同步写延迟较高
Write-Behind高吞吐写场景(如日志记录)写性能高,批量更新数据库数据可能丢失(未持久化前宕机)

🐮🐎

  • 使用场景:缓存适用于读多写少、热点数据、复杂计算等场景,显著提升系统性能。
  • 一致性问题:通过延迟双删、异步消息、分布式锁等方案平衡性能与一致性。
  • 常见问题:穿透、雪崩、击穿需针对性设计防御策略(布隆过滤器、随机TTL、互斥锁)。
    合理选择缓存策略,结合监控与动态调优,可最大化缓存收益并规避潜在风险。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/73296.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

谷歌 Gemini 2.0 Flash实测:1条指令自动出图+配故事!

今天看到很多人夸Gemini 2.0 Flash的能力很强。 强大的P图能力,改背景、换衣服、调整姿态、表情控制等等 其中最让人眼前一亮的是图文功能。 它不仅是理解图文,而是能根据文字描述创作出一整个的故事、步骤图文。 我上手试了一下,感觉效果…

雷电模拟器连接Android Studio步骤

打开雷电模拟器,点击桌面系统应用—>打开设置—>关于平板电脑→连续点击5次版本号,会出现开发者选项—->进入开发者选项—->勾选打开usb调试。 命令行提示符,进入雷电模拟器安装目录。然后执行 Plain Text adb.exe connect 127.0…

配置普通链接二维码规则 校验文件检查失败

配置普通链接二维码规则 校验文件检查失败 1.问题 2.解决思路: 直接访问地址,不跳转文本,感觉是nginx配置问题打开服务器nginx 域名默认走80端口,配置了指定的访问路径,命令行 nginx -t ,nginx -s reload,start ngin…

c语言经典基础编程题

c语言经典基础编程题 一、输出输出1.1温度输出1.2排齐数据1.3进制转换 二、选择分支2.1求最大值2.2成绩评定2.3分段函数求值2.4 利润计算2.5判断闰年2.6二次方程根 三、循环结构3.1倒数求和3.2最大数3.3判断素数3.4判断完全数3.5打印菱形🚀🚀&#x1f68…

安全的实现数据备份和恢复

📕我是廖志伟,一名Java开发工程师、《Java项目实战——深入理解大型互联网企业通用技术》(基础篇)、(进阶篇)、(架构篇)清华大学出版社签约作家、Java领域优质创作者、CSDN博客专家、…

OpenMCU(三):STM32F103 FreeRTOS移植

概述 本文主要描述了STM32F103移植FreeRTOS的简要步骤。移植描述过程中,忽略了Keil软件的部分使用技巧。默认读者熟练使用Keil软件。本文的描述是基于OpenMCU_RTOS这个工程,该工程已经下载放好了移植STM32F103 FreeRTOS的所有文件 OpenMCU_RTOS工程的愿景…

生成对抗网络(GAN)原理与应用

目录 一、引言 二、GAN的基本原理 (一)生成器(Generator)的工作机制 (二)判别器(Discriminator)的工作机制 (三)对抗训练的过程 三、GAN在AIGC生图中的应…

STM32 内置的通讯协议

数据是以帧为单位发的 USART和UART的区别就是有没有同步功能 同步是两端设备有时钟连接,异步是没时钟连接,靠约定号的频率(波特率)接收发送数据 RTS和CTS是用来给外界发送已“可接收”或“可发送”信号的,一般用不到…

Appium等待机制--强制等待、隐式等待、显式等待

书接上回,Appium高级操作--其他操作-CSDN博客文章浏览阅读182次,点赞6次,收藏7次。书接上回Appium高级操作--从源码角度解析--模拟复杂手势操作-CSDN博客。https://blog.csdn.net/fantasy_4/article/details/146162851主要讲解了Appium的一些…

NFS实验配置笔记

NFS NFS服务 nfs,最早是Sun这家公司所发展出来的,它最大的功能就是可以透过网络,让不同的机器,不同的操作系统,进行实现文档的共享。所以你可以简单的将他看做是文件服务器。 实验准备 ①先准备一个服务器端的操作…

深度学习|MAE技术全景图:自监督学习的“掩码魔法“如何重塑AI基础

一、引言:深度学习的困境与自监督的曙光 深度学习(Deep Learning)无疑是当今人工智能领域基础中的基础。从图像识别到自然语言处理(NLP),它在无数任务中展现了卓越性能。例如,在安防监控中&…

【SpringBoot】实现登录功能

在上一篇博客中,我们讲解了注册页面的实现。在此基础上会跳转到登录页面,今天给大家带来的是使用 SpringBoot,MyBatis,Html,CSS,JavaScript,前后端交互实现一个登录功能。 目录 一、效果 二、…

mingw工具源码编译

ming-w64 mingw编译生成的库,需要mingw的lib文件支持。 https://github.com/mingw-w64/mingw-w64 使用msys2的bash git checkout v8.0.3 ./configure --disable-dependency-tracking --targetx86_64-w64-mingw32 mingw32-make.exe -j4 修改makefile中的make 改成mi…

LSTM方法实践——基于LSTM的汽车销量时序建模与预测分析

Hi,大家好,我是半亩花海。本实验基于汽车销量时序数据,使用LSTM网络(长短期记忆网络)构建时间序列预测模型。通过数据预处理、模型训练与评估等完整流程,验证LSTM在短期时序预测中的有效性。 目录 一、实验…

Stable Diffusion教程|快速入门SD绘画原理与安装

什么是Stable Diffusion,什么是炼丹师?根据市场研究机构预测,到2025年全球AI绘画市场规模将达到100亿美元,其中Stable Diffusion(简称SD)作为一种先进的图像生成技术之一,市场份额也在不断增长&…

Webpack构建流程详解优化前端性能\Dev-Server与Proxy\网络攻击\HMR

简版 核心流程图 根据,Webpack的构建流程分为初始化、编译和输出三个阶段。初始化阶段读取配置、加载插件、实例化Compiler。编译阶段(构建依赖关系)涉及Compiler类的运行,生成Compilation对象,处理模块依赖。输出阶…

零成本搭建Calibre个人数字图书馆支持EPUB MOBI格式远程直读

文章目录 前言1.网络书库软件下载安装2.网络书库服务器设置3.内网穿透工具设置4.公网使用kindle访问内网私人书库 前言 嘿,各位书虫们!今天要给大家安利一个超级炫酷的技能——如何在本地Windows电脑上搭建自己的私人云端书库。亚马逊服务停了&#xff…

【Linux 指北】常用 Linux 指令汇总

第一章、常用基本指令 # 注意: # #表示管理员 # $表示普通用户 [rootlocalhost Practice]# 说明此处表示管理员01. ls 指令 语法: ls [选项][目录或文件] 功能:对于目录,该命令列出该目录下的所有子目录与文件。对于文件&#xf…

跟踪napi_gro_receive_entry时IP头信息缺失的分析

问题描述 在使用eBPF程序跟踪napi_gro_receive_entry内核跟踪点时,发现获取到的IP头部字段(如saddr、daddr、protocol)为空值。 代码如下: /* 自定义结构体来映射 napi_gro_receive_entry tracepoint 的 format */ struct napi…

Android子线程更新View的方法原理

对于所有的Android开发者来说,“View的更新必须在UI线程中进行”是一项最基本常识。 如果不在UI线程中更新View,系统会抛出CalledFromWrongThreadException异常。那么有没有什么办法可以不在UI线程中更新View?答案当然是有的! 一…