當前位置: 首頁>>代碼示例>>Java>>正文


Java MeterFailReason類代碼示例

本文整理匯總了Java中org.onosproject.net.meter.MeterFailReason的典型用法代碼示例。如果您正苦於以下問題:Java MeterFailReason類的具體用法?Java MeterFailReason怎麽用?Java MeterFailReason使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


MeterFailReason類屬於org.onosproject.net.meter包,在下文中一共展示了MeterFailReason類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: activate

import org.onosproject.net.meter.MeterFailReason; //導入依賴的package包/類
@Activate
public void activate() {
    providerService = providerRegistry.register(this);

    pendingOperations = CacheBuilder.newBuilder()
            .expireAfterWrite(TIMEOUT, TimeUnit.SECONDS)
            .removalListener((RemovalNotification<Long, MeterOperation> notification) -> {
                if (notification.getCause() == RemovalCause.EXPIRED) {
                    providerService.meterOperationFailed(notification.getValue(),
                                                         MeterFailReason.TIMEOUT);
                }
            }).build();

    controller.addEventListener(listener);
    controller.addListener(listener);

    controller.getSwitches().forEach((sw -> createStatsCollection(sw)));
}
 
開發者ID:shlee89,項目名稱:athena,代碼行數:19,代碼來源:OpenFlowMeterProvider.java

示例2: activate

import org.onosproject.net.meter.MeterFailReason; //導入依賴的package包/類
@Activate
public void activate() {

    store.setDelegate(delegate);

    onComplete = (request, result, error) ->
        {
            request.context().ifPresent(c -> {
                if (error != null) {
                    c.onError(request, MeterFailReason.UNKNOWN);
                } else {
                    if (result.reason().isPresent()) {
                        c.onError(request, result.reason().get());
                    } else {
                        c.onSuccess(request);
                    }
                }
            });

        };
    log.info("Started");
}
 
開發者ID:shlee89,項目名稱:athena,代碼行數:23,代碼來源:MeterManager.java

示例3: activate

import org.onosproject.net.meter.MeterFailReason; //導入依賴的package包/類
@Activate
public void activate() {

    local = clusterService.getLocalNode().id();


    meters = storageService.<MeterKey, MeterData>consistentMapBuilder()
                .withName(METERSTORE)
                .withSerializer(Serializer.using(Arrays.asList(KryoNamespaces.API),
                                                 MeterKey.class,
                                                 MeterData.class,
                                                 DefaultMeter.class,
                                                 DefaultBand.class,
                                                 Band.Type.class,
                                                 MeterState.class,
                                                 Meter.Unit.class,
                                                 MeterFailReason.class)).build();

    meters.addListener(mapListener);

    log.info("Started");
}
 
開發者ID:shlee89,項目名稱:athena,代碼行數:23,代碼來源:DistributedMeterStore.java

示例4: updateMeter

import org.onosproject.net.meter.MeterFailReason; //導入依賴的package包/類
@Override
public CompletableFuture<MeterStoreResult> updateMeter(Meter meter) {
    CompletableFuture<MeterStoreResult> future = new CompletableFuture<>();
    MeterKey key = MeterKey.key(meter.deviceId(), meter.id());
    futures.put(key, future);

    MeterData data = new MeterData(meter, null, local);
    try {
        if (meters.computeIfPresent(key, (k, v) -> data) == null) {
            future.complete(MeterStoreResult.fail(MeterFailReason.INVALID_METER));
        }
    } catch (StorageException e) {
        future.completeExceptionally(e);
    }
    return future;
}
 
開發者ID:shlee89,項目名稱:athena,代碼行數:17,代碼來源:DistributedMeterStore.java

示例5: performMeterOperation

import org.onosproject.net.meter.MeterFailReason; //導入依賴的package包/類
@Override
public void performMeterOperation(DeviceId deviceId, MeterOperation meterOp) {
    Dpid dpid = Dpid.dpid(deviceId.uri());
    OpenFlowSwitch sw = controller.getSwitch(dpid);
    if (sw == null) {
        log.error("Unknown device {}", deviceId);
        providerService.meterOperationFailed(meterOp,
                                             MeterFailReason.UNKNOWN_DEVICE);
        return;
    }

    performOperation(sw, meterOp);

    if (meterOp.type().equals(MeterOperation.Type.REMOVE)) {
        forceMeterStats(deviceId);
    }

}
 
