
com.hazelcast.internal.networking.nio.iobalancer.LoadImbalance Maven / Gradle / Ivy
The newest version!
/*
* Copyright (c) 2008-2024, Hazelcast, Inc. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.hazelcast.internal.networking.nio.iobalancer;
import com.hazelcast.internal.networking.nio.MigratablePipeline;
import com.hazelcast.internal.networking.nio.NioPipeline;
import com.hazelcast.internal.networking.nio.NioThread;
import com.hazelcast.internal.util.ItemCounter;
import java.util.Map;
import java.util.Set;
/**
* Describes a state of NioThread (im-)balance.
*
* It's used by {@link MigrationStrategy} to decide whether and what
* {@link NioPipeline} should be migrated.
*/
class LoadImbalance {
//load recorded by the busiest NioThread
long maximumLoad;
//load recorded by the least busy NioThread
long minimumLoad;
//busiest NioThread
NioThread srcOwner;
//least busy NioThread
NioThread dstOwner;
private final Map> ownerToPipelines;
private final ItemCounter pipelineLoadCounter;
LoadImbalance(Map> ownerToPipelines,
ItemCounter pipelineLoadCounter) {
this.ownerToPipelines = ownerToPipelines;
this.pipelineLoadCounter = pipelineLoadCounter;
}
/**
* @param owner
* @return A set of Pipelines owned by the owner
*/
Set getPipelinesOwnedBy(NioThread owner) {
return ownerToPipelines.get(owner);
}
/**
* @param pipeline
* @return load recorded by the pipeline
*/
long getLoad(MigratablePipeline pipeline) {
return pipelineLoadCounter.get(pipeline);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy