本文整理匯總了Java中org.onosproject.incubator.net.resource.label.LabelResourcePool類的典型用法代碼示例。如果您正苦於以下問題:Java LabelResourcePool類的具體用法?Java LabelResourcePool怎麽用?Java LabelResourcePool使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
LabelResourcePool類屬於org.onosproject.incubator.net.resource.label包,在下文中一共展示了LabelResourcePool類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: create
import org.onosproject.incubator.net.resource.label.LabelResourcePool; //導入依賴的package包/類
private boolean create(LabelResourcePool pool) {
Device device = deviceService.getDevice(pool.deviceId());
if (device == null) {
return false;
}
NodeId master = mastershipService.getMasterFor(pool.deviceId());
if (master == null) {
log.warn("Failed to create label resource pool: No master for {}", pool);
return false;
}
if (master.equals(clusterService.getLocalNode().id())) {
return internalCreate(pool);
}
log.trace("Forwarding getFlowEntries to {}, which is the primary (master) for device {}",
master, pool.deviceId());
return complete(clusterCommunicator
.sendAndReceive(pool,
LabelResourceMessageSubjects.LABEL_POOL_CREATED,
SERIALIZER::encode, SERIALIZER::decode,
master));
}
示例2: createDevicePool
import org.onosproject.incubator.net.resource.label.LabelResourcePool; //導入依賴的package包/類
@Override
public boolean createDevicePool(DeviceId deviceId, LabelResourceId beginLabel, LabelResourceId endLabel) {
LabelResourcePool labelResource = new LabelResourcePool(deviceId.toString(),
beginLabel.labelId(),
endLabel.labelId());
if (resourcePool.containsValue(labelResource)) {
return false;
}
resourcePool.put(deviceId, labelResource);
return true;
}
示例3: destroyDevicePool
import org.onosproject.incubator.net.resource.label.LabelResourcePool; //導入依賴的package包/類
@Override
public boolean destroyDevicePool(DeviceId deviceId) {
LabelResourcePool devicePool = resourcePool.get(deviceId);
if (devicePool == null) {
return false;
}
resourcePool.remove(deviceId);
return true;
}
示例4: createDevicePool
import org.onosproject.incubator.net.resource.label.LabelResourcePool; //導入依賴的package包/類
@Override
public boolean createDevicePool(DeviceId deviceId,
LabelResourceId beginLabel,
LabelResourceId endLabel) {
LabelResourcePool pool = new LabelResourcePool(deviceId.toString(),
beginLabel.labelId(),
endLabel.labelId());
return this.create(pool);
}
示例5: createGlobalPool
import org.onosproject.incubator.net.resource.label.LabelResourcePool; //導入依賴的package包/類
@Override
public boolean createGlobalPool(LabelResourceId beginLabel,
LabelResourceId endLabel) {
LabelResourcePool pool = new LabelResourcePool(GLOBAL_RESOURCE_POOL_DEVICE_ID,
beginLabel.labelId(),
endLabel.labelId());
return this.internalCreate(pool);
}
示例6: internalCreate
import org.onosproject.incubator.net.resource.label.LabelResourcePool; //導入依賴的package包/類
private boolean internalCreate(LabelResourcePool pool) {
Versioned<LabelResourcePool> poolOld = resourcePool
.get(pool.deviceId());
if (poolOld == null) {
resourcePool.put(pool.deviceId(), pool);
LabelResourceEvent event = new LabelResourceEvent(Type.POOL_CREATED,
pool);
notifyDelegate(event);
return true;
}
return false;
}
示例7: internalDestroy
import org.onosproject.incubator.net.resource.label.LabelResourcePool; //導入依賴的package包/類
private boolean internalDestroy(DeviceId deviceId) {
Versioned<LabelResourcePool> poolOld = resourcePool.get(deviceId);
if (poolOld != null) {
resourcePool.remove(deviceId);
LabelResourceEvent event = new LabelResourceEvent(Type.POOL_DESTROYED,
poolOld.value());
notifyDelegate(event);
}
log.info("success to destroy the label resource pool of device id {}",
deviceId);
return true;
}
示例8: isDevicePoolFull
import org.onosproject.incubator.net.resource.label.LabelResourcePool; //導入依賴的package包/類
@Override
public boolean isDevicePoolFull(DeviceId deviceId) {
Versioned<LabelResourcePool> pool = resourcePool.get(deviceId);
if (pool == null) {
return true;
}
return pool.value().currentUsedMaxLabelId() == pool.value().endLabel()
&& pool.value().releaseLabelId().size() == 0 ? true : false;
}
示例9: getFreeNumOfDevicePool
import org.onosproject.incubator.net.resource.label.LabelResourcePool; //導入依賴的package包/類
@Override
public long getFreeNumOfDevicePool(DeviceId deviceId) {
Versioned<LabelResourcePool> pool = resourcePool.get(deviceId);
if (pool == null) {
return 0;
}
return pool.value().endLabel().labelId()
- pool.value().currentUsedMaxLabelId().labelId()
+ pool.value().releaseLabelId().size();
}
示例10: execute
import org.onosproject.incubator.net.resource.label.LabelResourcePool; //導入依賴的package包/類
@Override
protected void execute() {
LabelResourceService lrs = get(LabelResourceService.class);
LabelResourcePool pool = lrs.getDeviceLabelResourcePool(DeviceId
.deviceId(deviceId));
if (pool != null) {
print(FMT, pool.deviceId().toString(), pool.beginLabel(),
pool.endLabel(), pool.totalNum(), pool.usedNum(),
pool.currentUsedMaxLabelId(), pool.releaseLabelId()
.toString());
} else {
print(FMT, deviceId, null, null, null, null, null, null);
}
}
示例11: execute
import org.onosproject.incubator.net.resource.label.LabelResourcePool; //導入依賴的package包/類
@Override
protected void execute() {
LabelResourceService lrs = get(LabelResourceService.class);
LabelResourcePool pool = lrs.getGlobalLabelResourcePool();
if (pool != null) {
print(FMT, pool.deviceId().toString(), pool.beginLabel(),
pool.endLabel(), pool.totalNum(), pool.usedNum(),
pool.currentUsedMaxLabelId(), pool.releaseLabelId()
.toString());
}
}
示例12: getDeviceLabelResourcePool
import org.onosproject.incubator.net.resource.label.LabelResourcePool; //導入依賴的package包/類
@Override
public LabelResourcePool getDeviceLabelResourcePool(DeviceId deviceId) {
checkNotNull(deviceId, "deviceId is not null");
return store.getDeviceLabelResourcePool(deviceId);
}
示例13: getGlobalLabelResourcePool
import org.onosproject.incubator.net.resource.label.LabelResourcePool; //導入依賴的package包/類
@Override
public LabelResourcePool getGlobalLabelResourcePool() {
return store.getGlobalLabelResourcePool();
}
示例14: activate
import org.onosproject.incubator.net.resource.label.LabelResourcePool; //導入依賴的package包/類
@Activate
public void activate() {
resourcePool = storageService
.<DeviceId, LabelResourcePool>consistentMapBuilder()
.withName(POOL_MAP_NAME).withSerializer(SERIALIZER)
.withPartitionsDisabled().build();
messageHandlingExecutor = Executors
.newFixedThreadPool(MESSAGE_HANDLER_THREAD_POOL_SIZE,
groupedThreads("onos/store/flow",
"message-handlers"));
clusterCommunicator
.addSubscriber(LabelResourceMessageSubjects.LABEL_POOL_CREATED,
SERIALIZER::<LabelResourcePool>decode,
operation -> {
log.trace("received get flow entry request for {}", operation);
return internalCreate(operation);
},
SERIALIZER::<Boolean>encode,
messageHandlingExecutor);
clusterCommunicator
.addSubscriber(LabelResourceMessageSubjects.LABEL_POOL_DESTROYED,
SERIALIZER::<DeviceId>decode,
deviceId -> {
log.trace("received get flow entry request for {}", deviceId);
return internalDestroy(deviceId);
},
SERIALIZER::<Boolean>encode,
messageHandlingExecutor);
clusterCommunicator
.addSubscriber(LabelResourceMessageSubjects.LABEL_POOL_APPLY,
SERIALIZER::<LabelResourceRequest>decode,
request -> {
log.trace("received get flow entry request for {}", request);
return internalApply(request);
},
SERIALIZER::<Collection<LabelResource>>encode,
messageHandlingExecutor);
clusterCommunicator
.addSubscriber(LabelResourceMessageSubjects.LABEL_POOL_RELEASE,
SERIALIZER::<LabelResourceRequest>decode,
request -> {
log.trace("received get flow entry request for {}",
request);
return internalRelease(request);
},
SERIALIZER::<Boolean>encode,
messageHandlingExecutor);
log.info("Started");
}
示例15: internalRelease
import org.onosproject.incubator.net.resource.label.LabelResourcePool; //導入依賴的package包/類
private boolean internalRelease(LabelResourceRequest request) {
DeviceId deviceId = request.deviceId();
Collection<LabelResource> release = request.releaseCollection();
Versioned<LabelResourcePool> poolOld = resourcePool.get(deviceId);
if (poolOld == null) {
log.info("the label resource pool of device id {} not allocated");
return false;
}
LabelResourcePool pool = poolOld.value();
if (pool == null) {
log.info("the label resource pool of device id {} does not exist");
return false;
}
Set<LabelResource> storeSet = new HashSet<>(pool.releaseLabelId());
LabelResource labelResource = null;
long realReleasedNum = 0;
for (Iterator<LabelResource> it = release.iterator(); it.hasNext();) {
labelResource = it.next();
if (labelResource.labelResourceId().labelId() < pool.beginLabel()
.labelId()
|| labelResource.labelResourceId().labelId() > pool
.endLabel().labelId()) {
continue;
}
if (pool.currentUsedMaxLabelId().labelId() > labelResource
.labelResourceId().labelId()
|| !storeSet.contains(labelResource)) {
storeSet.add(labelResource);
realReleasedNum++;
}
}
long beginNum = pool.beginLabel().labelId();
long endNum = pool.endLabel().labelId();
long totalNum = pool.totalNum();
long usedNum = pool.usedNum() - realReleasedNum;
long current = pool.currentUsedMaxLabelId().labelId();
ImmutableSet<LabelResource> s = ImmutableSet.copyOf(storeSet);
LabelResourcePool newPool = new LabelResourcePool(deviceId.toString(),
beginNum, endNum,
totalNum, usedNum,
current, s);
resourcePool.put(deviceId, newPool);
log.info("success to release label resource");
return true;
}