Skip to content

Commit

Permalink
Create readme.md
Browse files Browse the repository at this point in the history
  • Loading branch information
khwaishchawla authored Nov 9, 2024
1 parent 103ab76 commit 07247e7
Showing 1 changed file with 50 additions and 0 deletions.
50 changes: 50 additions & 0 deletions Miscellaneous Algorithmstw/twolevel/readme.md
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.






0 comments on commit 07247e7

Please sign in to comment.