-
Notifications
You must be signed in to change notification settings - Fork 293
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
0d8941a
commit 103ab76
Showing
1 changed file
with
50 additions
and
0 deletions.
There are no files selected for viewing
50 changes: 50 additions & 0 deletions
50
Miscellaneous Algorithms/proportional scheduling/two level scheduling/README.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,50 @@ | ||
Two-Level Scheduling is a CPU scheduling technique used primarily in systems with multiple processors or distributed environments. It separates scheduling into two distinct levels: a high-level (or global) scheduler and a low-level (or local) scheduler. The high-level scheduler assigns processes to specific CPUs, while the low-level scheduler manages the execution of those processes on each individual CPU. This approach allows for more efficient CPU utilization and better performance, especially in multi-core or distributed systems. | ||
|
||
How Two-Level Scheduling Works | ||
High-Level Scheduling: | ||
In this first stage, the high-level scheduler assigns processes to different CPUs or processors based on factors like CPU load, process priority, and resource requirements. This scheduling happens less frequently and helps balance the load across multiple CPUs. | ||
Low-Level Scheduling: | ||
Once a process is assigned to a CPU, the low-level scheduler (often using algorithms like round-robin, shortest job next, or priority scheduling) manages the execution of processes on that CPU. This level of scheduling operates more frequently, focusing on the efficient and fair use of the CPU it controls. | ||
Pros of Two-Level Scheduling | ||
Improved Load Balancing: | ||
|
||
The high-level scheduler helps distribute workload across multiple CPUs, avoiding situations where some CPUs are overloaded while others are underutilized. This improves overall system performance and resource usage. | ||
Enhanced Scalability: | ||
|
||
By offloading the process distribution responsibility to the high-level scheduler, the system can handle a large number of processes efficiently, making it ideal for multi-core and distributed systems. | ||
Better Responsiveness and Fairness: | ||
|
||
With a dedicated scheduler on each CPU, low-level scheduling ensures quick, responsive task handling within each CPU, while the high-level scheduler maintains fairness across CPUs. | ||
Efficient Multi-Core Usage: | ||
|
||
Two-level scheduling maximizes the use of multi-core processors by allowing CPUs to independently manage tasks assigned to them, leading to higher throughput. | ||
Reduced Context Switching: | ||
|
||
Processes are assigned to a specific CPU by the high-level scheduler, reducing the need for frequent process migrations between CPUs, which minimizes context switching overhead. | ||
Cons of Two-Level Scheduling | ||
Increased Complexity: | ||
|
||
Managing two levels of scheduling requires more complex algorithms and data structures, especially when balancing load across CPUs and handling process migrations. | ||
Higher Overhead: | ||
|
||
The two-layered approach can introduce overhead, as there are now two schedulers operating at different levels. The system needs to track which processes are assigned to which CPUs and manage load distribution. | ||
Potential CPU Idle Time: | ||
|
||
If the high-level scheduler doesn't efficiently assign processes to each CPU, it may lead to scenarios where some CPUs remain idle or underutilized, which can reduce efficiency. | ||
Challenges in Process Migration: | ||
|
||
Migrating processes between CPUs, if required, can be complex and may cause performance penalties. Process migration often requires additional mechanisms to transfer process states between CPUs without affecting performance. | ||
Suboptimal for Single-Core Systems: | ||
|
||
Two-level scheduling adds unnecessary complexity in single-core or less complex environments, where simpler scheduling techniques (like round-robin or priority-based scheduling) would suffice. | ||
Use Cases for Two-Level Scheduling | ||
Multi-Core Systems: In systems with multiple cores or processors, two-level scheduling maximizes core usage and balances the load effectively. | ||
Distributed Systems: In distributed computing environments, where multiple machines or nodes are available, two-level scheduling helps in resource allocation across nodes. | ||
Real-Time and High-Performance Applications: For systems needing high responsiveness and parallelism, such as web servers, scientific computing, or cloud-based applications, two-level scheduling improves resource allocation and responsiveness. | ||
Overall, two-level scheduling is a powerful approach for handling large-scale and multi-core workloads efficiently. However, it introduces additional complexity and overhead, making it most suitable for high-performance, multi-core, or distributed systems. | ||
|
||
|
||
|
||
|
||
|
||
|