当前位置: 首页 > news >正文

一些关于linux process 和python process的记录

python mulprocess

主要用来生成另一个进程并运行

def func(i):print('helloworld')from multiprocessing import Process
p = Process(target=func,args=(i, ))
p.start()

如果想要调用shell命令,可以采用os.popen 或者是 subprocess.run

但是前者只能执行命令并获取输出,对一些复杂的输出或者输入并不能处理,因此选择后者
subprocess.run vs subprocess.call vs subprocess.Popen
前两者没有什么区别,只是一个是python3.5之前的,一个是之后的,call会不会被取消还不清楚,
run是同步的,popen是异步的,体现在结果上就是run会等待,执行后会立刻结束,popen不等待,但是什么时候执行并不确定

getpid = os.popen("ps -ef | grep slice.sh | grep -v 'grep' | awk '{print $2}'")
pid = getpid.read().strip('\n').replace("\n", " ")command = "sudo kill -9 {0}".format(pid)
print(command)
p = subprocess.run("exec " + command,shell=True,preexec_fn=os.setsid)

os.killpg(pid,SIGINT)这个函数只能处理自己生成的进程,不能处理别的进程

linux process

请添加图片描述

sudo kill -9 pid = sudo kill -SIGKILL pid
ctrl+c = SIGINT
但是又可能忽略掉,sigint发送无用,ctrl+c有用
perf kill无输出

http://www.lryc.cn/news/25474.html

相关文章:

  • 卡尔曼滤波——一种基于滤波的时序状态估计方法
  • 什么是X6CrMo17-1
  • 软件测试是个人就能做?恕我直言,你可能是个“纯粹”的测试工具人,BUG收集器
  • 递归算法(recursion algorithm)
  • VScode下 ESP32 下载程序
  • 黑苹果日历
  • python+pytest接口自动化框架(5)-requests发送post请求
  • Linux 进程:进程控制
  • 过滤器的创建和执行顺序
  • JDK1.8 ConcurrentHashMap
  • 参考 Promise/A+ 规范和测试用例手写 Promise
  • yolov5数据集制作
  • 主板EC程序烧写异常致无法点亮修复经验
  • 【Java爬取赛事网站】命令行输出(仅供学习)
  • redis主从复制原理
  • buu刷题(第一周)
  • 算法训练营 day62 单调栈 每日温度 下一个更大元素 I
  • ChIP-seq 分析:Peak 注释与可视化(9)
  • ABB机器人配置DeviceNet总线IO板以及信号分配的具体方法示例
  • 2023 年网络安全漏洞的主要原因
  • 剑指 Offer 34. 二叉树中和为某一值的路径
  • 2023前端vue面试题(边面边更)
  • webpack配置完全指南
  • juju创建lxd容器时如何使用本地镜像(by quqi99)
  • 后端程序员学习前端开发之第一步环境搭建
  • 【记录问题】RuntimeError:working outside of application context. Flask使用SQLAlchemy数据库
  • 自动化测试难点案例分析,其实自动化你用错方向还不如不用
  • 866363-70-4,N3-C5-NHS ester,叠氮-C5-NHS 主要物理性质分享
  • 字符流定义及如何深入理解字符流的编码
  • 什么是pod类型