今天看了一篇好文章,里面一些思路颇值得借鉴。先摘录总结精华如下,然后看看梁山好汉如何处理秒杀系统。我看到秒杀这个概念,第一时间就想到了"呼延灼三千连环甲马"。 1. 摘录 a. 总体思路 系统隔离 因为秒杀活动是有计划的,并且在短时间内会爆发大量的请求。为了不影响现有的业务系统的正常运行,我们需要把 ...
分类:
其他好文 时间:
2019-11-22 23:56:20
阅读次数:
137
线程锁 531388 我们讲过的进程有进程锁,那么线程也有线程锁,先看上面代码,我们知道线程共享一个进程的空间,所以他们都对x进行增加操作,按道理来说,最后打印的结果应该是600000,而这里却远远不到,这是因为线程在进行长时间的操作时,cup切到下一个线程了,而这个时候可能x=1000+1,只执行 ...
分类:
编程语言 时间:
2019-09-18 20:56:50
阅读次数:
128
抢票小程序 我们可以利用所学的内容来写一个简易的抢票小程序 抢票小程序(优化) 之前的抢票小程序看似完善但实际上在数据的安全方面依旧存在着问题,因此我们可以使用进程锁来实现优化 进程锁 进程锁的本质则是把锁住的代码变成串行,它可以用lock.acquire和lock.release来实现 lock. ...
分类:
微信 时间:
2019-09-17 22:47:48
阅读次数:
147
优化抢票 加入Lock lock.acquire() 锁住 lock.release()释放锁头 进程锁把所著的代码编程串行, join 是把所有的子进程变成了串行。 队列 ipc机制 进程通讯 管道:pipe 基于共享的内存空间 队列:pipe+锁 queue ==put()==放东西 get.( ...
分类:
编程语言 时间:
2019-09-16 21:48:07
阅读次数:
128
[TOC] 队列、生产者消费者模型、初识线程 一、用进程锁来优化抢票小程序 1.1 进程锁 进程之间数据不共享,但是共享同一套文件系统,所以访问同一个文件,或同一个打印终端是没有问题的。而共享带来的是竞争,竞争带来的结果就是错乱,那就需要加锁处理来控制。 多个进程共享同一打印终端的时候,并发运行的话 ...
分类:
其他好文 时间:
2019-09-16 21:44:23
阅读次数:
106
一、ipc机制 进程通讯 管道:pipe 基于共享的内存空间 队列:pipe+锁 queue 下面拿代码来实现Queue如何使用: 案例一: 案例二: 案例三:(从这往下都是了解) 案例四: 案例五: 案例六: 二、生产者消费者模型: ? 在并发编程中使用生产者和消费者模式能够解决绝大多数并发问题。 ...
分类:
系统相关 时间:
2019-09-16 21:41:47
阅读次数:
137
join用法(等待子进程运行完) terminate的用法(杀死进程) daemon(守护进程) 进程锁 : 是把锁住的代码变成了串行 join 是把所有的子进程变成了串行 Queue(队列) JoinableQueue模块用法 ...
分类:
其他好文 时间:
2019-09-16 16:39:16
阅读次数:
95
(一)进程锁 抢票的例子: 结果: multipleprocessing.Lock 非递归的锁定对象,非常类似threading.Lock.一旦进程或线程获得了锁,后续尝试从任何进程或线程获取它,将被阻塞直到被释放; 任何进程或线程都可以释放它。 Lock支持上下文管理协议,可以在with中使用。 ...
分类:
编程语言 时间:
2019-09-16 10:20:03
阅读次数:
83
1、进程 2、进程数据共享 3、进程锁 4、进程池 ...
分类:
编程语言 时间:
2019-07-20 17:01:15
阅读次数:
108
参考别人的博客:https://www.cnblogs.com/whatisfantasy/p/6440585.html 线程 线程是操作系统能够进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位。一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行 ...
分类:
编程语言 时间:
2019-07-06 22:11:55
阅读次数:
169