进程

狭义:正在运行的程序实例。

广义:进程是一个具有一定独立功能的程序关于某个数据集合的一次运行活动,他是操作系统动态执行的基本单元。

python的进程都是并行的。

并行:两个进程同时执行一起走。

并发:逻辑上是两个线程同时进行,物理上是交替执行。

 import multiprocessing

 def fun1(i):
print(multiprocessing.current_process(),i) if __name__ == "__main__":
mp_lst = []
for i in range(100):
m = multiprocessing.Process(target=fun1,args=(i,))
m.start()
mp_lst.append(m) _ = [i.join() for i in mp_lst]

简单开启100个进程

python进程和线程的使用方式没啥区别

start() 开启进程

join() 等待,直到进程完成其工作并退出位置

为什么要使用__name__ == "__mian__"呢?

因为进程再创建时要导入目标函数的脚本,使用__name__ == "__mian__"方式来防止无限递归。

如果目标函数不在和开启进程同一个脚本中就不需要使用。

class Process():

    # TODO: set type of group to None
def __init__(self,
group: Any = ...,
target: Optional[Callable] = ..., #函数
name: Optional[str] = ..., #进程名
args: Iterable[Any] = ..., #参数
kwargs: Mapping[Any, Any] = ...,
*,
daemon: Optional[bool] = ...) #是否在后台运行进程
def start(self) #开启进程
def run(self) #目标函数
使用类开启多个进程

如何在后台运行进程

python没有守护进程,没有守护进程,没有守护进程 说三遍。

后台进程是一种典型的耗时执行模式,他不需要人为干预,但是可以与其他程序并发,python通过设置daemon选项设置后台进程。

后台进程不能有子进程,因为后台进程的父进程退出时它会终止,如果有子进程那么子进程就会变成游离状态。

 import multiprocessing

 class MyProcess(multiprocessing.Process):
def __init__(self):
super(MyProcess, self).__init__() def run(self):
print(self.name) a = MyProcess()
a.daemon = True #设置后台进程
a.start()

后台进程简单应用

杀死进程

 class MyProcess(multiprocessing.Process):
def __init__(self):
super(MyProcess, self).__init__() def run(self):
print(self.name) a = MyProcess() a.start() a.terminate() #杀死进程
time.sleep(5)
print(a.is_alive()) #判断进程存活
a.join()

杀死进程示例

进程不会被立刻杀死,需要一定时间。

p.exitcode 状态码

==0:表示没有错误

>0:表示进程遇到了错误并退出。

<0:表示进程被信号杀死了。

进程锁与递归锁同线程

信号量、事件都和线程一样

进程同步

python 3.2新增特性屏障barrier

import multiprocessing
from multiprocessing import Process,Barrier,Lock
import time def fun1(br,lockto):
br.wait() #屏障阻塞
now = time.time()
with lockto: #利用with获取和释放锁
print(multiprocessing.current_process().name,now) def fun2():
now = time.time()
print(multiprocessing.current_process().name,now) if __name__ == "__main__":
br = Barrier(2) #设置屏障要阻塞几个进程
lockto = Lock()
p1 = Process(target=fun1, args=(br, lockto), name="p1_prosess")
p2 = Process(target=fun1, args=(br, lockto), name="p2_prosess")
p3 = Process(target=fun2, name="p3_prosess")
p4 = Process(target=fun2, name="p4_prosess")
p1.start()
p2.start()
p3.start()
p4.start()
p1.join()
p2.join()
p3.join()
p4.join() 输出:
p3_prosess 1562118519.9697998
p2_prosess 1562118519.9697998
p1_prosess 1562118519.9697998
p4_prosess 1562118519.9768193

我们可以看到p1和p2的时间是完全相同的至于p3为什么也相同=。=俺电脑太棒了只能说,多测试几遍就有不同的值了不贴了。

这个屏障的作用就是wait阻塞住以后按照前面设置的阻塞进程的数量来拦截进程,我这里设置的是2个所以就第一个进程到达时阻塞直到第二个进程到达才一起释放。如下图:

利用进程管理器进行数据共享

 import multiprocessing

 def fun1(mg_dict,x,y):
mg_dict[x] = y if __name__ == "__main__":
mg = multiprocessing.Manager() #生成管理器对象
mg_dict = mg.dict() #创建共享字典 p_lst = [multiprocessing.\
Process(target=fun1,args=(mg_dict,i,i*2)) for i in range(10)] [p.start()for p in p_lst]
[task.join()for task in p_lst] print(mg_dict)

利用管理器共享数据

如果要访问数据也要加锁奥~

进程间通信

可以使用管道、队列

这里最主要想说是一个mpi4py的python模块,可以进行进程的点对点、广播、拓扑(订阅发布)的方式通信,但是一般大家都用rabitmq,不知道有没有必要写,我可以利用这个模块做什么呢?

可以使用他造轮子吗?但是有rbitmq这些还有必要造吗?有什么意义?感觉灵活度也不是很高。可以利用他再写一个类似celery的轮子?我觉得celery是可以重写因为大部分功能都用不上,减轻负重也不错。

