网络编程基础----并发编程 ---守护进程----同步锁 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算法,生产者消费者模型)
同步 两个或两个以上随时间变化的量在变化过程中保持一定的相对关系. 互斥 对一组并发进程,一次只有一个进程能够访问一个给定的资源或执行一个给定的功能. 互斥技术可以用于解决诸如资源争用之类的冲突,还可 ...
随机推荐
- HAProxy配置参数说明
一.全局配置"global"配置中的参数为进程级别的参数,且通常与其运行的OS相关.1.进程管理及安全相关的参数chroot <jail dir>修改haproxy的工 ...
- javascript高级语法
一.JavaScript对象 1.js对象简介 1.1 在JavaScript中除了null和undefined以外其他的数据类型都被定义成了对象,也可以用创建对象的方法定义变量,在JavaScrip ...
- 剑指offer 面试21题
面试21题: 题目:调整数组的顺序使奇数位于偶数前面 题一:输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数位于数组的前半部分,所有偶数位于数组的后半部分. 解题思路:使用两个指针 ...
- Ubuntu环境变量配置
根目录下的.bashrc文件中配置环境变量 export JAVA_HOME=/home/zn/softpackage/jdk1. export CLASSPATH=${JAVA_HOME}/lib ...
- yii2弹出层
bootstrap http://getbootstrap.com/javascript/#modals https://github.com/lichunqiang/yii2-sweet-submi ...
- Bürkert 流体控制系统 (8611 型通用调节器)
Type Description High-Tech Made EasyThe new universal controller eCONTROL Type 8611 brings an essent ...
- https网站无法加载http路径的js和css
在https的网站中引用http路径的js或css会导致不起作用,其形如: <script src="http://code.jquery.com/jquery-1.11.0.min. ...
- C++使用命名空间中成员的三种方式
通过简单的代码来介绍使用命名空间中成员的三种方式(我们最常用到的命名空间是是标准库std,下面的命名空间都以std为例): 使用作用域符:: #include<iostream> int ...
- tcp三次握手过程
TCP握手协议 在TCP/IP协议中,TCP协议提供可靠的连接服务,采用三次握手建立一个连接.第一次握手:建立连接时,客户端发送syn包(syn=j)到服务器,并进入SYN_SEND状态,等待服务器确 ...
- NCBI
RefSeq: NCBI Reference Sequences GeneBank序列注释说明 利用NCBI查找基因信息 NCBI中RefSeq各种accession说明(一) NCBI中RefSeq ...