设计模式-特例

文章探讨了在高并发场景下如何设计文章浏览量的计数系统,使用面向对象原则封装ID和readCount字段,利用Redis的HyperLogLog进行IP+文章ID的计数,通过切面自增并在每日固定时间持久化数据到数据库,确保数据准确且降低对数据库的压力。
摘要由CSDN通过智能技术生成

面向对象

高并发 自增 - 文章浏览量设计

// 生成 get/set
@Data 
Article{  
// 面向对象封装-id 只设置一次不该set。
// 但如果框架生成ID,则必须set
private String id;  
// 低耦合高内聚- 自增逻辑置于实体内
// 但自增值暂存与实体分离,没必要内聚
// 注意:实体内的字段,不要默认值。如果前端只传更新的字段,默认之会更新到库内,覆盖客户选值。
private Long readCount;
}

计数维度:IP + 文章ID
计数方式:Redis HyperLogLog | Redis
代码设计:GetMapping 获取文章时,切面自增计数
数据持久化方式:每日 23:30:00 定时保存到数据库,删除缓存
从SpringBoot构建十万博文聊聊高并发文章浏览量设计 (qq.com)2019-08-19

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值