设为首页 加入收藏

TOP

Python知识之 方法与函数、偏函数、轮询和长轮询、流量削峰、乐观锁与悲观锁(三)
2019-07-14 22:09:29 】 浏览:143
Tags:Python 知识 方法 函数 流量 乐观 悲观
户无法访问的情况出现。

  具体实例有很多:比如每年的春运买票同一时间大佬用户去抢购车票,比如淘宝双十一抢购活动,又比如秒杀活动,都是在短时间内用户发起请求导致流量剧增,服务器顶不住就会宕机。

  解决的办法之一就是流量削峰方案:

  削峰方案本质上就是更多的延缓用户请求,以及层层过滤用户的访问需求,遵循“最后落地到数据库的请求数要尽量少”的原则,来变相减轻服务器的压力。

总结:

1.对于秒杀这样的高并发场景业务,最基本的原则就是将请求拦截在系统上游,降低下游压力。如果不在前端拦截很可能造成数据库(mysql、oracle等)读写锁冲突,甚至导致死锁,最终还有可能出现雪崩等场景。

2.划分好动静资源,静态资源使用CDN进行服务分发。

3.充分利用缓存(redis等):增加QPS,从而加大整个集群的吞吐量。

4.高峰值流量是压垮系统很重要的原因,所以需要Kafka等消息队列在一端承接瞬时的流量洪峰,在另一端平滑地将消息推送出去。

乐观锁和悲观锁

悲观锁
  总是假设最坏的情况,每次去拿数据的时候都认为别人会修改,所以每次在拿数据的时候都会上锁,这样别人想拿这个数据就会阻塞直到它拿到锁(共享资源每次只给一个线程使用,其它线程阻塞,用完后再把资源转让给其它线程)。传统的关系型数据库里边就用到了很多这种锁机制,比如行锁,表锁等,读锁,写锁等,都是在做操作之前先上锁。

  悲观锁使用场景

  比较适合写入操作比较频繁的场景,如果出现大量的读取操作,每次读取的时候都会进行加锁,这样会增加大量的锁的开销,降低了系统的吞吐量。

乐观锁

  总是假设最好的情况,每次去拿数据的时候都认为别人不会修改,所以不会上锁,但是在更新的时候会判断一下在此期间别人有没有去更新这个数据,可以使用版本号机制和CAS算法实现。乐观锁适用于多读的应用类型,这样可以提高吞吐量,像数据库提供的类似于write_condition机制,其实都是提供的乐观锁。

  乐观锁使用场景

  比较适合读取操作比较频繁的场景,如果出现大量的写入操作,数据发生冲突的可能性就会增大,为了保证数据的一致性,应用层需要不断的重新获取数据,这样会增加大量的查询操作,降低了系统的吞吐量。

 

首页 上一页 1 2 3 下一页 尾页 3/3/3
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇python面试题37道(附答案)看完.. 下一篇MYSQL数据库数据类型

最新文章

热门文章

Hot 文章

Python

C 语言

C++基础

大数据基础

linux编程基础

C/C++面试题目