開發者ID:opennetworkinglab,項目名稱:onos,代碼行數:19,代碼來源:OpenFlowMeterProvider.java

示例6: updateMeter

import org.onosproject.net.meter.MeterFailReason; //導入依賴的package包/類
@Override
public CompletableFuture<MeterStoreResult> updateMeter(Meter meter) {
    CompletableFuture<MeterStoreResult> future = new CompletableFuture<>();
    MeterKey key = MeterKey.key(meter.deviceId(), meter.id());
    futures.put(key, future);

    MeterData data = new MeterData(meter, null, local);
    try {
        if (meters.computeIfPresent(key, (k, v) -> data) == null) {
            future.complete(MeterStoreResult.fail(MeterFailReason.INVALID_METER));
        }
    } catch (StorageException e) {
        futures.remove(key);
        future.completeExceptionally(e);
    }
    return future;
}
 
開發者ID:opennetworkinglab,項目名稱:onos,代碼行數:18,代碼來源:DistributedMeterStore.java

示例7: updateMeter

import org.onosproject.net.meter.MeterFailReason; //導入依賴的package包/類
@Override
public CompletableFuture<MeterStoreResult> updateMeter(NetworkId networkId, Meter meter) {
    ConcurrentMap<MeterKey, MeterData> meters = getMetersByNetwork(networkId);
    ConcurrentMap<MeterKey, CompletableFuture<MeterStoreResult>> futures =
            getFuturesByNetwork(networkId);

    CompletableFuture<MeterStoreResult> future = new CompletableFuture<>();
    MeterKey key = MeterKey.key(meter.deviceId(), meter.id());
    futures.put(key, future);

    MeterData data = new MeterData(meter, null, local);
    try {
            if (meters.computeIfPresent(key, (k, v) -> data) == null) {
                    future.complete(MeterStoreResult.fail(MeterFailReason.INVALID_METER));
            }
    } catch (StorageException e) {
            future.completeExceptionally(e);
    }
    return future;
}
 
開發者ID:opennetworkinglab,項目名稱:onos,代碼行數:21,代碼來源:SimpleVirtualMeterStore.java

示例8: activate

import org.onosproject.net.meter.MeterFailReason; //導入依賴的package包/類
@Activate
public void activate(ComponentContext context) {
    store.setDelegate(delegate);
    cfgService.registerProperties(getClass());
    eventDispatcher.addSink(MeterEvent.class, listenerRegistry);

    onComplete = (request, result, error) -> {
            request.context().ifPresent(c -> {
                if (error != null) {
                    c.onError(request, MeterFailReason.UNKNOWN);
                } else {
                    if (result.reason().isPresent()) {
                        c.onError(request, result.reason().get());
                    } else {
                        c.onSuccess(request);
                    }
                }
            });

        };

    executorService = newFixedThreadPool(numThreads,
            groupedThreads(GROUP_THREAD_NAME, WORKER_PATTERN, log));
    modified(context);
    log.info("Started");
}
 
開發者ID:opennetworkinglab,項目名稱:onos,代碼行數:27,代碼來源:MeterManager.java

示例9: performMeterOperation

import org.onosproject.net.meter.MeterFailReason; //導入依賴的package包/類
@Override
public void performMeterOperation(DeviceId deviceId, MeterOperations meterOps) {
    Dpid dpid = Dpid.dpid(deviceId.uri());
    OpenFlowSwitch sw = controller.getSwitch(dpid);
    if (sw == null) {
        log.error("Unknown device {}", deviceId);
        meterOps.operations().forEach(op ->
                                              providerService.meterOperationFailed(op,
                                                                                   MeterFailReason.UNKNOWN_DEVICE)
        );
        return;
    }

    meterOps.operations().forEach(op -> performOperation(sw, op));
}
 
開發者ID:shlee89,項目名稱:athena,代碼行數:16,代碼來源:OpenFlowMeterProvider.java

示例10: VirtualNetworkMeterManager

