每日一题之 高并发系统

2年前 (2022) 程序员胖胖胖虎阿
215 0 0

点击上方 Java后端选择 设为星标

优质文章,及时送达


高并发系统的设计与实现

在开发高并发系统时有三把利器用来保护系统:缓存、降级和限流。
  • 缓存:缓存比较好理解,在大型高并发系统中,如果没有缓存数据库将分分钟被爆,系统也会瞬间瘫痪。使用缓存不单单能够提升系统访问速度、提高并发访问量,也是保护数据库、保护系统的有效方式。大型网站一般主要是“读”,缓存的使用很容易被想到。在大型“写”系统中,缓存也常常扮演者非常重要的角色。比如累积一些数据批量写入,内存里面的缓存队列(生产消费),以及HBase写数据的机制等等也都是通过缓存提升系统的吞吐量或者实现系统的保护措施。甚至消息中间件,你也可以认为是一种分布式的数据缓存。
  • 降级:服务降级是当服务器压力剧增的情况下,根据当前业务情况及流量对一些服务和页面有策略的降级,以此释放服务器资源以保证核心任务的正常运行。降级往往会指定不同的级别,面临不同的异常等级执行不同的处理。根据服务方式:可以拒接服务,可以延迟服务,也有时候可以随机服务。根据服务范围:可以砍掉某个功能,也可以砍掉某些模块。总之服务降级需要根据不同的业务需求采用不同的降级策略。主要的目的就是服务虽然有损但是总比没有好。
  • 限流:限流可以认为服务降级的一种,限流就是限制系统的输入和输出流量已达到保护系统的目的。一般来说系统的吞吐量是可以被测算的,为了保证系统的稳定运行,一旦达到的需要限制的阈值,就需要限制流量并采取一些措施以完成限制流量的目的。比如:延迟处理,拒绝处理,或者部分拒绝处理等等。

负载均衡算法:

  1. 轮询
  2. 加权轮询
  3. 随机算法
  4. 一致性Hash
常见的限流算法:


常见的限流算法有计数器、漏桶和令牌桶算法。漏桶算法在分布式环境中消息中间件或者Redis都是可选的方案。发放令牌的频率增加可以提升整体数据处理的速度,而通过每次获取令牌的个数增加或者放慢令牌的发放速度和降低整体数据处理速度。而漏桶不行,因为它的流出速率是固定的,程序处理速度也是固定的。
秒杀并发情况下库存为负数问题
  1. for update显示加锁
  2. 把update语句写在前边,先把数量-1,之后select出库存如果>-1就commit,否则rollback。
  
  
  
update products set quantity = quantity-1 WHERE id=3;
select quantity from products WHERE id=3 for update;
  1. update语句在更新的同时加上一个条件
  
  
  
quantity = select quantity from products WHERE id=3;
update products set quantity = ($quantity-1) WHERE id=3 and queantity = $quantity;


- END -



       
       
       
最近整理一份面试资料《Java技术栈学习手册》,覆盖了Java技术、面试题精选、Spring全家桶、Nginx、SSM、微服务、数据库、数据结构、架构等等。
获取方式:点“ 在看,关注公众号 Java后端 并回复 777 领取,更多内容陆续奉上。
读 
1. 每日一题之 ZooKeeper
2. 每日一题之 Redis
3. 
每日一题之 MySQL

 
        
        
        
4. 
每日一题之 JVM-01

5. 每日一题之 JVM-02



6

.

 
每日一题之 JVM-03


7. 

每日一题之线程


8.

  每日一题之 HashMap

  
         
         
         
9.
 每日一题之 HashMap - 02

10.
 每日一题之 ThreadLocal


11.

  每日一题之 Spring
12.
 每日一题之 计算机网络
13.
 每日一题之 Dubbo
14.
 每日一题之 Kafka

每日一题之 高并发系统

在看 

每日一题之 高并发系统


本文分享自微信公众号 - Java后端(web_resource)。
如有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

版权声明:程序员胖胖胖虎阿 发表于 2022年11月23日 上午7:08。
转载请注明:每日一题之 高并发系统 | 胖虎的工具箱-编程导航

相关文章

暂无评论

暂无评论...