Linux:User space 与 Kernel space

学习 Linux 时,常常能够看到两个词:User space(用户空间)和 Kernel space(内核空间)。安全

简单说,Kernel space 是 Linux 内核的运行空间,User space 是用户程序的运行空间。为了安全,它们是隔离的,即便用户的程序崩溃了,内核也不受影响。学习

Kernel space 能够执行任意命令,调用系统的一切资源;User space 只能执行简单的运算,不能直接调用系统资源,必须经过系统接口(又称 system call),才能向内核发出指令。spa

str = "my string" // 用户空间
x = x + 2 // 用户空间
file.write(str) // 切换到内核空间
y = x + 4 // 切换回用户空间

上面代码中,第一行和第二行都是简单的赋值运算,在 User space 执行。第三行须要写入文件,就要切换到 Kernel space,由于用户不能直接写文件,必须经过内核安排。第四行又是赋值运算,就切换回 User space。code

查看 CPU 时间在 User space 与 Kernel Space 之间的分配状况,可使用top
命令。它的第三行输出就是 CPU 时间分配统计。blog

这一行有 8 项统计指标。接口

其中,第一项24.8 us(user 的缩写)就是 CPU 消耗在 User space 的时间百分比,第二项0.5 sy(system 的缩写)是消耗在 Kernel space 的时间百分比。进程

随便也说一下其余 6 个指标的含义。资源

  • ni:niceness 的缩写,CPU 消耗在 nice 进程(低优先级)的时间百分比
  • id:idle 的缩写,CPU 消耗在闲置进程的时间百分比,这个值越低,表示 CPU 越忙
  • wa:wait 的缩写,CPU 等待外部 I/O 的时间百分比,这段时间 CPU 不能干其余事,可是也没有执行运算,这个值过高就说明外部设备有问题
  • hi:hardware interrupt 的缩写,CPU 响应硬件中断请求的时间百分比
  • si:software interrupt 的缩写,CPU 响应软件中断请求的时间百分比
  • st:stole time 的缩写,该项指标只对虚拟机有效,表示分配给当前虚拟机的 CPU 时间之中,被同一台物理机上的其余虚拟机偷走的时间百分比

若是想查看单个程序的耗时,通常使用time命令。虚拟机

 

程序名以前加上time命令,会在程序执行完毕之后,默认显示三行统计。string

  • real:程序从开始运行到结束的所有时间,这是用户能感知到的时间,包括CPU切换去执行其余任务的时间。
  • user:程序在 User space 执行的时间
  • sys:程序在 Kernel space 执行的时间

user和sys之和,通常状况下,应该小于real。但若是是多核 CPU,这两个指标反映的是全部 CPU 的总耗时,因此它们之和可能大于real。

User space vs kernel space

相关文章
相关标签/搜索