import org.onosproject.net.meter.MeterFailReason; //導入依賴的package包/類
/**
 * Creates a new VirtualNetworkMeterManager object.
 *
 * @param manager virtual network manager service
 * @param networkId a virtual network identifier
 */
public VirtualNetworkMeterManager(VirtualNetworkService manager,
                                  NetworkId networkId) {
    super(manager, networkId, MeterEvent.class);

    coreStorageService = serviceDirectory.get(StorageService.class);
    providerRegistryService =
            serviceDirectory.get(VirtualProviderRegistryService.class);

    store = serviceDirectory.get(VirtualNetworkMeterStore.class);
    store.setDelegate(networkId, this.storeDelegate);

    innerProviderService = new InternalMeterProviderService();
    providerRegistryService.registerProviderService(networkId(), innerProviderService);


    onComplete = (request, result, error) -> {
        request.context().ifPresent(c -> {
            if (error != null) {
                c.onError(request, MeterFailReason.UNKNOWN);
            } else {
                if (result.reason().isPresent()) {
                    c.onError(request, result.reason().get());
                } else {
                    c.onSuccess(request);
                }
            }
        });

    };

    log.info("Started");
}
 
開發者ID:opennetworkinglab,項目名稱:onos,代碼行數:39,代碼來源:VirtualNetworkMeterManager.java

示例11: activate

import org.onosproject.net.meter.MeterFailReason; //導入依賴的package包/類
@Activate
public void activate() {
    providerRegistryService.registerProvider(this);
    internalMeterListener = new InternalMeterListener();

    idGenerator = getIdGenerator();

    pendingOperations = CacheBuilder.newBuilder()
            .expireAfterWrite(TIMEOUT, TimeUnit.SECONDS)
            .removalListener(
                    (RemovalNotification<Long, VirtualMeterOperation>
                             notification) -> {
                if (notification.getCause() == RemovalCause.EXPIRED) {
                    NetworkId networkId = notification.getValue().networkId();
                    MeterOperation op = notification.getValue().operation();

                    VirtualMeterProviderService providerService =
                            (VirtualMeterProviderService) providerRegistryService
                                    .getProviderService(networkId,
                                                        VirtualMeterProvider.class);

                    providerService.meterOperationFailed(op,
                                                         MeterFailReason.TIMEOUT);
                }
            }).build();

    meterService.addListener(internalMeterListener);

    log.info("Started");
}
 
開發者ID:opennetworkinglab,項目名稱:onos,代碼行數:31,代碼來源:DefaultVirtualMeterProvider.java

示例12: performOperation

import org.onosproject.net.meter.MeterFailReason; //導入依賴的package包/類
private void performOperation(NetworkId networkId, DeviceId deviceId,
                              MeterOperation op) {

    VirtualMeterOperation vOp = new VirtualMeterOperation(networkId, op);
    pendingOperations.put(idGenerator.getNewId(), vOp);

    switch (op.type()) {
        case ADD:
            //TODO: devirtualize + submit
            break;
        case REMOVE:
            //TODO: devirtualize + withdraw
            break;
        case MODIFY:
            //TODO: devitualize + withdraw and submit
            break;
        default:
            log.warn("Unknown Meter command {}; not sending anything",
                     op.type());
            VirtualMeterProviderService providerService =
                    (VirtualMeterProviderService) providerRegistryService
                            .getProviderService(networkId,
                                                VirtualMeterProvider.class);
            providerService.meterOperationFailed(op,
                                                 MeterFailReason.UNKNOWN_COMMAND);
    }

}
 
開發者ID:opennetworkinglab,項目名稱:onos,代碼行數:29,代碼來源:DefaultVirtualMeterProvider.java

示例13: activate

