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


Java ExecutionEngine類代碼示例

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


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

示例1: initiateSnapshots

import org.voltdb.jni.ExecutionEngine; //導入依賴的package包/類
public void initiateSnapshots(ExecutionEngine ee, Deque<SnapshotTableTask> tasks) {
    LOG.trace("initiateSnapshots at : partition "+ee.getPartitionExecutor().getPartitionId()+ " tasks size ::"+tasks.size());
    
    m_snapshotTableTasks = new ArrayDeque<SnapshotTableTask>(tasks);
    m_snapshotTargets = new ArrayList<SnapshotDataTarget>();
    for (final SnapshotTableTask task : tasks) {
        if (!task.m_isReplicated) {
            assert(task != null);
            assert(m_snapshotTargets != null);
            m_snapshotTargets.add(task.m_target);
        }
        // FIXME meng
       if (!ee.activateTableStream(task.m_tableId, TableStreamType.SNAPSHOT )) {
           LOG.error("Attempted to activate copy on write mode for table "
                   + task.m_name + " and failed");
           LOG.error(task);
           HStore.crashDB();
       }
       else{
           LOG.trace("Activated COW mode for table "+task.m_name+" at partition "+ee.getPartitionExecutor().getPartitionId());
       }
    }
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:24,代碼來源:SnapshotSiteProcessor.java

示例2: generateCurrentSample

import org.voltdb.jni.ExecutionEngine; //導入依賴的package包/類
/**
 * Poll the operating system and generate a Datum
 * @return A newly created Datum instance.
 */
private static synchronized Datum generateCurrentSample() {
    // get this info once
    if (!initialized) initialize();

    long rss = -1;
    switch (mode) {
    case MACOSX_NATIVE:
        rss = ExecutionEngine.nativeGetRSS();
        break;
    case PROCFS:
        rss = getRSSFromProcFS();
        break;
    case PS:
        rss = PSScraper.getPSData(pid).rss;
        break;
    }

    // create a new Datum which adds java stats
    Datum d = new Datum(rss);
    return d;
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:26,代碼來源:SystemStatsCollector.java

示例3: testSameLongHash

import org.voltdb.jni.ExecutionEngine; //導入依賴的package包/類
public void testSameLongHash() {
    ExecutionEngine ee = new ExecutionEngineJNI(null, 1, 1, 0, 0, "");

    /**
     *  Run with 100k of random values and make sure C++ and Java hash to
     *  the same value.
     */
    for (int i = 0; i < 100000; i++) {
        int partitionCount = r.nextInt(1000) + 1;
        // this will produce negative values, which is desired here.
        long valueToHash = r.nextLong();

        int eehash = ee.hashinate(valueToHash, partitionCount);
        int javahash = TheHashinator.hashinate(valueToHash, partitionCount);
        assertEquals(eehash, javahash);
        assertTrue(eehash < partitionCount);
        assertTrue(eehash > -1);
    }
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:20,代碼來源:TestTheHashinator.java

示例4: testSameStringHash

import org.voltdb.jni.ExecutionEngine; //導入依賴的package包/類
public void testSameStringHash() {
    ExecutionEngine ee = new ExecutionEngineJNI(null, 1, 1, 0, 0, "");

    for (int i = 0; i < 100000; i++) {
        int partitionCount = r.nextInt(1000) + 1;
        String valueToHash = Long.toString(r.nextLong());

        int eehash = ee.hashinate(valueToHash, partitionCount);
        int javahash = TheHashinator.hashinate(valueToHash, partitionCount);
        if (eehash != javahash) {
            partitionCount++;
        }
        assertEquals(eehash, javahash);
        assertTrue(eehash < partitionCount);
    }
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:17,代碼來源:TestTheHashinator.java

示例5: doPhysicalRecovery

import org.voltdb.jni.ExecutionEngine; //導入依賴的package包/類
public void doPhysicalRecovery() {
    while (!m_ariesLog.isReadyForReplay()) {
        try {
            // don't sleep for too long as recovery numbers might get biased
            Thread.sleep(500);
        } catch (InterruptedException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }        

    LOG.info("ARIES : ariesLog is ready for replay at site :"+this.site_id);

    if (!m_ariesLog.isRecoveryCompleted()) {
        int m_siteId = this.getSiteId();
        CatalogMap<Partition> partitionMap = this.catalog_site.getPartitions();

        for (Partition pt : partitionMap ) {
            PartitionExecutor pe =  getPartitionExecutor(pt.getId());
            assert (pe != null);

            ExecutionEngine ee = pe.getExecutionEngine();
            assert (ee != null);

            int m_partitionId = pe.getPartitionId();

            LOG.info("ARIES : start recovery at partition  :"+m_partitionId+" on site :"+m_siteId);
            
            if (!m_ariesLog.isRecoveryCompletedForSite(m_partitionId)) {
                ee.doAriesRecoveryPhase(m_ariesLog.getPointerToReplayLog(), m_ariesLog.getReplayLogSize(), m_ariesLog.getTxnIdToBeginReplay());
                m_ariesLog.setRecoveryCompleted(m_partitionId);                
            }
        }
    }

    LOG.info("ARIES : recovery completed at site :"+this.site_id);
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:38,代碼來源:HStoreSite.java

示例6: loadOrAddRefPlanFragment

import org.voltdb.jni.ExecutionEngine; //導入依賴的package包/類
/**
 * Get the site-local fragment id for a given plan identified by 20-byte sha-1 hash
 * If the plan isn't known to this SPC, load it up. Otherwise addref it.
 */
public static long loadOrAddRefPlanFragment(byte[] planHash, byte[] plan, String stmtText) {
    Sha1Wrapper key = new Sha1Wrapper(planHash);
    synchronized (FragInfo.class) {
        FragInfo frag = m_plansByHash.get(key);
        if (frag == null) {
            frag = new FragInfo(key, plan, m_nextFragId++, stmtText);
            m_plansByHash.put(frag.hash, frag);
            m_plansById.put(frag.fragId, frag);
            if (m_plansById.size() > ExecutionEngine.EE_PLAN_CACHE_SIZE) {
                evictLRUfragment();
            }
        }

        // Bit of a hack to work around an issue where a statement-less adhoc
        // fragment could be identical to a statement-needing regular procedure.
        // This doesn't really address the broader issue that fragment hashes
        // are not 1-1 with SQL statements.
        if (frag.stmtText == null) {
            frag.stmtText = stmtText;
        }

        // The fragment MAY be in the LRU map.
        // An incremented refCount is a lazy way to keep it safe from eviction
        // without having to update the map.
        // This optimizes for popular fragments in a small or stable cache that may be reused
        // many times before the eviction process needs to take any notice.
        frag.refCount++;
        return frag.fragId;
    }
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:35,代碼來源:ActivePlanRepository.java

示例7: testExpectNonZeroHash

import org.voltdb.jni.ExecutionEngine; //導入依賴的package包/類
@Test
public void testExpectNonZeroHash() throws Exception {
    int partitionCount = 3;
    final byte configBytes[] = TheHashinator.getConfigureBytes(partitionCount);
    TheHashinator.initialize(TheHashinator.getConfiguredHashinatorClass(), configBytes);
    HashinatorConfig config = TheHashinator.getCurrentConfig();
    ExecutionEngine ee =
            new ExecutionEngineJNI(
                    1,
                    1,
                    0,
                    0,
                    "",
                    100,
                    config);

    long valueToHash = hashinatorType == HashinatorType.ELASTIC ? 39: 2;

    int eehash = ee.hashinate(valueToHash, config);
    int javahash = TheHashinator.getPartitionForParameter(VoltType.typeFromObject(valueToHash).getValue(),
            valueToHash);
    if (eehash != javahash) {
        System.out.printf("Mismatched hash of (%s) %d with %d partitions => EE: %d, Java: %d\n",
                VoltType.typeFromObject(valueToHash).toSQLString(),
                valueToHash, partitionCount, eehash, javahash);
    }
    assertEquals(eehash, javahash);
    assertNotSame(0, eehash);
    assertTrue(eehash < partitionCount);
    assertTrue(eehash >= 0);

    try { ee.release(); } catch (Exception e) {}
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:34,代碼來源:TestTheHashinator.java

示例8: testSameLongHash

import org.voltdb.jni.ExecutionEngine; //導入依賴的package包/類
@Test
public void testSameLongHash() throws Exception {
    byte configBytes[] = TheHashinator.getConfigureBytes(1);
    ExecutionEngine ee = new ExecutionEngineJNI(1, 1, 0, 0, "", 100, new HashinatorConfig(hashinatorType, configBytes, 0, 0));

    /**
     *  Run with 10k of random values and make sure C++ and Java hash to
     *  the same value.
     */
    for (int i = 0; i < 1500; i++) {
        final int partitionCount = r.nextInt(1000) + 1;
        configBytes = TheHashinator.getConfigureBytes(partitionCount);
        TheHashinator.initialize(TheHashinator.getConfiguredHashinatorClass(), configBytes);
        // this will produce negative values, which is desired here.
        final long valueToHash = r.nextLong();
        final int javahash = TheHashinator.getPartitionForParameter(VoltType.typeFromObject(valueToHash).getValue(),
                                                                    valueToHash);
        final int eehash = ee.hashinate(valueToHash, TheHashinator.getCurrentConfig());
        if (eehash != javahash) {
            System.out.printf("Mismatched hash of (%s) %d with %d partitions => EE: %d, Java: %d\n",
                    VoltType.typeFromObject(valueToHash).toSQLString(),
                    valueToHash, partitionCount, eehash, javahash);
        }
        assertEquals(eehash, javahash);
        assertTrue(eehash < partitionCount);
        assertTrue(eehash > -1);
    }

    try { ee.release(); } catch (Exception e) {}
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:31,代碼來源:TestTheHashinator.java

示例9: testSameStringHash

import org.voltdb.jni.ExecutionEngine; //導入依賴的package包/類
@Test
public void testSameStringHash() throws Exception {
    byte configBytes[] = TheHashinator.getConfigureBytes(1);
    ExecutionEngine ee =
            new ExecutionEngineJNI(
                    1,
                    1,
                    0,
                    0,
                    "",
                    100,
                    new HashinatorConfig(hashinatorType, configBytes, 0, 0));

    for (int i = 0; i < 1500; i++) {
        int partitionCount = r.nextInt(1000) + 1;
        configBytes = TheHashinator.getConfigureBytes(partitionCount);
        String valueToHash = Long.toString(r.nextLong());
        TheHashinator.initialize(TheHashinator.getConfiguredHashinatorClass(), configBytes);

        int eehash = ee.hashinate(valueToHash, TheHashinator.getCurrentConfig());
        int javahash = TheHashinator.getPartitionForParameter(VoltType.typeFromObject(valueToHash).getValue(),
                                                              valueToHash);
        if (eehash != javahash) {
            System.out.printf("Mismatched hash of (%s) %d with %d partitions => EE: %d, Java: %d\n",
                    VoltType.typeFromObject(valueToHash).toSQLString(),
                    valueToHash, partitionCount, eehash, javahash);
            partitionCount++;
        }
        assertEquals(eehash, javahash);
        assertTrue(eehash < partitionCount);
        assertTrue(eehash >= 0);
    }

    try { ee.release(); } catch (Exception e) {}
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:36,代碼來源:TestTheHashinator.java

示例10: testSameBytesHash

import org.voltdb.jni.ExecutionEngine; //導入依賴的package包/類
@Test
public void testSameBytesHash() throws Exception {
    ExecutionEngine ee =
            new ExecutionEngineJNI(
                    1,
                    1,
                    0,
                    0,
                    "",
                    100,
                    new HashinatorConfig(hashinatorType, TheHashinator.getConfigureBytes(6), 0, 0));
    for (int i = 0; i < 2500; i++) {
        int partitionCount = r.nextInt(1000) + 1;
        byte[] valueToHash = new byte[r.nextInt(1000)];
        r.nextBytes(valueToHash);
        final byte configBytes[] = TheHashinator.getConfigureBytes(partitionCount);
        TheHashinator.initialize(TheHashinator.getConfiguredHashinatorClass(), configBytes);
        int eehash = ee.hashinate(valueToHash, TheHashinator.getCurrentConfig());
        int javahash = TheHashinator.getPartitionForParameter(VoltType.typeFromClass(byte[].class).getValue(),
                valueToHash);
        if (eehash != javahash) {
            System.out.printf("Mismatched hash of (%s) %d bytes %d partitions => EE: %d Java: %d\n",
                    VoltType.typeFromObject(valueToHash).toSQLString(),
                    valueToHash.length, partitionCount, eehash, javahash);
            partitionCount++;
        }
        assertTrue(eehash < partitionCount);
        assertTrue(eehash >= 0);
        assertEquals(eehash, javahash);
    }
    try { ee.release(); } catch (Exception e) {}
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:33,代碼來源:TestTheHashinator.java

示例11: getExecutionEngine

import org.voltdb.jni.ExecutionEngine; //導入依賴的package包/類
public final ExecutionEngine getExecutionEngine() {
    return (this.ee);
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:4,代碼來源:PartitionExecutor.java

示例12: OptimisticConflictChecker

import org.voltdb.jni.ExecutionEngine; //導入依賴的package包/類
public OptimisticConflictChecker(CatalogContext catalogContext, ExecutionEngine ee) {
    super(catalogContext);
    this.ee = ee;
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:5,代碼來源:OptimisticConflictChecker.java

示例13: evictLRUfragment

import org.voltdb.jni.ExecutionEngine; //導入依賴的package包/類
private static void evictLRUfragment() {
    /// Evict the least recently used fragment (if any are currently unused).
    /// Along the way, update any obsolete entries that were left
    /// by the laziness of the fragment state changes (fragment reuse).
    /// In the rare case of a cache bloated beyond its usual limit,
    /// keep evicting as needed and as entries are available until the bloat is gone.

    while ( ! m_plansLRU.isEmpty()) {
        // Remove the earliest entry.
        Entry<Long, FragInfo> lru = m_plansLRU.pollFirstEntry();
        FragInfo frag = lru.getValue();
        if (frag.refCount > 0) {
            // The fragment is being re-used, it is no longer an eviction candidate.
            // It is only in the map due to the laziness in loadOrAddRefPlanFragment.
            // It will be re-considered (at a later key) once it is no longer referenced.
            // Resetting its lastUse to 0, here, restores it to a state identical to that
            // of a new fragment.
            // It eventually causes decrefPlanFragmentById to put it back in the map
            // at its then up-to-date key.
            // This makes it safe to keep out of the LRU map for now.
            // See the comment in decrefPlanFragmentById and the one in the next code block.
            frag.lastUse = 0;
        }
        else if (lru.getKey() != frag.lastUse) {
            // The fragment is not in use but has been re-used more recently than the key reflects.
            // This is a result of the laziness in decrefPlanFragmentById.
            // Correct the entry's key in the LRU map to reflect its last use.
            // This may STILL be the least recently used entry.
            // If so, it will be picked off in a later iteration of this loop;
            // its key will now match its lastUse value.
            m_plansLRU.put(frag.lastUse, frag);
        }
        else {
            // Found and removed the actual up-to-date least recently used entry from the LRU map.
            // Remove the entry from the other collections.
            m_plansById.remove(frag.fragId);
            m_plansByHash.remove(frag.hash);
            // Normally, one eviction for each new fragment is enough to restore order.
            // BUT, if a prior call ever failed to find an unused fragment in the cache,
            // the cache may have grown beyond its normal size. In that rare case,
            // one eviction is not enough to reduce the cache to the desired size,
            // so take another bite at the apple.
            // Otherwise, trading exactly one evicted fragment for each new fragment
            // would never reduce the cache.
            if (m_plansById.size() > ExecutionEngine.EE_PLAN_CACHE_SIZE) {
                 continue;
            }
            return;
        }
    }
    // Strange. All FragInfo entries appear to be in use. There's nothing to evict.
    // Let the cache bloat a little and try again later after the next new fragment.
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:54,代碼來源:ActivePlanRepository.java

示例14: testSameLongHash1

import org.voltdb.jni.ExecutionEngine; //導入依賴的package包/類
@Test
public void testSameLongHash1() throws Exception {
    int partitionCount = 2;
    TheHashinator.initialize(TheHashinator.getConfiguredHashinatorClass(), TheHashinator.getConfigureBytes(partitionCount));
    HashinatorConfig hashinatorConfig = TheHashinator.getCurrentConfig();
    ExecutionEngine ee =
            new ExecutionEngineJNI(
                    1,
                    1,
                    0,
                    0,
                    "",
                    100,
                    hashinatorConfig);


    long valueToHash = 0;
    int eehash = ee.hashinate(valueToHash, hashinatorConfig);
    int javahash = TheHashinator.getPartitionForParameter(VoltType.typeFromObject(valueToHash).getValue(),
            valueToHash);
    if (eehash != javahash) {
        System.out.printf("Mismatched hash of (%s) %d with %d partitions => EE: %d, Java: %d\n",
                VoltType.typeFromObject(valueToHash).toSQLString(),
                valueToHash, partitionCount, eehash, javahash);
    }
    assertEquals(eehash, javahash);
    assertTrue(eehash < partitionCount);
    assertTrue(eehash >= 0);

    valueToHash = 1;
    eehash = ee.hashinate(valueToHash, hashinatorConfig);
    javahash = TheHashinator.getPartitionForParameter(VoltType.typeFromObject(valueToHash).getValue(),
            valueToHash);
    if (eehash != javahash) {
        System.out.printf("Mismatched hash of (%s) %d with %d partitions => EE: %d, Java: %d\n",
                VoltType.typeFromObject(valueToHash).toSQLString(),
                valueToHash, partitionCount, eehash, javahash);
    }
    assertEquals(eehash, javahash);
    assertTrue(eehash < partitionCount);
    assertTrue(eehash >= 0);

    valueToHash = 2;
    eehash = ee.hashinate(valueToHash, hashinatorConfig);
    javahash = TheHashinator.getPartitionForParameter(VoltType.typeFromObject(valueToHash).getValue(),
            valueToHash);
    if (eehash != javahash) {
        System.out.printf("Mismatched hash of (%s) %d with %d partitions => EE: %d, Java: %d\n",
                VoltType.typeFromObject(valueToHash).toSQLString(),
                valueToHash, partitionCount, eehash, javahash);
    }
    assertEquals(eehash, javahash);
    assertTrue(eehash < partitionCount);
    assertTrue(eehash >= 0);

    valueToHash = 3;
    eehash = ee.hashinate(valueToHash, hashinatorConfig);
    javahash = TheHashinator.getPartitionForParameter(VoltType.typeFromObject(valueToHash).getValue(),
            valueToHash);
    if (eehash != javahash) {
        System.out.printf("Mismatched hash of (%s) %d with %d partitions => EE: %d, Java: %d\n",
                VoltType.typeFromObject(valueToHash).toSQLString(),
                valueToHash, partitionCount, eehash, javahash);
    }
    assertEquals(eehash, javahash);
    assertTrue(eehash < partitionCount);
    assertTrue(eehash >= 0);

    try { ee.release(); } catch (Exception e) {}
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:71,代碼來源:TestTheHashinator.java

示例15: testEdgeCases

import org.voltdb.jni.ExecutionEngine; //導入依賴的package包/類
@Test
public void testEdgeCases() throws Exception {
    byte configBytes[] = TheHashinator.getConfigureBytes(1);
    ExecutionEngine ee =
            new ExecutionEngineJNI(
                    1,
                    1,
                    0,
                    0,
                    "",
                    100,
                    new HashinatorConfig(hashinatorType, configBytes, 0, 0));

    /**
     *  Run with 100k of random values and make sure C++ and Java hash to
     *  the same value.
     */
    for (int i = 0; i < 500; i++) {
        int partitionCount = r.nextInt(1000) + 1;
        long[] values = new long[] {
                Long.MIN_VALUE, Long.MAX_VALUE, Long.MAX_VALUE - 1, Long.MIN_VALUE + 1
        };
        configBytes = TheHashinator.getConfigureBytes(partitionCount);
        TheHashinator.initialize(TheHashinator.getConfiguredHashinatorClass(), configBytes);
        for (long valueToHash : values) {
            int eehash = ee.hashinate(valueToHash, TheHashinator.getCurrentConfig());
            int javahash = TheHashinator.getPartitionForParameter(VoltType.typeFromObject(valueToHash).getValue(),
                    valueToHash);
            if (eehash != javahash) {
                System.out.printf("Mismatched hash of (%s) %d with %d partitions => EE: %d, Java: %d\n",
                        VoltType.typeFromObject(valueToHash).toSQLString(),
                        valueToHash, partitionCount, eehash, javahash);
            }
            assertEquals(eehash, javahash);
            assertTrue(eehash < partitionCount);
            assertTrue(eehash >= 0);
        }
    }

    try { ee.release(); } catch (Exception e) {}
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:42,代碼來源:TestTheHashinator.java


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