网络编程基础----并发编程 ---守护进程----同步锁 lock-----IPC机制----生产者消费者模型
1 守护进程:
主进程 创建 守护进程 辅助主进程的运行
设置进程的 daemon属性 p1.daemon=True
1 守护进程会在主进程代码执行结束后就终止;
2 守护进程内无法再开启子进程,否则抛出异常;
AssertionError: daemonic processes are not allowed to have children
注意:进程之间是互相独立的,主进程代码运行结束,守护进程随即终止
from multiprocessing import Process
import time def work(n):
print('---start')
time.sleep(0.5)
print('---end')
def work2():
print('主人死了')
time.sleep(6)
print(' 我也不活了!') if __name__=='__main__':
p1=Process(target=work,args=(2,))
p2=Process(target=work2) p2.daemon=True # 修改 daemon属性 守护进程 不能再开子进程 p1.start()
p2.start()
time.sleep(5)
print('主') # 主进程结束---子进程(辅助进程)马上结束
2 同步锁 互斥锁
进程之间数据通信----需要共享数据 ======多进程 共享数据===== 进程 之间 用 共享空间(争抢) ---- 硬盘 文件 修改共享数据---串行 ---保证数据安全
其他操作---并发
lock 可以锁住一部分 内容 ===== 把一部分并发 变为串行
# 模拟购票 from multiprocessing import Process,Lock
import os
import time
import json
import random def search(n): # 查找---并发
dic=json.load(open('db.txt'))
print('<%s> 查到的剩余票数 [%s] '%(n,dic['count']))
def get(n): # 修改操作---串行
dic=json.load(open('db.txt')) if dic['count']>0:
dic['count']-=1
time.sleep(random.randint(1,3))
json.dump(dic,open('db.txt','w'))
print('<%s> 购票成功'%(n)) def task(n,lock): search(n) lock.acquire() # 加锁
get(n)
lock.release() # 解锁 # with lock:
# get(n) # lock 支持上下文管理
if __name__=='__main__':
lock=Lock()
for i in range(30):
p=Process(target=task,args=(i,lock))
p.start()
3 IPC机制: ---- 内存数据的通信
内存空间 ---- 共享的内存 (硬盘速度慢) ---进程之间的数据通信--- 共享----竞争---无序---不安全 IPC机制 (进程间的通信) ---- (内存空间的数据通信) ----实现方法 队列 管道 数据安全---lock 锁
队列 (管道+锁)---基于IPC编程
管道------------基于IPC编程
队列:
=== 队列 =====
from multiprocessing import Queue q=Queue(3) # 只能放三次数据 q.put('bb')
q.put((3,1,2,5))
q.put({'a':1}) # q是队列对象 --- q 放在内存中 # q.get_nowait(11111) 不等 满了就会报错 print(q.get())
print(q.get())
print(q.get()) # print(q.get_nowait()) 不等 没有就会 报错
4 生产者 消费者 模型:
涉及到两个进程之间的通信---内存数据的交互(管道)---安全(锁) ==== 队列(管道+锁) 生产者 消费者 ===== 通过 共享空间 (解耦合) ----队列
生产者消费者模型: 1 程序中有两类角色
一类负责生产数据(生产者) 一类负责处理数据(消费者) 2 引入生产者消费者模型的目的:
平衡生产者 与 消费者之间的 速度差 3 如何实现:
生产者---队列----消费者 (解耦合)
# 生产者 消费者 模型 from multiprocessing import Queue,Process
import time,random def producer(name,q):
for i in range(10):
time.sleep(0.2)
res='%s 制作的第%s包子'%(name,i)
q.put(res)
# q.put(None)
def consumer(name,q):
while True:
res=q.get()
if not res:break
print('%s 吃了 %s'%(name,res)) if __name__=='__main__':
q=Queue()
p=Process(target=producer,args=('egon',q)) #共享的管道 q
p2=Process(target=consumer,args=('alex',q)) #共享的管道 q
p.start()
p2.start() p.join() # 等待p进程结束
q.put(None)
网络编程基础----并发编程 ---守护进程----同步锁 lock-----IPC机制----生产者消费者模型的更多相关文章
- 守护、互斥锁、IPC和生产者消费者模型
守护进程 主进程创建守护进程 其一:守护进程会在主进程代码执行结束后就终止 其二:守护进程内无法再开启子进程,否则抛出异常:AssertionError: daemonic processes are ...
- [并发编程 - socketserver模块实现并发、[进程查看父子进程pid、僵尸进程、孤儿进程、守护进程、互斥锁、队列、生产者消费者模型]
[并发编程 - socketserver模块实现并发.[进程查看父子进程pid.僵尸进程.孤儿进程.守护进程.互斥锁.队列.生产者消费者模型] socketserver模块实现并发 基于tcp的套接字 ...
- python并发编程之多进程(二):互斥锁(同步锁)&进程其他属性&进程间通信(queue)&生产者消费者模型
一,互斥锁,同步锁 进程之间数据不共享,但是共享同一套文件系统,所以访问同一个文件,或同一个打印终端,是没有问题的, 竞争带来的结果就是错乱,如何控制,就是加锁处理 part1:多个进程共享同一打印终 ...
- (并发编程)进程IPC,生产者消费者模型,守护进程补充
一.IPC(进程间通信)机制进程之间通信必须找到一种介质,该介质必须满足1.是所有进程共享的2.必须是内存空间附加:帮我们自动处理好锁的问题 a.from multiprocessing import ...
- 并发编程 - 进程 - 1.队列的使用/2.生产者消费者模型/3.JoinableQueue
1.队列的使用: 队列引用的前提: 多个进程对同一块共享数据的修改:要从硬盘读文件,慢,还要考虑上锁: 所以就出现了 队列 和 管道 都在内存中(快): 队列 = 管道 + 上锁 用队列的目的: 进程 ...
- python开发进程:互斥锁(同步锁)&进程其他属性&进程间通信(queue)&生产者消费者模型
一,互斥锁,同步锁 进程之间数据不共享,但是共享同一套文件系统,所以访问同一个文件,或同一个打印终端,是没有问题的, 竞争带来的结果就是错乱,如何控制,就是加锁处理 part1:多个进程共享同一打印终 ...
- day34 python学习 守护进程,线程,互斥锁,信号量,生产者消费者模型,
六 守护线程 无论是进程还是线程,都遵循:守护xxx会等待主xxx运行完毕后被销毁 需要强调的是:运行完毕并非终止运行 #1.对主进程来说,运行完毕指的是主进程代码运行完毕 #2.对主线程来说,运行完 ...
- C++11 并发指南九(综合运用: C++11 多线程下生产者消费者模型详解)
前面八章介绍了 C++11 并发编程的基础(抱歉哈,第五章-第八章还在草稿中),本文将综合运用 C++11 中的新的基础设施(主要是多线程.锁.条件变量)来阐述一个经典问题——生产者消费者模型,并给出 ...
- Linux同步互斥(Peterson算法,生产者消费者模型)
同步 两个或两个以上随时间变化的量在变化过程中保持一定的相对关系. 互斥 对一组并发进程,一次只有一个进程能够访问一个给定的资源或执行一个给定的功能. 互斥技术可以用于解决诸如资源争用之类的冲突,还可 ...
随机推荐
- C#将图片白色背景设置为透明
Image image = System.Drawing.Image.FromFile(@"C:\A.JPG"); Bitmap pbitmap = new Bitmap(imag ...
- CSS 中z-index全解析(摘自阿里西西)
z-index全解析 Z-index属性决定了一个HTML元素的层叠级别.元素层叠级别是相对于元素在Z轴上(与X轴Y轴相对照)的位置而言.一个更高的Z-index值意味着这个元素在叠层顺序中会更靠近顶 ...
- Link
GNU/Linux, Bash, C, PHP, Perl, JavaScript, Vim, Git http://blog.sanctum.geek.nz/about 中文數學詞典 http: ...
- SpringBoot编辑代码时不重启服务
@SpringBootApplication @ComponentScan("com.sicdt") public class SicSignWebApplication { pu ...
- Java系列之EJB 理解
EJB = Enterprise Java Bean,它和JavaBean有本质的区别,最好不要将他们混淆起来,就像不要将Java和 Javascript混淆起来一样.EJB有3中类型:Session ...
- MongoDB环境配置
在官网上下载MongoDB可执行文件安装在电脑上后,想要运行需先安装路径下新建一个data文件夹,再在里面新建db文件夹用户存放数据库文件和相关配置. 在bin目录里面运行命令行: 这样MongoDB ...
- ubuntu里设置从串口登录
1) Create a file called /etc/init/ttyS0.conf containing the following: # ttySAC0 - getty # # This se ...
- Struts2笔记02——Struts2 概述(转)
原始内容:https://www.tutorialspoint.com/struts_2/basic_mvc_architecture.htm Struts2是基于MVC设计模式的一种流行.成熟的We ...
- JSP笔记02——概述(转)
不完全翻译,结合谷歌,一定主观性,还可能有误,原始内容地址:https://www.tutorialspoint.com/jsp/jsp_overview.htm 主要内容如下: 什么是JSP? 为什 ...
- C#多线程学习之:Monitor类
关于对C#多线程类Monitor的理解 1.对线程的理解 围绕着锁周围的线程可以分为以下三类: l 拥有锁的线程:只有一个 l 就绪队列:只有就绪队列里的线程才有机会在锁被释放时去获取锁. l ...