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


Java DeadlockDetectingListeningExecutorService類代碼示例

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


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

示例1: setupStore

import org.opendaylight.yangtools.util.concurrent.DeadlockDetectingListeningExecutorService; //導入依賴的package包/類
@Before
public void setupStore() {

    InMemoryDOMDataStore operStore = new InMemoryDOMDataStore("OPER",
            MoreExecutors.newDirectExecutorService());
    InMemoryDOMDataStore configStore = new InMemoryDOMDataStore("CFG",
            MoreExecutors.newDirectExecutorService());
    schemaContext = TestModel.createTestContext();

    operStore.onGlobalContextUpdated(schemaContext);
    configStore.onGlobalContextUpdated(schemaContext);

    ImmutableMap<LogicalDatastoreType, DOMStore> stores = ImmutableMap.<LogicalDatastoreType, DOMStore> builder() //
            .put(CONFIGURATION, configStore) //
            .put(OPERATIONAL, operStore) //
            .build();

    commitExecutor = new CommitExecutorService(Executors.newSingleThreadExecutor());
    futureExecutor = SpecialExecutors.newBlockingBoundedCachedThreadPool(1, 5, "FCB");
    executor = new DeadlockDetectingListeningExecutorService(commitExecutor,
            TransactionCommitDeadlockException.DEADLOCK_EXCEPTION_SUPPLIER, futureExecutor);
    domBroker = new SerializedDOMDataBroker(stores, executor);
}
 
開發者ID:hashsdn,項目名稱:hashsdn-controller,代碼行數:24,代碼來源:DOMBrokerTest.java

示例2: setupStore

import org.opendaylight.yangtools.util.concurrent.DeadlockDetectingListeningExecutorService; //導入依賴的package包/類
@Before
public void setupStore() {
    InMemoryDOMDataStore operStore = new InMemoryDOMDataStore("OPER",
            MoreExecutors.newDirectExecutorService());
    InMemoryDOMDataStore configStore = new InMemoryDOMDataStore("CFG",
            MoreExecutors.newDirectExecutorService());
    schemaContext = TestModel.createTestContext();

    operStore.onGlobalContextUpdated(schemaContext);
    configStore.onGlobalContextUpdated(schemaContext);

    ImmutableMap<LogicalDatastoreType, DOMStore> stores = ImmutableMap.<LogicalDatastoreType, DOMStore>builder() //
            .put(CONFIGURATION, configStore) //
            .put(OPERATIONAL, operStore) //
            .build();

    commitExecutor = new CommitExecutorService(Executors.newSingleThreadExecutor());
    futureExecutor = SpecialExecutors.newBlockingBoundedCachedThreadPool(1, 5, "FCB");
    executor = new DeadlockDetectingListeningExecutorService(commitExecutor,
            TransactionCommitDeadlockException.DEADLOCK_EXCEPTION_SUPPLIER, futureExecutor);
    domBroker = new SerializedDOMDataBroker(stores, executor);
}
 
開發者ID:hashsdn,項目名稱:hashsdn-controller,代碼行數:23,代碼來源:DOMDataTreeListenerTest.java

示例3: createInstance

import org.opendaylight.yangtools.util.concurrent.DeadlockDetectingListeningExecutorService; //導入依賴的package包/類
@Override
public java.lang.AutoCloseable createInstance() {
    //Initializing Operational DOM DataStore defaulting to InMemoryDOMDataStore if one is not configured
    DOMStore operStore =  getOperationalDataStoreDependency();
    if(operStore == null){
       //we will default to InMemoryDOMDataStore creation
      operStore = InMemoryDOMDataStoreFactory.create("DOM-OPER", getSchemaServiceDependency());
    }

    DOMStore configStore = getConfigDataStoreDependency();
    if(configStore == null){
       //we will default to InMemoryDOMDataStore creation
       configStore = InMemoryDOMDataStoreFactory.create("DOM-CFG", getSchemaServiceDependency());
    }

    final Map<LogicalDatastoreType, DOMStore> datastores = new EnumMap<>(LogicalDatastoreType.class);
    datastores.put(LogicalDatastoreType.OPERATIONAL, operStore);
    datastores.put(LogicalDatastoreType.CONFIGURATION, configStore);

    /*
     * We use an executor for commit ListenableFuture callbacks that favors reusing available
     * threads over creating new threads at the expense of execution time. The assumption is
     * that most ListenableFuture callbacks won't execute a lot of business logic where we want
     * it to run quicker - many callbacks will likely just handle error conditions and do
     * nothing on success. The executor queue capacity is bounded and, if the capacity is
     * reached, subsequent submitted tasks will block the caller.
     */
    ExecutorService listenableFutureExecutor = SpecialExecutors.newBlockingBoundedCachedThreadPool(
            getMaxDataBrokerFutureCallbackPoolSize(), getMaxDataBrokerFutureCallbackQueueSize(),
            "CommitFutures");

    final List<AbstractMXBean> mBeans = Lists.newArrayList();
    final DurationStatisticsTracker commitStatsTracker;

    /*
     * We use a single-threaded executor for commits with a bounded queue capacity. If the
     * queue capacity is reached, subsequent commit tasks will be rejected and the commits will
     * fail. This is done to relieve back pressure. This should be an extreme scenario - either
     * there's deadlock(s) somewhere and the controller is unstable or some rogue component is
     * continuously hammering commits too fast or the controller is just over-capacity for the
     * system it's running on.
     */
    ExecutorService commitExecutor = SpecialExecutors.newBoundedSingleThreadExecutor(
        getMaxDataBrokerCommitQueueSize(), "WriteTxCommit");

    SerializedDOMDataBroker sdb = new SerializedDOMDataBroker(datastores,
        new DeadlockDetectingListeningExecutorService(commitExecutor,
            TransactionCommitDeadlockException.DEADLOCK_EXCEPTION_SUPPLIER,
            listenableFutureExecutor));
    commitStatsTracker = sdb.getCommitStatsTracker();

    final AbstractMXBean commitExecutorStatsMXBean =
            ThreadExecutorStatsMXBeanImpl.create(commitExecutor, "CommitExecutorStats",
                JMX_BEAN_TYPE, null);
    if(commitExecutorStatsMXBean != null) {
        mBeans.add(commitExecutorStatsMXBean);
    }

    if(commitStatsTracker != null) {
        final CommitStatsMXBeanImpl commitStatsMXBean = new CommitStatsMXBeanImpl(
                commitStatsTracker, JMX_BEAN_TYPE);
        commitStatsMXBean.registerMBean();
        mBeans.add(commitStatsMXBean);
    }

    final AbstractMXBean commitFutureStatsMXBean =
            ThreadExecutorStatsMXBeanImpl.create(listenableFutureExecutor,
                    "CommitFutureExecutorStats", JMX_BEAN_TYPE, null);
    if(commitFutureStatsMXBean != null) {
        mBeans.add(commitFutureStatsMXBean);
    }

    sdb.setCloseable(() -> mBeans.forEach(AbstractMXBean::unregisterMBean));

    return sdb;
}
 
開發者ID:hashsdn,項目名稱:hashsdn-controller,代碼行數:77,代碼來源:DomInmemoryDataBrokerModule.java


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