今天因为查一个Java zero copy的问题,遇到了kernel space。之前是耳闻过内核空间的,但是看到kernel space不知道是啥。知道的太少,除了学习,我也做不了啥。因为自己认知有限,有很多文章博客写的非常系统,非常深入,我仅拿最基础的来了解,作为自己的学习笔记。

习 Linux 时,经常可以看到两个词:User space(用户空间)和 Kernel space(内核空间)。

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

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


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

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

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

这一行有 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命令,会在程序执行完毕以后,默认显示三行统计。

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

usersys之和,一般情况下,应该小于real。但如果是多核 CPU,这两个指标反映的是所有 CPU 的总耗时,所以它们之和可能大于real

学习并转载自:http://www.ruanyifeng.com/blog/2016/12/user_space_vs_kernel_space.html

最新文章

  1. Angular企业级开发(1)-AngularJS简介
  2. CSharpGL(36)通用的非托管数组排序方法
  3. 【原创】开源.NET排列组合组件KwCombinatorics使用(二)——排列生成
  4. Python学习 过程中零散知识点的总结
  5. highcharts 柱状图 动态加载
  6. HTML中input标签的alt属性和title属性的比较
  7. hdoj 5003
  8. 继续转 [转]php版本的cron定时任务执行器
  9. input 中的enabled与disabled属性
  10. python3.0_day9_scoket基础之篇
  11. 初识MFC,WinForm,WPF,Q't
  12. OpenCV-Python教程(10、直方图均衡化)
  13. Openstack新建云主机的流程
  14. 使用 electron 做个播放器
  15. 80C51学习 蜂鸣器
  16. Linux磁盘分区-rpm-yum
  17. RabbitMQ分布式集群架构和高可用性(HA)
  18. 使用Dockerfile定制ubuntu+nginx镜像
  19. syslog-ng内容讲解
  20. 【MVC】Spring MVC常用配置

热门文章

  1. osgEarth的agglite插件使用例子feature_rasterize.earth
  2. ubuntu的安装方法
  3. php学习十:继承
  4. 剑指offer练习
  5. Map的有序实现类和无序实现类
  6. ajax jquery校验用户是否已经注册
  7. MQTT-SN协议乱翻之功能描述
  8. JavaWeb温习之HttpServletResponse对象
  9. EUI EXML内部类Skin和ItemRenderer
  10. WebConfig配置详解大全