python创建系统进程

python创建函数并将其作为进程

一、掌握导入python的multiprocessing包,定义函数创建单个进程,创建多个进程的方法,并理解守护进程、进程阻塞的方法;
二、掌握Linux系统下运行python程序的方法,掌握Linux系统下进程的优先级、NICE值以及renice命令
Linux 进程调度及多任务
每个CPU(或CPU核心)在一个时间点上只能处理一个进程,通过时间片技术,Linux实际能够运行的进程(和线程数)可以超
出实际可用的CPU及核心数量。Linux内核 进程调度程序将多个进程在CPU核心上快速切换,从而给用户多个进程在同时运行的印象。
Linux支持从19(最低优先级)到-20(最高优先级)的nice值。默认值为0。
nice 值越高: 表示优先级越低,例如+19,该进程容易将CPU 使用量让给其他进程。
nice 值越低: 表示优先级越高,例如-20,该进程更不倾向于让出CPU。
在这里插入图片描述
在这里插入图片描述

三、常用命令解释
1、p.pid() : #获取进程id
2、os.getpid() : #获取进程id
3、os.getppid() : #获取父进程id
4、p.name: #进程的名称
5、p.daemon: #默认值为False,如果设为True,代表p为后台运行的守护进程,当p的父进程终止时,p也随之终止,并且设定为True后,p不能创建自己的新进程,必须在p.start()之前设置
6、p.is_alive(): #如果p仍然运行,返回True

#守护进程实例
from multiprocessing import Process
import time
def foo():
    print(123)
    time.sleep(1)
    print("end123")
def bar():
    print(456)
    time.sleep(3)
    print("end456")
if __name__ == '__main__':
    p1=Process(target=foo)
    p2=Process(target=bar)
    p1.daemon=True #这里将p1开启守护进程
    p1.start()
    p2.start()
    time.sleep(2) #这里如果延迟1秒,则foo子进程内的end123不会运行,因为主进程和子进程是异步的
    print("main-------")

PS:当p1开启守护进程时候,主进程运行快于子进程,所以foo这段代码是不会运行,在主进程前设置延迟3秒,两个子进程内代码都会运行
PS:当主进程的延迟高于子进程,则子进程有足够的时间运行结束,所有子进程都能运行
四、Process对象的join方法:
  在主进程运行过程中,如果想并发地执行其它的任务,我们可以开启子进程,此时主进程的任务与子进程的任务分两种情况:

情况一:在主进程的任务与子进程的任务彼此独立的情况下,主进程的任务先执行完毕后,主进程还需要等待子进程执行完毕,然后统一回收资源
情况二:如果主进程的任务在执行到某一个阶段时,需要等待子进程执行完后才能继续执行,就需要有一种机制能够让主进程检测子进程是否运行完毕,在子进程执行完毕后才继续执行,否则一直在原地阻塞,这就是join方法的作用
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值