linux命令进度调度 linux 调度时机

Linux 进程管理之进程调度与切换我们知道,进程运行需要各种各样的系统资源 , 如内存、文件、打印机和最
宝贵的 CPU 等 , 所以说,调度的实质就是资源的分配 。系统通过不同的调度算法(Scheduling Algorithm)来实现这种资源的分配 。通常来说,选择什么样的调度算法取决于资源分配的策略(Scheduling Policy) 。
有关调度相关的结构保存在 task_struct 中,如下linux命令进度调度:
active_mm 是为内核线程而引入的,因为内核线程没有自己的地址空间 , 为了让内核线程与普通进程具有统一的上下文切换方式,当内核线程进行上下文切换时,让切换进来的线程的 active_mm 指向刚被调度出去的进程的 active_mm(如果进程的mm 域不为空,则其 active_mm 域与 mm 域相同) 。
在 linux 2.6 中 sched_class 表示该进程所属的调度器类有3种linux命令进度调度:
进程的调度策略有5种 , 用户可以调用调度器里不同的调度策略:
在每个 CPU 中都有一个自身的运行队列 rq,每个活动进程只出现在一个运行队列中 , 在多个 CPU 上同时运行一个进程是不可能的 。
运行队列是使用如下结构实现的:
tast 作为调度实体加入到 CPU 中的调度队列中 。
系统中所有的运行队列都在 runqueues 数组中 , 该数组的每个元素分别对应于系统中的一个 CPU 。在单处理器系统中,由于只需要一个就绪队列,因此数组只有一个元素 。
内核也定义了一下便利的宏,其含义很明显 。
Linux、c/c服务器开发篇-------我们来聊聊进程的那些事
Linux内核 进程间通信组件的实现
学习地址:C/CLinux服务器开发/后台架构师【零声教育】-学习视频教程-腾讯课堂
需要C/CLinux服务器架构师学习资料加qun812855908获?。ㄗ柿习?C/C , Linux,golang技术 , Nginx , ZeroMQ,MySQL,Redis , fastdfs , MongoDB,ZK,流媒体,CDN,P2P,K8S,Docker,TCP/IP,协程 , DPDK,ffmpeg等),免费分享
在分析调度流程之前,我们先来看在什么情况下要执行调度程序,我们把这种情况叫做调度时机 。
Linux 调度时机主要有 。
时机1,进程要调用 sleep() 或 exit() 等函数进行状态转换,这些函数会主动调用调度程序进行进程调度 。
时机2,由于进程的时间片是由时钟中断来更新的,因此,这种情况和时机4 是一样的 。
时机3,当设备驱动程序执行长而重复的任务时 , 直接调用调度程序 。在每次反复循环中,驱动程序都检查 need_resched 的值,如果必要,则调用调度程序 schedule() 主动放弃 CPU 。
时机4 , 如前所述, 不管是从中断、异常还是系统调用返回,最终都调用 ret_from_sys_call(),由这个函数进行调度标志的检测,如果必要,则调用调用调度程序 。那么,为什么从系统调用返回时要调用调度程序呢linux命令进度调度?这当然是从效率考虑 。从系统调用返回意味着要离开内核态而返回到用户态,而状态的转换要花费一定的时间,因此,在返回到用户态前,系统把在内核态该处理的事全部做完 。
Linux 的调度程序是一个叫 Schedule() 的函数,这个函数来决定是否要进行进程的切换,如果要切换的话 , 切换到哪个进程等 。
从代码分析来看 , Schedule 主要完成了2个功能:
进程上下文切换包括进程的地址空间的切换和执行环境的切换 。
对于 switch_mm 处理,关键的一步就是它将新进程页面目录的起始物理地址装入到寄存器 CR3 中 。CR3 寄存器总是指向当前进程的页面目录 。
switch_to 把寄存器中的值比如esp等存放到进程thread结构中,保存现场一边后续恢复,同时调用 __switch_to 完成了堆栈的切换 。
在进程的 task_struct 结构中有个重要的成分 thread,它本身是一个数据结构 thread_struct, 里面记录着进程在切换时的(系统空间)堆栈指针,取指令地址(也就是“返回地址”)等关键性的信息 。
关于__switch_to 的工作就是处理 TSS (任务状态段) 。
TSS 全称task state segment,是指在操作系统进程管理的过程中,任务(进程)切换时的任务现场信息 。
linux 为每一个 CPU 提供一个 TSS 段,并且在 TR 寄存器中保存该段 。
linux 中之所以为每一个 CPU 提供一个 TSS 段,而不是为每个进程提供一个TSS 段,主要原因是 TR 寄存器永远指向它,在任务切换的适合不必切换 TR 寄存器,从而减小开销 。
在从用户态切换到内核态时,可以通过获取 TSS 段中的 esp0 来获取当前进程的内核栈 栈顶指针,从而可以保存用户态的 cs,esp,eip 等上下文 。
TSS 在任务切换过程中起着重要作用,通过它实现任务的挂起和恢复 。所谓任务切换是指 , 挂起当前正在执行的任务,恢复或启动另一任务的执行 。
在任务切换过程中,首先,处理器中各寄存器的当前值被自动保存到 TR(任务寄存器)所指定的任务的 TSS 中linux命令进度调度;然后,下一任务的 TSS 被装入 TR;最后 , 从 TR 所指定的 TSS 中取出各寄存器的值送到处理器的各寄存器中 。由此可见,通过在 TSS 中保存任务现场各寄存器状态的完整映象,实现任务的切换 。
因此,__switch_to 核心内容就是将 TSS 中的内核空间(0级)堆栈指针换成 next-esp0 。这是因为 CPU 在穿越中断门或者陷阱门时要根据新的运行级别从TSS中取得进程在系统空间的堆栈指针 。
thread_struct.esp0 指向进程的系统空间堆栈的顶端 。当一个进程被调度运行时 , 内核会将这个变量写入 TSS 的 esp0 字段,表示这个进程进入0级运行时其堆栈的位置 。换句话说,进程的 thread_struct 结构中的 esp0 保存着其系统空间堆栈指针 。当进程穿过中断门、陷阱门或者调用门进入系统空间时,处理器会从这里恢复期系统空间栈 。
由于栈中变量的访问依赖的是段、页、和 esp、ebp 等这些寄存器,所以当段、页、寄存器切换完以后,栈中的变量就可以被访问了 。
因此 switch_to 完成了进程堆栈的切换,由于被切进的进程各个寄存器的信息已完成切换,因此 next 进程得以执行指令运行 。
由于 A 进程在调用 switch_to 完成了与 B 进程堆栈的切换,也即是寄存器中的值都是 B 的,所以 A 进程在switch_to 执行完后,A停止运行,B开始运行,当过一段时间又把 A 进程切进去后,A 开始从switch_to 后面的代码开始执行 。
schedule 的调用流程如下:
Linux进程的查看和调度分别使用什么命令进程查看的命令是ps和top 。
ps 命令用于查看当前正在运行的进程 。
进程调度的命令有at , crontab,batch,kill 。
浅析Linux下进程的调度策略与优先级 在 Linux 中,线程是由进程来实现的,可以认为线程就是一个轻量级的进程,因此,线程调度是按照进程调度的方式来进行的 。这样设计,线程调度流程可以直接复用进程调度流程,没必要再设计一个进程内的线程调度器了 。
在 Linux 中,进程调度器是基于进程的调度策略与调度优先级来决定调度哪个进程运行 。
调度策略主要包括:
调度优先级的范围是 0~99 , 数值越大,表示优先级越高 。
其中,SCHED_OTHER、SCHED_IDLE、SCHED_BACH 为非实时调度策略 , 其调度优先级为 0 。而 SCHED_FIFO、SCHED_RR 是实时调度策略,其调度优先级范围为 1~99 。
实时调度策略的进程总是比非实时调度策略的进程优先级高 。
在 Linux 内部实现中,调度器会为每个可能的调度优先级维护一个可运行的进程列表,以最高优先级列表头部的进程作为下一次调度的进程,所有的调度都是抢占式的,如果一个具有更高调度优先级的进程转换为可运行状态 , 那么当前运行的进程将被强制进入其等待的队列中 。
SCHED_OTHER
该调度策略是默认的 Linux 分时调度策略,该调度策略为非实时的,其调度优先级总是为 0 。
对于该调度策略类型的进程,调度器是基于动态优先级来调度的 。动态优先级跟属性 nice 有关,nice 的值会随着进程的运行时间而动态改变 , 以确保所有具有 SCHED_OTHER 策略的进程公平地得到调度 。
在 Linux 中,nice 的值范围为-20 ~19,默认值为 0 。nice 值越大,则优先级越低,因此相对较低 nice 值的进程可以获得更多的处理器时间 。
通过命令ps -el查看系统中的进程列表,其中NI列就是进程对应的 nice 值 。
使用top命令,看到的NI列也是进程的 nice 值 。
调整 nice 值,可以通过 shell 命令nice ,该命令可以按照指定的 nice 值运行cmd ,命令的帮助信息为:
重新调整已运行进程的 nice 值 , 可通过renice命令实现,命令的帮助信息为:
另外,可以执行top命令,输入r ,根据提示输入进程的pid ,再输入nice数值,也可以调整进程的nice值 。
SCHED_FIFO
该调度策略为先入先出调度策略,简单概括,就是一旦进程占用了 CPU,则一直运行,直到有更高优先级的任务抢占,或者进程自己放弃占用 CPU 。
SCHED_RR
该调度策略为时间片轮转调度策略,该调度策略是基于 SCHED_FIFO 策略的演进 , 其在每个进程上增加一个时间片限制,当时间片使用完成后,调度器将该进程置于队列的尾端,放在尾端保证了所有具有相同调度优先级的进程的调度公平 。
使用top命令,如果PR列的值为RT ,则说明该进程采用的是实时调度策略,其调度策略为 SCHED_FIFO 或者 SCHED_RR,而对于非实时调度策略的进程,该列的值为NI20。
可以通过命令ps -eo state,uid,pid,ppid,rtprio,time,comm来查看进程对应的实时优先级,实时优先级位于RTPRIO列下,如果进程对应的列显示为- ,说明该进程不是实时进程 。
chrt命令可以用来很简单地更改进程的调度策略与调度优先级 。在 Linux 下查看chrt命令的帮助信息:
比如,获取某个进程的调度策略,使用如下命令:
在比如,设置某个进程的调度策略为 SCHED_FIFO,调度优先级为 70 , 使用如下命令:
Linux进程调度的概述Linux的调度程序是一个叫Schedule()的函数,由它来决定是否要进行进程的切换 。而所谓的调度时机则是在什么情况下执行调度程序 。
Linux进程调度采用的是抢占式多任务处理 , 所以进程之间的挂起和继续运行无需彼此之间的协作 。
主要分为以下几种情况:
1、进程状态转换的时刻:进程终止、进程睡眠
进程要调用sleep()或exit()等函数进行状态转换,这些函数会主动调用调度程序进行进程调度 。
2、当前进程的时间片用完时(current-counter=0)
由于进程的时间片是由时钟中断来更新的,因此,这种情况和时机4是一样的 。
3、设备驱动程序
当设备驱动程序执行长而重复的任务时,直接调用调度程序 。在每次反复循环中,驱动程序都检查need_resched的值 , 如果必要,则调用调度程序schedule()主动放弃CPU 。
4、进程从中断、异常及系统调用返回到用户态时
不管是从中断、异常还是系统调用返回,最终都调用ret_from_sys_call() , 由这个函数进行调度标志的检测,如果必要,则调用调度程序 。
Linux中如何启动进程?进程调度命令有哪些?Linux技术的发展引起了很多企业和个人的关注 。市场对Linux运维的需求逐渐增加 , 学习Linux技术的人越来越多 。在Linux运维中,进程是必须学习掌握的技能 。那么Linux中如何启动进程?常用的进程调度命令有哪些?
执行中的程序称作进程 。当程序的可执行文件存储在存储器中并运行时 , 每个进程将被动态分配系统资源、内存、安全属性和相关状态 。多个进程可以与同一个程序相关联,并在同一时间执行 , 而不会相互干扰 。操作系统将有效地管理和跟踪所有正在运行的进程 。
Linux中如何启动进程?启动进程的方法是什么?
手工启动 。用户在输入端发出命令,直接启动进程 。分为前台启动和后台启动 。前台启动:直接在SHELL中输入命令进行启动 。后台启动:启动一个目前并不紧急的进程 。
调度启动 。系统管理员根据系统资源和进程占用资源的情况 , 事先进行调度安排,指定任务运行的时间和场合 , 到时候系统会自动完成该任务 。
常用的进程调度命令有哪些?
常用的进程调度命令有:at、batch、crontab 。
以上便是关于“如何启动或终止进程?常用的进程调度命令有哪些?”的相关介绍 。想要成为一名优秀的Linux运维工程师,需要掌握更多的Linux知识 。
【linux命令进度调度 linux 调度时机】linux命令进度调度的介绍就聊到这里吧 , 感谢你花时间阅读本站内容,更多关于linux 调度时机、linux命令进度调度的信息别忘了在本站进行查找喔 。

    推荐阅读