import org.onosproject.net.meter.MeterFailReason; //導入依賴的package包/類
@Activate
public void activate() {
    local = clusterService.getLocalNode().id();

    meters = storageService.<MeterKey, MeterData>consistentMapBuilder()
                .withName(METERSTORE)
                .withSerializer(serializer).build();

    meters.addListener(mapListener);

    meterFeatures = storageService.<MeterFeaturesKey, MeterFeatures>consistentMapBuilder()
            .withName(METERFEATURESSTORE)
            .withSerializer(Serializer.using(KryoNamespaces.API,
                                             MeterFeaturesKey.class,
                                             MeterFeatures.class,
                                             DefaultMeterFeatures.class,
                                             Band.Type.class,
                                             Meter.Unit.class,
                                             MeterFailReason.class,
                                             MeterFeaturesFlag.class)).build();

    // Init the set of the available ids
    availableMeterIds = new DefaultDistributedSet<>(storageService.<MeterKey>setBuilder()
            .withName(AVAILABLEMETERIDSTORE)
            .withSerializer(Serializer.using(KryoNamespaces.API,
                                             MeterKey.class)).build(),
            DistributedPrimitive.DEFAULT_OPERATION_TIMEOUT_MILLIS);

    // Init atomic map counters
    meterIdGenerators = storageService.<DeviceId>atomicCounterMapBuilder()
            .withName(METERIDSTORE)
            .withSerializer(Serializer.using(KryoNamespaces.API)).build();

    log.info("Started");
}
 
開發者ID:opennetworkinglab,項目名稱:onos,代碼行數:36,代碼來源:DistributedMeterStore.java

示例14: failedMeter

import org.onosproject.net.meter.MeterFailReason; //導入依賴的package包/類
@Override
public void failedMeter(NetworkId networkId, MeterOperation op, MeterFailReason reason) {
    ConcurrentMap<MeterKey, MeterData> meters = getMetersByNetwork(networkId);

    MeterKey key = MeterKey.key(op.meter().deviceId(), op.meter().id());
    meters.computeIfPresent(key, (k, v) ->
            new MeterData(v.meter(), reason, v.origin()));
}
 
開發者ID:opennetworkinglab,項目名稱:onos,代碼行數:9,代碼來源:SimpleVirtualMeterStore.java

示例15: signalMeterError

import org.onosproject.net.meter.MeterFailReason; //導入依賴的package包/類
private void signalMeterError(OFMeterModFailedErrorMsg meterError,
                              MeterOperation op) {
    switch (meterError.getCode()) {
        case UNKNOWN:
            providerService.meterOperationFailed(op,
                                                 MeterFailReason.UNKNOWN_DEVICE);
            break;
        case METER_EXISTS:
            providerService.meterOperationFailed(op,
                                                 MeterFailReason.EXISTING_METER);
            break;
        case INVALID_METER:
            providerService.meterOperationFailed(op,
                                                 MeterFailReason.INVALID_METER);
            break;
        case UNKNOWN_METER:
            providerService.meterOperationFailed(op,
                                                 MeterFailReason.UNKNOWN);
            break;
        case BAD_COMMAND:
            providerService.meterOperationFailed(op,
                                                 MeterFailReason.UNKNOWN_COMMAND);
            break;
        case BAD_FLAGS:
            providerService.meterOperationFailed(op,
                                                 MeterFailReason.UNKNOWN_FLAGS);
            break;
        case BAD_RATE:
            providerService.meterOperationFailed(op,
                                                 MeterFailReason.BAD_RATE);
            break;
        case BAD_BURST:
            providerService.meterOperationFailed(op,
                                                 MeterFailReason.BAD_BURST);
            break;
        case BAD_BAND:
            providerService.meterOperationFailed(op,
                                                 MeterFailReason.BAD_BAND);
            break;
        case BAD_BAND_VALUE:
            providerService.meterOperationFailed(op,
                                                 MeterFailReason.BAD_BAND_VALUE);
            break;
        case OUT_OF_METERS:
            providerService.meterOperationFailed(op,
                                                 MeterFailReason.OUT_OF_METERS);
            break;
        case OUT_OF_BANDS:
            providerService.meterOperationFailed(op,
                                                 MeterFailReason.OUT_OF_BANDS);
            break;
        default:
            providerService.meterOperationFailed(op,
                                                 MeterFailReason.UNKNOWN);
    }
}
 
開發者ID:shlee89,項目名稱:athena,代碼行數:57,代碼來源:OpenFlowMeterProvider.java


注:本文中的org.onosproject.net.meter.MeterFailReason類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。