Skip to content

Latest commit

 

History

History
132 lines (98 loc) · 2.86 KB

048-820515-进程_内存状态_process_ps_pid_ppid_RSS_SZ.sy.md

File metadata and controls

132 lines (98 loc) · 2.86 KB
show version enable_checker
step
1.0
true

查看进程

回忆上次内容

  • 进程查询
    • ps -lf 查看 本终端相关的 进程信息
    • ps -elf 查看 所有进程的 信息
  • 杀死 进程
    • kill -9 PID 给进程发送死亡信号
  • 后台 运行
    • nohup python3 sleep.py>>s.log &

图片描述

  • 这些进程之间 是什么关系呢?🤔
#!/usr/bin/python
i = 0
import time
while True:
    i = i + 1
    print(i, "===", time.asctime())
    time.sleep(1)

具体查询

nohup python3 sleep.py >> s.log &
  • zsh进程相关的 3 个进程
    • zsh
      • 当前的 shell环境
      • zsh进程
    • python3 sleep.py
      • 输出时间的python程序
    • ps -lf
      • 查询进程的ps进程

图片描述

  • 先 输出重定向到process
    • 再打开process
ps -lf > process
vi process
  • 可以查看到
    • 这进程之间有父子关系

父子关系

图片描述

  • 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

图片描述

  • 对了
    • 还导入了time模块(module)

time

  • 除了 基础部分(内建 模块函数)之外
    • print()
    • ord()、chr()
    • int()、hex()、bin()
  • 还有 新加载的部分
    • sleep.py
    • import 进来的 time 这个 module

图片描述

  • 但是time属于内建(built-in)的啊!
  • 都 装进内存
    • 也没有 10+M 呀?

总结

  • 进程查询
    • ps -elf 查看所有进程信息
    • ps -lf 查看本终端相关进程信息
    • kill -9 PID 给进程发送死亡信号
  • 进程前后台切换
    • ctrl + z 把当前进程切换到后台并暂停
    • jobs 查看所有作业
  • 运行多个 python3 sleep.py 的话
    • 各个进程独立
    • 各占内存
    • 每个进程大概 10+M 内存

图片描述

  • 怎么会占那么多内存呢??🤔
  • 我们下次再说!👋