You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							37 lines
						
					
					
						
							956 B
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							37 lines
						
					
					
						
							956 B
						
					
					
				
								package balance
							 | 
						|
								
							 | 
						|
								import (
							 | 
						|
									"github.com/seaweedfs/seaweedfs/weed/worker/tasks/base"
							 | 
						|
									"github.com/seaweedfs/seaweedfs/weed/worker/types"
							 | 
						|
								)
							 | 
						|
								
							 | 
						|
								// Scheduling implements the scheduling logic for balance tasks
							 | 
						|
								func Scheduling(task *types.TaskInput, runningTasks []*types.TaskInput, availableWorkers []*types.WorkerData, config base.TaskConfig) bool {
							 | 
						|
									balanceConfig := config.(*Config)
							 | 
						|
								
							 | 
						|
									// Count running balance tasks
							 | 
						|
									runningBalanceCount := 0
							 | 
						|
									for _, runningTask := range runningTasks {
							 | 
						|
										if runningTask.Type == types.TaskTypeBalance {
							 | 
						|
											runningBalanceCount++
							 | 
						|
										}
							 | 
						|
									}
							 | 
						|
								
							 | 
						|
									// Check concurrency limit
							 | 
						|
									if runningBalanceCount >= balanceConfig.MaxConcurrent {
							 | 
						|
										return false
							 | 
						|
									}
							 | 
						|
								
							 | 
						|
									// Check if we have available workers
							 | 
						|
									availableWorkerCount := 0
							 | 
						|
									for _, worker := range availableWorkers {
							 | 
						|
										for _, capability := range worker.Capabilities {
							 | 
						|
											if capability == types.TaskTypeBalance {
							 | 
						|
												availableWorkerCount++
							 | 
						|
												break
							 | 
						|
											}
							 | 
						|
										}
							 | 
						|
									}
							 | 
						|
								
							 | 
						|
									return availableWorkerCount > 0
							 | 
						|
								}
							 |