查看进程

回忆上次内容

  • 上次先进程查询

    • ps -elf 查看所有进程信息
    • ps -lf 查看本终端相关进程信息
  • 杀死进程

    • kill -9 PID 给进程发送死亡信号
  • 运行多个 python3 show_time.py 的话

    • 各个进程独立
    • python3 show_time.py 大概 8+M
    • 各占内存
  • 这些进程之间是什么关系呢?

编辑

具体查询

  • zsh进程相关的 3 个进程

    • zsh(当前的 shell 环境)

      • zsh(shell本身)进程
    • /usr/bin/python3 /home/shiyanlou/sleep.py

      • 输出时间的python程序
    • ps -lf

      • 查询进程的ps进程

编辑

  • 这进程之间有父子关系

父子关系

  • pid 是指进程的 id

    • process id
  • ppid 是指 进程 id

    • parent process id
  • ppidpid 的爸爸

编辑

  • pspython3 都是 zsh 的子进程
  • python3 这个进程占内存是 SZ

    • 4860 个 Page
    • 每个 page 大概 4K

      • 总共 10+M

编辑

  • python3 这个文件不是本身才 4.3M 么

    • 都装进内存也就是 4.3M
    • 都装进内存页没有 10+M 呀?

10+M 的原因

  • 除了基础的部分(内建模块函数)之外

    • print()
    • ord()、chr()
    • int()、hex()、bin()
  • 还有新加载的部分

    • sleep.py
    • 还有 import 进来的 time 这个 module

实际分配

ps -o pid,ppid,sz,vsz,rss,cmd
  • SZ 是欲分配的内存用页(4K)来当单位
  • VSZ 是欲分配的内存用 K 来当单位

编辑

  • RSS 非交换区的内存用 K 来当单位
  • 也就是说实际这个东西也就 8+M

编辑

后台多任务查询jobs

  • 还可以用jobs查看当前的任务

编辑

  • jobs 可以看到后台的任务

    • 我们可以切换任务到前台吗

将任务切换到前台

