parent
c12ff20ab2
commit
9ab269ab39
@ -0,0 +1,104 @@ |
||||
// Copyright (c) 2016, Facebook, Inc. All rights reserved.
|
||||
// This source code is licensed under the BSD-style license found in the
|
||||
// LICENSE file in the root directory of this source tree. An additional grant
|
||||
// of patent rights can be found in the PATENTS file in the same directory.
|
||||
package org.rocksdb; |
||||
|
||||
import org.junit.After; |
||||
import org.junit.Before; |
||||
import org.junit.Rule; |
||||
import org.junit.Test; |
||||
import org.junit.rules.TemporaryFolder; |
||||
import org.junit.runner.RunWith; |
||||
import org.junit.runners.Parameterized; |
||||
import org.junit.runners.Parameterized.Parameter; |
||||
import org.junit.runners.Parameterized.Parameters; |
||||
|
||||
import java.nio.ByteBuffer; |
||||
import java.util.*; |
||||
import java.util.concurrent.*; |
||||
|
||||
@RunWith(Parameterized.class) |
||||
public class WriteBatchThreadedTest { |
||||
|
||||
@Parameters(name = "WriteBatchThreadedTest(threadCount={0})") |
||||
public static Iterable<Integer> data() { |
||||
return Arrays.asList(new Integer[]{1, 10, 50, 100}); |
||||
} |
||||
|
||||
@Parameter |
||||
public int threadCount; |
||||
|
||||
@Rule |
||||
public TemporaryFolder dbFolder = new TemporaryFolder(); |
||||
|
||||
RocksDB db; |
||||
|
||||
@Before |
||||
public void setUp() throws Exception { |
||||
RocksDB.loadLibrary(); |
||||
final Options options = new Options() |
||||
.setCreateIfMissing(true) |
||||
.setIncreaseParallelism(32); |
||||
db = RocksDB.open(options, dbFolder.getRoot().getAbsolutePath()); |
||||
assert (db != null); |
||||
} |
||||
|
||||
@After |
||||
public void tearDown() throws Exception { |
||||
if (db != null) { |
||||
db.close(); |
||||
} |
||||
} |
||||
|
||||
@Test |
||||
public void threadedWrites() throws InterruptedException, ExecutionException { |
||||
final List<Callable<Void>> callables = new ArrayList<>(); |
||||
for (int i = 0; i < 100; i++) { |
||||
final int offset = i * 100; |
||||
callables.add(new Callable<Void>() { |
||||
@Override |
||||
public Void call() throws RocksDBException { |
||||
final WriteBatch wb = new WriteBatch(); |
||||
for (int i = offset; i < offset + 100; i++) { |
||||
wb.put(ByteBuffer.allocate(4).putInt(i).array(), |
||||
"parallel rocks test".getBytes()); |
||||
} |
||||
db.write(new WriteOptions(), wb); |
||||
|
||||
return null; |
||||
} |
||||
}); |
||||
} |
||||
|
||||
//submit the callables
|
||||
final ExecutorService executorService = |
||||
Executors.newFixedThreadPool(threadCount); |
||||
try { |
||||
final ExecutorCompletionService<Void> completionService = |
||||
new ExecutorCompletionService<>(executorService); |
||||
final Set<Future<Void>> futures = new HashSet<>(); |
||||
for (final Callable<Void> callable : callables) { |
||||
futures.add(completionService.submit(callable)); |
||||
} |
||||
|
||||
while (futures.size() > 0) { |
||||
final Future<Void> future = completionService.take(); |
||||
futures.remove(future); |
||||
|
||||
try { |
||||
future.get(); |
||||
} catch (final ExecutionException e) { |
||||
for (final Future<Void> f : futures) { |
||||
f.cancel(true); |
||||
} |
||||
|
||||
throw e; |
||||
} |
||||
} |
||||
} finally { |
||||
executorService.shutdown(); |
||||
executorService.awaitTermination(10, TimeUnit.SECONDS); |
||||
} |
||||
} |
||||
} |
Loading…
Reference in new issue