python进程概要的更多相关文章

  1. python——进程基础

    我们现在都知道python的多线程是个坑了,那么多进程在这个时候就变得很必要了.多进程实现了多CPU的利用,效率简直棒棒哒~~~ 拥有一个多进程程序: #!/usr/bin/env python #- ...

  2. 使用gdb调试Python进程

    使用gdb调试Python进程 有时我们会想调试一个正在运行的Python进程,或者一个Python进程的coredump.例如现在遇到一个mod_wsgi的进程僵死了,不接受请求,想看看究竟是运行到 ...

  3. python进程、线程、协程(转载)

    python 线程与进程简介 进程与线程的历史 我们都知道计算机是由硬件和软件组成的.硬件中的CPU是计算机的核心,它承担计算机的所有任务. 操作系统是运行在硬件之上的软件,是计算机的管理者,它负责资 ...

  4. Python进程、线程、协程详解

    进程与线程的历史 我们都知道计算机是由硬件和软件组成的.硬件中的CPU是计算机的核心,它承担计算机的所有任务. 操作系统是运行在硬件之上的软件,是计算机的管理者,它负责资源的管理和分配.任务的调度. ...

  5. python进程池剖析(一)

    python中两个常用来处理进程的模块分别是subprocess和multiprocessing,其中subprocess通常用于执行外部程序,比如一些第三方应用程序,而不是Python程序.如果需要 ...

  6. python——进程、线程、协程

    Python线程 Threading用于提供线程相关的操作,线程是应用程序中工作的最小单元. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 #!/usr/bin/env pytho ...

  7. python/进程线程的总结

    python/进程线程的总结 一.进程和线程的描述: 进程:最小的资源管理单位 线程:最小的执行单位 执行一个进程时就默认执行一个线程(主线程) 进程和线程的工作方式: 串行: 假如共有A.B.C任务 ...

  8. python 进程介绍 进程简单使用 join 验证空间隔离

    一.多道程序设计技术(详情参考:https://www.cnblogs.com/clschao/articles/9613464.html) 所谓多道程序设计技术,就是指允许多个程序同时进入内存并运行 ...

  9. Python 进程之间共享数据

    最近遇到多进程共享数据的问题,到网上查了有几篇博客写的蛮好的,记录下来方便以后查看. 一.Python multiprocessing 跨进程对象共享  在mp库当中,跨进程对象共享有三种方式,第一种 ...

随机推荐

  1. Swagger Learing - Spring Boot 整合swagger

    学习了一下swagger. 这是编写的Demo 源码 https://github.com/AmberBar/Learning/tree/master/swagger-learning/swagger ...

  2. R的安装

    更新时间:2019.09.23 1. 序言 之前曾经用过一段时间的R(一直忍受着原生R那个超级"简洁"的界面),但是后来重装了系统并且学习了Python,就没有再怎么碰过R了.然而 ...

  3. 关于微信oauth登录的坑

    这是实习公司里微信公众号的一个小项目,用的是ssm.问题是获取用户openid为空. 分析下步骤 首先用户点击微信公众号按钮 访问微信服务器获取code 跳转到项目url 拿code访问微信服务器,获 ...

  4. Handler的postDelayed(Runnable, long)

    handler.postDelayed(myRunnable,1000)是为了轮播图片,每隔1000ms后执行一次run方法,实现轮播实例如下: public void MesageColse(){ ...

  5. Redis5源码解析-Sentinel

    简单的概念就不解释.基于Redis5.0.5 从Sentinel主函数触发 在sentinel.c文件的最后面可以发现sentinelTimer函数,这个就是Sentinel的主函数,sentinel ...

  6. 【网络安全】HTTPS为什么比较安全

    目录 HTTP和HTTPS简介 SSL协议 SSL协议的主要功能 SSL协议加密数据的原理 用户和服务器的认证流程 TLS 参考 HTTP和HTTPS简介 1. HTTP协议为什么是不安全的 http ...

  7. 第七篇 Flask实例化配置及Flask对象配置

    一.Flask对象的配置 Flask 是一个非常灵活且短小精干的web框架 , 那么灵活性从什么地方体现呢? 有一个神奇的东西叫 Flask配置 , 这个东西怎么用呢? 它能给我们带来怎么样的方便呢? ...

  8. [考试反思]0725NOIP模拟测试8

    看清你是个什么东西了么? 现在看清了么?rank#15?垃圾玩意? 你什么也不是.你没有骄傲,偷懒的资格! 节节败退,永无止境,你想掉到什么样子? 你还在为了成功拿到送分的T1而沾沾自喜?只不过是勉强 ...

  9. Asp.Net终于可以在龙芯服务器上运行啦:Jexus成功完成对国产系列CPU的适配

    为了确保我国信息化建设“安全可靠”,使用国产关键系统.关键应用.关键软硬件替代国外信息技术产品,已经在党政部门.国营企事业单位得到了进一步落实.过去运行于 Windows 服务器的 Web 应用程序, ...

  10. 期末考试(正解:三分单峰函数 me~)

    好久没有水过杂题了! 今天lsc终于刚过了三道考试题来水杂题了! 期末考试 首先一看还是一脸mb(这是正常现象,毕竟我不像一些大神可以一眼出正解)然后我就被颓了标签,知道是三分单峰函数,但是自己实在是 ...