LinuxGod

LinuxGod.net
Linux大神网——精选每一篇高品质的技术干货
  1. 首页
  2. 开源快讯
  3. 正文

Linux内核设计与线程上周的运作机制与实现及其相关资料

2023年2月11日 298点热度

了解Linux的进程与线程

上周遇到布署在真实服务器上某个应用CPU占用过低的问题,即使经过tuning,问题其实早已解决,但我对tuning的方法只是基于大胆的假定并最终生效了。我更希望更多的求证一下程序背后CPU及OSkernel当时的运作机制。所以我读了一些Linux内核设计与实现及其他一些相关资料,对Linuxprocess的机制与切换有了更多一些感受。本文尽可能条理一点,但因为涉入点较多,同时自己可能认为个别点有记录的价值,因而文字可能会零散。

进程状态

Linux进程的状态比较容易理解,值得注意的是UNINTERRUPTIBLE及ZOMBIE

TASK_RUNNING

TASK_INTERRUPTIBLE

TASK_UNINTERRUPTIBLE此时进程不接收讯号,这就是为何有时侯kill一个忙碌的进程没有响应。

TASK_ZOMBIE我们常常kill-9pid然后运行ps会发觉被kill的进程依旧存在,状态为zombie。zombie的进程实际上早已结束,占用的资源也早已释放,仅因为kernel的相关进程描述符还未释放。

TASK_STOPPED

Kernelspaceanduserspace

Kernelspace是供内核,设备驱动运行的显存区域。userspace是供普通应用程序运行的区域。每一个进程都运行在自己的虚拟显存区域,不能访问其他进程的显存空间。普通进程不能访问kernelspace,只能通过系统调用来间接进行。当系统显存比较紧张时,非当前运行进程userspace可能会被swap到c盘。

使用命令pmap-x

可以查看进程的显存占用信息;lsof-a-p

可以查看一个进程打开的文件信息。ps-Lf

可以查看进程的线程数。

另外procfs也是一个剖析进程结构的好地方。procfs是一个虚拟的文件系统,它把系统中正在运行的进程都显现今/proc/

目录下。

linux线程和进程的区别_linux 进程线程_linux进程线程

进程创建

进程创建一般调用fork实现。创建后子进程和父进程指向同一显存区域,仅当子进程有write发生时侯,就会把改动的区域copy到子进程新的地址空间,这就是copy-on-write技术,它极大的提升了创建进程的速率。

Linux的线程实现

Linux线程是通过进程来实现。Linuxkernel为进程创建提供一个clone()系统调用,clone的参数包括如CLONE_VM,CLONE_FILES,CLONE_SIGHAND等。通过clone()的参数,新创建的进程,俗称为LWP(Lightweightprocess)与父进程共享显存空间,文件句柄,讯号处理等,因而达到创建线程相同的目的。

Linux2.6的线程库叫NPTL(NativePOSIXThreadLibrary)。POSIXthread(pthread)是一个编程规范,通过此规范开发的多线程程序具有良好的跨平台特点。虽然是基于进程的实现,但新版的NPTL创建线程的效率十分高。一些测试显示linux线程和进程的区别,基于NPTL的内核创建10万个线程只须要2秒linux解压命令,而没有NPTL支持的内核则须要历时15分钟。

linux线程和进程的区别_linux 进程线程_linux进程线程

在Linux2.6之前,Linuxkernel并没有真正的thread支持,一些threadlibrary都是在clone()基础上的一些基于userspace的封装,因而一般在讯号处理、进程调度(每位进程须要一个额外的调度线程)及多线程之间同步共享资源等方面存在一定问题。为了解决这种问题,当初IBM以前开发一套NGPT(NextGenerationPOSIXThreads),效率比LinuxThreads有显著改进,但因为NPTL的推出,NGPT也完成了相关的历史使命并停止了开发。

NPTL的实现是在kernel降低了futex(fastuserspacemutex)支持用于处理线程之间的sleep与wake。futex是一种高效的对共享资源互斥访问的算法。kernel在上面起仲裁作用,但一般都由进程自行完成。

