本文整理匯總了Java中org.apache.flume.Transaction.begin方法的典型用法代碼示例。如果您正苦於以下問題:Java Transaction.begin方法的具體用法?Java Transaction.begin怎麽用?Java Transaction.begin使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類org.apache.flume.Transaction
的用法示例。
在下文中一共展示了Transaction.begin方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: sendAndAssertFail
import org.apache.flume.Transaction; //導入方法依賴的package包/類
private void sendAndAssertFail(Logger logger) throws Throwable {
/*
* Log4j internally defines levels as multiples of 10000. So if we
* create levels directly using count, the level will be set as the
* default.
*/
int level = 20000;
try {
logger.log(Level.toLevel(level), "Test Msg");
} catch (FlumeException ex) {
ex.printStackTrace();
throw ex.getCause();
}
Transaction transaction = ch.getTransaction();
transaction.begin();
Event event = ch.take();
Assert.assertNull(event);
transaction.commit();
transaction.close();
}
示例2: testPutFilenameHeader
import org.apache.flume.Transaction; //導入方法依賴的package包/類
@Test
public void testPutFilenameHeader() throws IOException {
File f1 = new File(tmpDir, "file1");
Files.write("f1\n", f1, Charsets.UTF_8);
Context context = new Context();
context.put(POSITION_FILE, posFilePath);
context.put(FILE_GROUPS, "fg");
context.put(FILE_GROUPS_PREFIX + "fg", tmpDir.getAbsolutePath() + "/file.*");
context.put(FILENAME_HEADER, "true");
context.put(FILENAME_HEADER_KEY, "path");
Configurables.configure(source, context);
source.start();
source.process();
Transaction txn = channel.getTransaction();
txn.begin();
Event e = channel.take();
txn.commit();
txn.close();
assertNotNull(e.getHeaders().get("path"));
assertEquals(f1.getAbsolutePath(),
e.getHeaders().get("path"));
}
示例3: testCommitAfterNoPutTake
import org.apache.flume.Transaction; //導入方法依賴的package包/類
@Test
public void testCommitAfterNoPutTake() throws Exception {
channel.start();
Assert.assertTrue(channel.isOpen());
Transaction transaction;
transaction = channel.getTransaction();
transaction.begin();
transaction.commit();
transaction.close();
// ensure we can reopen log with no error
channel.stop();
channel = createFileChannel();
channel.start();
Assert.assertTrue(channel.isOpen());
transaction = channel.getTransaction();
transaction.begin();
Assert.assertNull(channel.take());
transaction.commit();
transaction.close();
}
示例4: testPutTake
import org.apache.flume.Transaction; //導入方法依賴的package包/類
@Test
public void testPutTake() throws InterruptedException, EventDeliveryException {
Event event = EventBuilder.withBody("test event".getBytes());
Context context = new Context();
Configurables.configure(channel, context);
Transaction transaction = channel.getTransaction();
Assert.assertNotNull(transaction);
transaction.begin();
channel.put(event);
transaction.commit();
transaction.close();
transaction = channel.getTransaction();
Assert.assertNotNull(transaction);
transaction.begin();
Event event2 = channel.take();
Assert.assertEquals(event, event2);
transaction.commit();
}
示例5: putToChannel
import org.apache.flume.Transaction; //導入方法依賴的package包/類
public static void putToChannel(Channel in, Iterable<Event> records)
throws EventDeliveryException {
Transaction t = in.getTransaction();
try {
t.begin();
for (Event record : records) {
in.put(record);
}
t.commit();
} catch (Throwable th) {
t.rollback();
Throwables.propagateIfInstanceOf(th, Error.class);
Throwables.propagateIfInstanceOf(th, EventDeliveryException.class);
throw new EventDeliveryException(th);
} finally {
t.close();
}
}
示例6: testThreeEvents
import org.apache.flume.Transaction; //導入方法依賴的package包/類
@Test
public void testThreeEvents() throws Exception {
testUtility.createTable(tableName.getBytes(), columnFamily.getBytes());
deleteTable = true;
AsyncHBaseSink sink = new AsyncHBaseSink(testUtility.getConfiguration());
Configurables.configure(sink, ctx);
Channel channel = new MemoryChannel();
Configurables.configure(channel, ctx);
sink.setChannel(channel);
sink.start();
Transaction tx = channel.getTransaction();
tx.begin();
for (int i = 0; i < 3; i++) {
Event e = EventBuilder.withBody(Bytes.toBytes(valBase + "-" + i));
channel.put(e);
}
tx.commit();
tx.close();
Assert.assertFalse(sink.isConfNull());
sink.process();
sink.stop();
HTable table = new HTable(testUtility.getConfiguration(), tableName);
byte[][] results = getResults(table, 3);
byte[] out;
int found = 0;
for (int i = 0; i < 3; i++) {
for (int j = 0; j < 3; j++) {
if (Arrays.equals(results[j], Bytes.toBytes(valBase + "-" + i))) {
found++;
break;
}
}
}
Assert.assertEquals(3, found);
out = results[3];
Assert.assertArrayEquals(Longs.toByteArray(3), out);
}
示例7: testThreeEvents
import org.apache.flume.Transaction; //導入方法依賴的package包/類
@Test
public void testThreeEvents() throws Exception {
initContextForSimpleHbaseEventSerializer();
ctx.put("batchSize", "3");
HBaseSink sink = new HBaseSink(conf);
Configurables.configure(sink, ctx);
Channel channel = new MemoryChannel();
Configurables.configure(channel, new Context());
sink.setChannel(channel);
sink.start();
Transaction tx = channel.getTransaction();
tx.begin();
for (int i = 0; i < 3; i++) {
Event e = EventBuilder.withBody(Bytes.toBytes(valBase + "-" + i));
channel.put(e);
}
tx.commit();
tx.close();
sink.process();
sink.stop();
HTable table = new HTable(conf, tableName);
byte[][] results = getResults(table, 3);
byte[] out;
int found = 0;
for (int i = 0; i < 3; i++) {
for (int j = 0; j < 3; j++) {
if (Arrays.equals(results[j], Bytes.toBytes(valBase + "-" + i))) {
found++;
break;
}
}
}
Assert.assertEquals(3, found);
out = results[3];
Assert.assertArrayEquals(Longs.toByteArray(3), out);
}
示例8: putEvents
import org.apache.flume.Transaction; //導入方法依賴的package包/類
public static Set<String> putEvents(Channel channel, String prefix, int batchSize, int numEvents,
boolean untilCapacityIsReached) throws Exception {
Set<String> result = Sets.newHashSet();
for (int i = 0; i < numEvents; i += batchSize) {
Transaction transaction = channel.getTransaction();
transaction.begin();
try {
Set<String> batch = Sets.newHashSet();
for (int j = 0; j < batchSize; j++) {
String s = prefix + "-" + i + "-" + j + "-" + UUID.randomUUID();
Event event = EventBuilder.withBody(s.getBytes(Charsets.UTF_8));
channel.put(event);
batch.add(s);
}
transaction.commit();
result.addAll(batch);
} catch (Exception ex) {
transaction.rollback();
if (untilCapacityIsReached && ex instanceof ChannelException &&
("The channel has reached it's capacity. "
+ "This might be the result of a sink on the channel having too "
+ "low of batch size, a downstream system running slower than "
+ "normal, or that the channel capacity is just too low. "
+ "[channel=" + channel.getName() + "]").equals(ex.getMessage())) {
break;
}
throw ex;
} finally {
transaction.close();
}
}
return result;
}
示例9: testByteCapacityOverload
import org.apache.flume.Transaction; //導入方法依賴的package包/類
@Test(expected = ChannelException.class)
public void testByteCapacityOverload() {
Context context = new Context();
Map<String, String> parms = new HashMap<String, String>();
parms.put("byteCapacity", "2000");
parms.put("byteCapacityBufferPercentage", "20");
context.putAll(parms);
Configurables.configure(channel, context);
byte[] eventBody = new byte[405];
Transaction transaction = channel.getTransaction();
transaction.begin();
channel.put(EventBuilder.withBody(eventBody));
channel.put(EventBuilder.withBody(eventBody));
channel.put(EventBuilder.withBody(eventBody));
transaction.commit();
transaction.close();
transaction = channel.getTransaction();
transaction.begin();
channel.put(EventBuilder.withBody(eventBody));
channel.put(EventBuilder.withBody(eventBody));
// this should kill it
transaction.commit();
Assert.fail();
}
示例10: takeEvent
import org.apache.flume.Transaction; //導入方法依賴的package包/類
private static Event takeEvent(Channel channel) {
Transaction txn = channel.getTransaction();
txn.begin();
Event evt = channel.take();
txn.commit();
txn.close();
return evt;
}
示例11: takeWithoutCommit
import org.apache.flume.Transaction; //導入方法依賴的package包/類
public static Set<String> takeWithoutCommit(Channel channel, Transaction tx,
int number) {
Set<String> events = Sets.newHashSet();
tx.begin();
for (int i = 0; i < number; i++) {
Event e = channel.take();
if (e == null) {
break;
}
events.add(new String(e.getBody()));
}
return events;
}
示例12: process
import org.apache.flume.Transaction; //導入方法依賴的package包/類
@Override
public Status process() throws EventDeliveryException {
Status status = Status.READY;
Channel channel = getChannel();
Transaction transaction = channel.getTransaction();
if (resetConnectionFlag.get()) {
resetConnection();
// if the time to reset is long and the timeout is short
// this may cancel the next reset request
// this should however not be an issue
resetConnectionFlag.set(false);
}
try {
transaction.begin();
verifyConnection();
List<Event> batch = Lists.newLinkedList();
for (int i = 0; i < client.getBatchSize(); i++) {
Event event = channel.take();
if (event == null) {
break;
}
batch.add(event);
}
int size = batch.size();
int batchSize = client.getBatchSize();
if (size == 0) {
sinkCounter.incrementBatchEmptyCount();
status = Status.BACKOFF;
} else {
if (size < batchSize) {
sinkCounter.incrementBatchUnderflowCount();
} else {
sinkCounter.incrementBatchCompleteCount();
}
sinkCounter.addToEventDrainAttemptCount(size);
client.appendBatch(batch);
}
transaction.commit();
sinkCounter.addToEventDrainSuccessCount(size);
} catch (Throwable t) {
transaction.rollback();
if (t instanceof Error) {
throw (Error) t;
} else if (t instanceof ChannelException) {
logger.error("Rpc Sink " + getName() + ": Unable to get event from" +
" channel " + channel.getName() + ". Exception follows.", t);
status = Status.BACKOFF;
} else {
destroyConnection();
throw new EventDeliveryException("Failed to send events", t);
}
} finally {
transaction.close();
}
return status;
}
示例13: testSslSinkWithNonSslServer
import org.apache.flume.Transaction; //導入方法依賴的package包/類
@Test
public void testSslSinkWithNonSslServer() throws InterruptedException,
EventDeliveryException, InstantiationException, IllegalAccessException {
setUp();
Event event = EventBuilder.withBody("test event 1", Charsets.UTF_8);
Server server = createServer(new MockAvroServer());
server.start();
Context context = new Context();
context.put("hostname", hostname);
context.put("port", String.valueOf(port));
context.put("ssl", String.valueOf(true));
context.put("trust-all-certs", String.valueOf(true));
context.put("batch-size", String.valueOf(2));
context.put("connect-timeout", String.valueOf(2000L));
context.put("request-timeout", String.valueOf(3000L));
Configurables.configure(sink, context);
sink.start();
Assert.assertTrue(LifecycleController.waitForOneOf(sink,
LifecycleState.START_OR_ERROR, 5000));
Transaction transaction = channel.getTransaction();
transaction.begin();
for (int i = 0; i < 10; i++) {
channel.put(event);
}
transaction.commit();
transaction.close();
boolean failed = false;
try {
for (int i = 0; i < 5; i++) {
sink.process();
failed = true;
}
} catch (EventDeliveryException ex) {
logger.info("Correctly failed to send event", ex);
}
sink.stop();
Assert.assertTrue(LifecycleController.waitForOneOf(sink,
LifecycleState.STOP_OR_ERROR, 5000));
server.close();
if (failed) {
Assert.fail("SSL-enabled sink successfully connected to a non-SSL-enabled server, that's wrong.");
}
}
示例14: testMultipleClients
import org.apache.flume.Transaction; //導入方法依賴的package包/類
@Test
public void testMultipleClients() throws Exception {
ExecutorService submitter = Executors.newCachedThreadPool();
client = RpcClientFactory.getThriftInstance(props);
Context context = new Context();
context.put("capacity", "1000");
context.put("transactionCapacity", "1000");
channel.configure(context);
configureSource();
context.put(ThriftSource.CONFIG_BIND, "0.0.0.0");
context.put(ThriftSource.CONFIG_PORT, String.valueOf(port));
Configurables.configure(source, context);
source.start();
ExecutorCompletionService<Void> completionService = new ExecutorCompletionService(submitter);
for (int i = 0; i < 30; i++) {
completionService.submit(new SubmitHelper(i), null);
}
//wait for all threads to be done
for (int i = 0; i < 30; i++) {
completionService.take();
}
Transaction transaction = channel.getTransaction();
transaction.begin();
long after = System.currentTimeMillis();
List<Integer> events = Lists.newArrayList();
for (int i = 0; i < 300; i++) {
Event event = channel.take();
Assert.assertNotNull(event);
Assert.assertTrue(Long.valueOf(event.getHeaders().get("time")) < after);
events.add(Integer.parseInt(new String(event.getBody())));
}
transaction.commit();
transaction.close();
Collections.sort(events);
int index = 0;
//30 batches of 10
for (int i = 0; i < 30; i++) {
for (int j = 0; j < 10; j++) {
Assert.assertEquals(i, events.get(index++).intValue());
}
}
}
示例15: testGetTransaction
import org.apache.flume.Transaction; //導入方法依賴的package包/類
@Test
public void testGetTransaction() throws Exception {
final Transaction transaction = channel.getTransaction();
executor.submit(new Runnable() {
@Override
public void run() {
Assert.assertNotSame(transaction, channel.getTransaction());
}
}).get();
Assert.assertSame(transaction, channel.getTransaction());
transaction.begin();
executor.submit(new Runnable() {
@Override
public void run() {
Assert.assertNotSame(transaction, channel.getTransaction());
}
}).get();
Assert.assertSame(transaction, channel.getTransaction());
transaction.commit();
executor.submit(new Runnable() {
@Override
public void run() {
Assert.assertNotSame(transaction, channel.getTransaction());
}
}).get();
Assert.assertSame(transaction, channel.getTransaction());
transaction.close();
executor.submit(new Runnable() {
@Override
public void run() {
Assert.assertNotSame(transaction, channel.getTransaction());
}
}).get();
Assert.assertNotSame(transaction, channel.getTransaction());
}