请输入您要查询的百科知识:

 

词条 Run queue
释义

  1. See also

  2. References

{{Unreferenced|date=December 2009}}

In modern computers many processes run at once. Active processes are placed in an array called a run queue, or runqueue. The run queue may contain priority values for each process, which will be used by the scheduler to determine which process to run next. To ensure each program has a fair share of resources, each one is run for some time period (quantum) before it is paused and placed back into the run queue. When a program is stopped to let another run, the program with the highest priority in the run queue is then allowed to execute.

Processes are also removed from the run queue when they ask to sleep, are waiting on a resource to become available, or have been terminated.

In the Linux operating system (prior to kernel 2.6.23), each CPU in the system is given a run queue, which maintains both an active and expired array of processes. Each array contains 140 (one for each priority level) pointers to doubly linked lists, which in turn reference all processes with the given priority. The scheduler selects the next process from the active array with highest priority. When a process' quantum expires, it is placed into the expired array with some priority. When the active array contains no more processes, the scheduler swaps the active and expired arrays, hence the name O(1) scheduler.

In UNIX or Linux, the sar command is used to check the run queue.

The vmstat UNIX or Linux command can also be used to determine the number of processes that are queued to run or waiting to run. These appear in the 'r' column.

There are two models for Run queues: one that assigns a Run Queue to each physical processor, and the other has only one Run Queue in the system

See also

  • Completely Fair Scheduler, the scheduling algorithm used by Linux since kernel 2.6.23

References

  • Tanenbaum AS (2008) Modern Operating Systems, 3rd ed., p. 753-4. Pearson Education, Inc. {{ISBN|0-13-600663-9}}
  • Silberschatz, Galvin, Gange (2012) Operating System Concepts, 9th ed.. Wiley, {{ISBN|978-1-118-09333-0}}
{{DEFAULTSORT:Run Queue}}

2 : Scheduling (computing)|Linux kernel

随便看

 

开放百科全书收录14589846条英语、德语、日语等多语种百科知识,基本涵盖了大多数领域的百科知识,是一部内容自由、开放的电子版国际百科全书。

 

Copyright © 2023 OENC.NET All Rights Reserved
京ICP备2021023879号 更新时间:2024/9/21 8:24:37