编辑

  • fg 可以

    • 将最后一个任务(3#job)
    • 切换到前台
  • 可以切2#job吗?

指定任务进行切换

  • 我们可以用 fg 加参数的方式

    • 把指定编号的进程恢复到前台
    • 注意前面的 1193、1527、1542 分别是他们的 pid

编辑

  • 这就是前后台切换

    • 用 ctrl + z 把当前进程切换到后台
    • 用jobs查询当前shell的后台任务
    • 用ps可以查看进程
    • 用kill可以结束进程
    • 用 ctrl + c 结束当前前台的进程
  • jobs这个词怎么来的呢?

jobs

  • 词源字典

    • 凯尔特语(gob)、(gop)
    • 原意就是口(the mouth)
    • 中古英语就变成(jobbe)

      • 一堆(lump)
      • 一口(mouthful)
    • 再演变而成一件工作

编辑

  • work

    • 是长时期稳定的工作
    • 全日制的工作
  • jobs

    • 是临时突发的工作
    • 零工
    • 偷窃也叫jobs
  • 如果两个jobs的话

    • 占用内存会变小吗?

两个进程

  • 我们开两个 show_time.py
  • PID 分别是 422、514

编辑

  • 然后观察到

    • 每个 python进程 实际分配差不多都是 9M(RSS)
    • 相互之间是独立的兄弟进程
    • 但是从逻辑上都属于zsh的子进程

      • 先运行的进程在非交换区的内存占用略高
  • 如果开多个xfce 进程情况又是如何呢?
  • 再打开几个xfce终端

进程层次关系

  • ps -elf

    • 拉到最后
    • 找zsh和上级的xfce4

编辑

  • 祖父是xfce4-terminal

    • 大伯是zsh(252)

      • 家里三个兄弟
    • 二伯是zsh(405)

      • 家里也是三兄弟
  • 就像一棵树

    • 可以用树的形式观察吗?

pstree

  • pstree -h 命令查看这棵树

编辑

  • 可以看到清晰地父子兄弟关系

总结

[oeasy]python0033_任务管理_jobs_切换任务_进程树结构_fg的更多相关文章

  1. Python进阶(5)_进程与线程之协程、I/O模型

    三.协程 3.1协程概念 协程:又称微线程,纤程.英文名Coroutine.一句话说明什么是线程:协程是一种用户态的轻量级线程. 协程拥有自己的寄存器上下文和栈.协程调度切换时,将寄存器上下文和栈保存 ...

  2. Python进阶(2)_进程与线程的概念

    1 进程与线程相关概念 1.1 进程 进程定义: 进程就是一个程序在一个数据集上的一次动态执行过程.进程一般由程序.数据集.进程控制块三部分组成,是最小的资源管理单元 程序:用来描述进程要完成哪些功能 ...

  3. 操作系统(2)_进程管理_李善平ppt

    所有程序都有CPU和io这两部分,即使没有用户输入也有输出. CPU最好特别忙,io空闲无所谓. 程序/数据/状态 三个维度来看进程. 等待的资源可能是io资源或者通信资源(别的进程的答复). 一个进 ...

  4. Python笔记_第四篇_高阶编程_进程、线程、协程_4.协程

    1.协程的概念: 子程序或者子函数,在所有语言中都是层级调用,比如A调用B,再B执行的过程中又可以调用C,C执行完毕返回,B执行返回,最后是A执行完毕返回.是通过栈来实现的,一个线程就是执行一个自称, ...

  5. Python笔记_第四篇_高阶编程_进程、线程、协程_3.进程vs线程

    1.多任务的实现原理: 通常我们会设计Mater-Workder模式,Master负责分配任务,Worker负责执行任务,因此多任务环境下,通常是一个Master,多个Worker 2.多进程: 主进 ...

  6. Python笔记_第四篇_高阶编程_进程、线程、协程_1.进程

    1. 多任务原理: 现代操作系统,像win,max os x,linux,unix等都支持多任务. * 什么叫做多任务? 操作系统可以同时运行多个任务. * 单核CPU实现多任务原理? 操作系统轮流让 ...

  7. zabbix_监控_进程

        一.根据进程名称监控 1.创建Item(只能通过进程名.用户过滤进程)  http://www.2cto.com/os/201405/302249.html http://www.ithao1 ...

  8. C# Process类_进程_应用程序域与上下文之间的关系

    进程(Process)是Windows系统中的一个基本概念,它包含着一个运行程序所需要的资源.进程之间是相对独立的,一个进程无法直接访问另一个进程的数据(除非分布式),一个进程运行的失败也不会影响其他 ...

  9. C# Process类_进程管理器Demo

    Process用于管理计算机的进程,下面给出一个C#进程管理器的DEMO. namespace ProcessManager { public partial class Form1 : Form { ...

  10. python并发_进程_multiprocessing

    多进程基础, 主要是用了 multiprocessing模块 : 在一个python进程中开启子进程,start方法和并发效果. import time from multiprocessing im ...

随机推荐

  1. spring boot 在windows下的 批文件部署

    目录结构如下: install.bat @echo off SET JAVA_HOME="C:\Program Files\Java\jdk1.8.0_211\bin" copy ...

  2. 【c++】求解八皇后问题

    为:在8×8格的国际象棋上摆放8个皇后,使其不能互相攻击,即任意两个皇后都不能处于同一行.同一列或同一斜线上,问有多少种摆法.一共92个解 解决思路:一层层回溯,采用深度优先的递归算法. 动态分配的数 ...

  3. C# Datagridview combox列 初始化颜色

    DataGridView 初始化完成后,在combox里显示颜色,如这样: DataGridView 注册 cellPainting事件: private void m_dataGridView_Ce ...

  4. MD5计算,一个扩展类,哪里都能用

    最近有同学问到如何计算一个字节数组的MD5值,现在分享一个扩展类,有了它,MD5计算再也不用其他了. 先看示例: string s = "hello world"; var s_m ...

  5. c/c++复习 2.0 ProMax

    main函数执行前后做了什么 初始化.data数据段,包括静态变量和全局变量 初始化.bss字段,包括int 0; bool false: 指针 NULL 设置栈指针.main函数的参数传递.全局对象 ...

  6. 8.10考试总结(NOIP模拟35)[玩游戏·排列·最短路·矩形]

    所谓人,无论是谁到了最后,都会形单影只. T1 玩游戏 解题思路 可以把序列从 k 位置掰成两个序列. 问题就变成了两个序列从开头走向末尾是否可以保证前缀和之和一直不大于 0 . 并且可以移动到两个序 ...

  7. ncnn的blob_vkallocator、workspace_vkallocator、staging_vkallocator区别

    ncnn::Extractor中有三个成员函数: void set_blob_vkallocator(VkAllocator* allocator); void set_workspace_vkall ...

  8. INFINI Labs 产品更新 | 发布 Easysearch Java 客户端,Console 支持 SQL 查询等功能

    近年来,日志管理平台越来越流行.使用日志管理平台可以实时地.统一地.方便地管理和查看日志,挖掘日志数据价值,驱动运维.运营,提升服务管理效率. 方案架构 Beats 是轻量级采集器,包括 Filebe ...

  9. Scrapy框架(五)--请求传参

    在某些情况下,我们爬取的数据不在同一个页面中,例如,我们爬取一个电影网站,电影的名称,评分在一级页面,而要爬取的其他电影详情在其二级子页面中. 这时我们就需要用到请求传参. 请求传参的使用场景 当我们 ...

  10. spark读取写入jdbc.,Caused by: java.lang.NoSuchMethodException: org.apache.spark.sql.execution.datasources.jdbc.DriverWrapper.<init>()

    df.write .option("truncate", "true") .option("driver", mysqlDriver) .m ...