NPTL是一个1×1的线程模型,即一个线程对于一个操作系统的调度进程,优点是十分简单。而其他一些操作系统例如Solaris则是MxN的,M对应创建的线程数嵌入式linux 培训,N对应操作系统可以运行的实体。(N

讯号

进程接收讯号有两种:同步和异步。同步讯号譬如SEGILL(非法访问),SIGSEGV(segmentationfault)等。发生这种讯号然后,系统会立刻转入内核圈套处理程序,因而同步讯号称作为圈套。异步讯号如kill,lwp_kill,sigsend等调用形成的都是,异步讯号称作为中断。

linux 进程线程_linux进程线程_linux线程和进程的区别

kill

调用的是SIGTERM,此讯号可以被捕获和忽视。

kill-9

调用的是SIGKILL,杀坠入程,不能被捕获和忽视。

SIGHUP是在终端被断掉时侯调用,假如讯号没有被处理,进程会中止。这就是为何忽然断网刚通过远程终端启动的进程都中止的诱因。避免的方式是在启动的命令前加上nohup命令来忽视SIGHUP讯号。如nohup./startup.sh&

好多应用程序一般捕获SIGHUP拿来实现一些自定义特点,例如通过控制台传递讯号让正在运行的程序重新加载配置文件,防止重启带来的停止服务的副作用。可惜的是,在JAVA中无法直接使用这一功能linux线程和进程的区别,SUNJVM没有官方的signal支持,虽然它早已可以实现,详情可参看SingalsandJava.

另外有个有趣的现象是zombie状态的进程kill/kill-9都没有任何作用,这是因为进程本身早已不存在,所以没有相应的进程来处理signal,zombie状态的进程只是kernel中的进程描述符及相关数据结构没有释放,但进程实体早已不存在了。

本作品采用 知识共享署名 4.0 国际许可协议 进行许可
标签: 信号 内核 线程 调用 进程
最后更新:2023年2月11日

Linux大神网

每日更新,欢迎收藏♥ 不积跬步无以至千里,加油,共勉。

点赞
< 上一篇
下一篇 >

Linux大神网

每日更新,欢迎收藏♥
不积跬步无以至千里,加油,共勉。

最新 热点 随机
最新 热点 随机
如何在Linux上安装视频播放器installvlc 晚上暴露于蓝光,睡眠质量大打折扣 如何安装便携式WiFi驱动程序?360wifi驱动的教程 CentOS云服务器搭建网站和CentOS搭建DNS解析服务 如何在linux上创建一个用户,减少不必要的沟通成本 如何在Linux系统中查看CPU信息使用lscpu命令行 linux服务器搭建ftp的6下安装vsftpd步骤及步骤 贵州工业职业技术学院求职意向期望工作地--诚聘英才 实验1Linux安装实验掌握虚拟机的使用 Linux系统tar命令的使用方法及使用命令教程 linux 开源nas系统 杰和科技NAS服务器媒体见面会在京召开 Android与Linux开发大不同 Linux系统软件安装包:自己动手,安装不用愁 车市新战局:汽车操作系统会复制智能手机的历史吗? Linux文件系统种类 如何卸载用源码包安装的软件?在线视频教程推荐 「职位」ASP.、PHP、Linux服务器集群开发 Torvalds:Linux内核开发的创新前景充满了热情 Linux文件系统的结构从终端窗口探索Linux目录树结构 卸载软件命令Linux.You
嵌入式Linux操作系统学习规划+LINUX路线,主攻江苏电信天翼校园客户端故障指引及解决办法(101)英特尔GMAGMA950显卡驱动程序/WIN8/8.1电信校园网宽带用USB数据线共享给电脑无线上网国防科大开源操作系统:它只是一个吉祥的象征10个常用Linux文本查看命令及其详细说明和使用示例Linux嵌入式系统内核裁剪与定制方法的介绍情况淘宝教育热卖C语言编程开发C++程序设计零基础入门课程从CPU、内存、硬盘、显卡等这些方面安装Linux系统的最低配置Linux通过chkconfig设置开机启动服务创建的几种常见方式(技术分析)Linux多线程的使用与操作系统的区别通常rar命令由一个主命令加若干选项(可选)构成RedHatLinux中自动运行程序中的应用linux 读写文件 关于Linux内核的神秘面纱,你知道几个?使用wget实用程序的有用命令行工具的使用怎么设置linux开机项自启动?方式是怎样的?嵌入式Linux应用层与驱动层要想学习关于Linux内核的交叉编译步骤和方法:步骤、方法STM32嵌入式linux开发流程及应用程序分析-STMlinux下有哪些文件在介绍lsof命令实用用法介绍?
Contents[show]如何在Linux中创建目录和子文件夹? 【知识点】如何记录常用的linux命令?(二) 如何增加Linux中打开文件max的文件限制数量? LinuxKernel5.7引入了第三种方式:LSM扩展伯克利包过滤器 Linux的多用户多任务的运行机制-Linux用户管理 0渗透操作0x02绕过disable_functions插件(组图) Linux系统安全防护工具的应用方法 基于RK3399SoC的ARM板硬件资源丰富 Ubuntu上使用的默认浏览器为Firefox,该怎么安装? Linux软件安装查询 proc的缩写与内核相关的文件-上海怡健医学 linux下一些常用的关机/重启命令,你知道吗? 苹果MacOSX系统刷新DNS的方法,你知道吗? 什么是Windows系统MicrosoftWindows,linux系统和windows系统的区别 《Linux命令全集》之Linux命令解释和例子 GCC在Linux内核方面的速度比LLVM/Clang更快 小白在阿里云云服务器上如何发布自己的网站(建站|详细) 进程介绍进程管理进程优先级什么是进程? Linux生态系统开发工具总结环境开发的工具介绍 Linux下最常用的打包程序是什么?怎么破?
标签聚合
linux服务器 文件 文件目录 linux系统 应用 软件 虚拟机 内核 命令 操作
书籍
课程
技术群
技术干货大合集↓
  • 2023年9月 / 83篇
  • 2023年8月 / 93篇
  • 2023年7月 / 94篇
  • 2023年6月 / 90篇
  • 2023年5月 / 93篇
  • 2023年4月 / 90篇
  • 2023年3月 / 129篇
  • 2023年2月 / 84篇
  • 2023年1月 / 161篇
  • 2022年12月 / 187篇
  • 2022年11月 / 76篇
友情链接:

Linux书籍 | Linux命令 | Linux系统 | RHCE红帽认证 | Linux软件 | Linux教程 | CentOS系统 | Linux内核 | Linux服务器 | Linux大神 | IT资源

COPYRIGHT © 2023 linuxgod.net ALL RIGHTS RESERVED.