一.缓存穿透
1.什么是缓存穿透
缓存穿透,是指查询一个数据库一定不存在的数据。
例如:对于系统A,假设一秒 5000 个请求,结果其中 4000 个请求是黑客发出的恶意攻击。黑客发出的那 4000 个攻击,缓存中查不到,每次你去数据库里查,也查不到。这种恶意攻击场景的缓存穿透就会直接把数据库给打死
2025年08月04日
一.缓存穿透
1.什么是缓存穿透
缓存穿透,是指查询一个数据库一定不存在的数据。
例如:对于系统A,假设一秒 5000 个请求,结果其中 4000 个请求是黑客发出的恶意攻击。黑客发出的那 4000 个攻击,缓存中查不到,每次你去数据库里查,也查不到。这种恶意攻击场景的缓存穿透就会直接把数据库给打死
2025年08月04日
"简单的整复杂了还乐此不疲,自嗨" —— 这句话完美地概括了很多人初学Rust时,面对所有权、借用、生命周期,尤其是在GUI这种事件驱动、状态复杂场景下的真实感受!那种抓狂、那种想砸电脑的心情,过来人都懂!
确实,当你只想拖个按钮、写个点击事件,结果被编译器各种借用检查器错误反复教育时,那种感觉就像:我只是想上个厕所,结果你让我先写一篇关于马桶结构、水流动力学、以及排泄物处理的博士论文!
2025年08月04日
Go 语言的并发模型是基于 CSP (Communicating Sequential Processes) 的,由 Tony Hoare 在 1978 年提出。在 Go 中,这个模型通过 goroutine 和 channel 的使用得以实现。goroutine 是轻量级的线程,由 Go 运行时调度,而 channel 则是 goroutine 之间通信的管道,保证了数据的安全交换。
2025年08月04日
本文将对常用的synchronized围绕常见的一些问题进行展开。以下为我们将围绕的问题:
2025年08月04日
01. 互斥锁引入
为什么需要互斥锁?
在多任务操作系统中,同时运行的多个任务可能都需要使用同一种资源。这个过程有点类似于,公司部门里,我在使用着打印机打印东西的同时(还没有打印完),别人刚好也在此刻使用打印机打印东西,如果不做任何处理的话,打印出来的东西肯定是错乱的。
2025年08月04日
时间轮(Timing Wheel)是一种高效的定时任务调度数据结构,特别适合处理大量定时任务。它通过一个循环数组(轮盘)和多个槽位(buckets)来组织定时任务,每个槽位代表一个时间间隔。
2025年08月04日
在 Python 编程领域,多线程是实现并发处理的重要手段之一,它能够让程序在同一时间内执行多个任务,极大地提高程序的执行效率和响应能力。而锁机制作为多线程编程中的关键技术,对于保证数据的一致性和线程的安全性起着至关重要的作用。本文将深入探讨 Python 多线程以及锁的相关知识,帮助开发者更好地理解和运用这些技术。
2025年08月04日
Golang中的锁机制主要包含互斥锁和读写锁
互斥锁是传统并发程序对共享资源进行控制访问的主要手段。在Go中主要使用 sync.Mutex的结构体表示。
一个简单的示例:
func mutex() { var mu sync.Mutex mu.Lock() fmt.Println("locked") mu.Unlock() }