[oeasy]python0032_杀死进程_进程后台运行不输出_nohup_ps_显示进程
精选
原创
©著作权归作者所有:来自51CTO博客作者overmind1980的原创作品,请联系作者获取转载授权,否则将追究法律责任
查看进程
回忆上次内容
- 上次先<kbd>ctrl</kbd> + <kbd>z</kbd> 挂起进程
- 程序继续跑起来
- 而且不断输出到标准输出流
- 甚至连<kbd>ctrl</kbd> + <kbd>c</kbd> 都无法结束进程了
- 这可怎么办呢?
- 只能新开一个终端想办法
查询进程
进程
动手试试
- 看起来上一个zsh就是pid为281的进程
- 记住281这个pid
搜索
杀意
- pid的编号可以通过ps -elf的结果中找到
- 找到上一个zsh的pid
- 就是刚刚的281
- 发过去之后那个进程就要自尽 🥵
- 没有任何进程愿意接受着这个信号
- 君要臣死,臣不得不死
- 权限对进程是多么重要啊
- 但是接到了就要执行
- 阿啊阿啊阿啊·~ 💀
zsh进程
#查询进程
#我们只要和zsh这个进程相关的
#把e去掉
ps -lf
启动更多新进程
suspend词源
- 支撑;承受(sus+tain握住→在下面握住→支撑)
- susceptive 有接受力的;敏感的(sus+cept拿+ive→有拿下的能力→有接受力的)
-pend
- de-, 向下,离开 -pend, 悬挂
- 即悬挂点
- 引申义依靠
- denpendent
- independent
- 词根词缀: ap- 来 , 临近
- -pend- 悬挂
- 垂→依附
- ex- 出 , 向外 + -pend- 支付
- spend
suspend
- 先运行再挂起还是有点麻烦
- 可以直接后台运行但是不输出到屏幕吗?
搜索
查询手册
后台运行不输出
- nohup python -u show_time.py > test.log 2>&1 &
- 0 – stdin (standard input,标准输入)
- 1 – stdout (standard output,标准输出)
- 2 – stderr (standard error,标准错误输出)
- 2>&1 解释:
- 将标准错误 2 重定向到标准输出 &1
- 标准输出 &1 再被重定向输入到 test.log 文件中
后台进程
总结
-
ps -elf
查看所有进程信息 -
ps -lf
查看本终端相关进程信息
-
kill -9 PID
给进程发送死亡信号
- 运行多个
python3 show_time.py
的话
- 各个进程独立
-
python3 show_time.py
大概 8+M - 各占内存