本文整理匯總了Java中org.apache.kafka.connect.errors.ConnectException類的典型用法代碼示例。如果您正苦於以下問題:Java ConnectException類的具體用法?Java ConnectException怎麽用?Java ConnectException使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
ConnectException類屬於org.apache.kafka.connect.errors包,在下文中一共展示了ConnectException類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: toSourceRecord
import org.apache.kafka.connect.errors.ConnectException; //導入依賴的package包/類
/**
* Convert a message into a Kafka Connect SourceRecord.
*
* @param context the JMS context to use for building messages
* @param topic the Kafka topic
* @param messageBodyJms whether to interpret MQ messages as JMS messages
* @param message the message
*
* @return the Kafka Connect SourceRecord
*
* @throws JMSException Message could not be converted
*/
@Override public SourceRecord toSourceRecord(JMSContext context, String topic, boolean messageBodyJms, Message message) throws JMSException {
byte[] payload;
if (message instanceof BytesMessage) {
payload = message.getBody(byte[].class);
}
else if (message instanceof TextMessage) {
String s = message.getBody(String.class);
payload = s.getBytes(UTF_8);
}
else {
log.error("Unsupported JMS message type {}", message.getClass());
throw new ConnectException("Unsupported JMS message type");
}
SchemaAndValue sv = converter.toConnectData(topic, payload);
return new SourceRecord(null, null, topic, sv.schema(), sv.value());
}
示例2: connectInternal
import org.apache.kafka.connect.errors.ConnectException; //導入依賴的package包/類
/**
* Internal method to connect to MQ.
*
* @throws RetriableException Operation failed, but connector should continue to retry.
* @throws ConnectException Operation failed and connector should stop.
*/
private void connectInternal() throws ConnectException, RetriableException {
if (connected) {
return;
}
try {
if (userName != null) {
jmsCtxt = mqConnFactory.createContext(userName, password, JMSContext.SESSION_TRANSACTED);
}
else {
jmsCtxt = mqConnFactory.createContext(JMSContext.SESSION_TRANSACTED);
}
jmsProd = jmsCtxt.createProducer();
jmsProd.setDeliveryMode(deliveryMode);
jmsProd.setTimeToLive(timeToLive);
connected = true;
}
catch (JMSRuntimeException jmse) {
log.debug("JMS exception {}", jmse);
handleException(jmse);
}
}
示例3: commit
import org.apache.kafka.connect.errors.ConnectException; //導入依賴的package包/類
/**
* Commits the current transaction. If the current transaction contains a message that could not
* be processed, the transaction is "in peril" and is rolled back instead to avoid data loss.
*
* @throws RetriableException Operation failed, but connector should continue to retry.
* @throws ConnectException Operation failed and connector should stop.
*/
public void commit() throws ConnectException, RetriableException {
connectInternal();
try {
if (inflight) {
inflight = false;
if (inperil) {
inperil = false;
log.trace("Rolling back in-flight transaction");
jmsCtxt.rollback();
throw new RetriableException("Transaction rolled back");
}
else {
jmsCtxt.commit();
}
}
}
catch (JMSRuntimeException jmse) {
log.debug("JMS exception {}", jmse);
handleException(jmse);
}
}
示例4: flush
import org.apache.kafka.connect.errors.ConnectException; //導入依賴的package包/類
public void flush(final List<String> sqlBatch) throws SQLException {
if (sqlBatch == null || sqlBatch.isEmpty()) {
return;
}
Connection connection = connectionHolder.getValidConnection();
connection.setAutoCommit(false);
Statement statement = connection.createStatement();
for (String sql : sqlBatch) {
log.info("===>>>statement addBatch sql:{}", sql);
statement.addBatch(sql);
}
int[] updateCountArr = statement.executeBatch();
if (updateCountArr.length != sqlBatch.size()) {
throw new ConnectException(String.format("updateCountArr size:(%d) not equals to sqlBatch size:(%d)", updateCountArr.length, sqlBatch.size()));
}
connection.commit();
statement.close();
}
示例5: seek
import org.apache.kafka.connect.errors.ConnectException; //導入依賴的package包/類
@Override
public void seek(Offset offset) {
if (offset.getRecordOffset() < 0) {
throw new IllegalArgumentException("Record offset must be greater than 0");
}
try {
if (offset.getRecordOffset() < reader.getLineNumber()) {
this.reader = new LineNumberReader(new InputStreamReader(getFs().open(getFilePath())));
currentLine = null;
}
while ((currentLine = reader.readLine()) != null) {
if (reader.getLineNumber() - 1 == offset.getRecordOffset()) {
this.offset.setOffset(reader.getLineNumber());
return;
}
}
this.offset.setOffset(reader.getLineNumber());
} catch (IOException ioe) {
throw new ConnectException("Error seeking file " + getFilePath(), ioe);
}
}
示例6: poll
import org.apache.kafka.connect.errors.ConnectException; //導入依賴的package包/類
@Override
public List<SourceRecord> poll() throws InterruptedException {
while (stop != null && !stop.get() && !policy.hasEnded()) {
log.trace("Polling for new data");
final List<SourceRecord> results = new ArrayList<>();
List<FileMetadata> files = filesToProcess();
files.forEach(metadata -> {
try (FileReader reader = policy.offer(metadata, context.offsetStorageReader())) {
log.info("Processing records for file {}", metadata);
while (reader.hasNext()) {
results.add(convert(metadata, reader.currentOffset(), reader.next()));
}
} catch (ConnectException | IOException e) {
//when an exception happens reading a file, the connector continues
log.error("Error reading file from FS: " + metadata.getPath() + ". Keep going...", e);
}
});
return results;
}
return null;
}
示例7: flush
import org.apache.kafka.connect.errors.ConnectException; //導入依賴的package包/類
public void flush(final List<String> sqlBatch) throws SQLException {
if (sqlBatch == null || sqlBatch.isEmpty()) {
return;
}
Connection connection = connectionHolder.getValidConnection();
connection.setAutoCommit(false);
Statement statement = connection.createStatement();
for (String sql : sqlBatch) {
statement.addBatch(sql);
}
int[] updateCountArr = statement.executeBatch();
if (updateCountArr.length != sqlBatch.size()) {
throw new ConnectException(String.format("updateCountArr size:(%d) not equals to sqlBatch size:(%d)",
updateCountArr.length, sqlBatch.size()));
}
connection.commit();
statement.close();
}
示例8: close
import org.apache.kafka.connect.errors.ConnectException; //導入依賴的package包/類
public void close(Collection<TopicPartition> partitions) {
// Close any writers we have. We may get assigned the same partitions and end up duplicating
// some effort since we'll have to reprocess those messages. It may be possible to hold on to
// the TopicPartitionWriter and continue to use the temp file, but this can get significantly
// more complex due to potential failures and network partitions. For example, we may get
// this close, then miss a few generations of group membership, during which
// data may have continued to be processed and we'd have to restart from the recovery stage,
// make sure we apply the WAL, and only reuse the temp file if the starting offset is still
// valid. For now, we prefer the simpler solution that may result in a bit of wasted effort.
for (TopicPartition tp: assignment) {
try {
topicPartitionWriters.get(tp).close();
} catch (ConnectException e) {
log.error("Error closing writer for {}. Error: {}", tp, e.getMessage());
} finally {
topicPartitionWriters.remove(tp);
}
}
}
示例9: start
import org.apache.kafka.connect.errors.ConnectException; //導入依賴的package包/類
@Override
public void start(Map<String, String> properties) {
//TODO: Create resources like database or api connections here.
FluentdSinkConnectorConfig config = new FluentdSinkConnectorConfig(properties);
Fluency.Config fluencyConfig = new Fluency.Config()
.setMaxBufferSize(config.getFluentdClientMaxBufferSize())
.setBufferChunkInitialSize(config.getFluentdClientBufferChunkInitialSize())
.setBufferChunkRetentionSize(config.getFluentdClientBufferChunkRetentionSize())
.setFlushIntervalMillis(config.getFluentdClientFlushInterval())
.setAckResponseMode(config.getFluentdClientAckResponseMode())
.setFileBackupDir(config.getFluentdClientFileBackupDir())
.setWaitUntilBufferFlushed(config.getFluentdClientWaitUntilBufferFlushed())
.setWaitUntilFlusherTerminated(config.getFluentdClientWaitUntilFlusherTerminated())
.setJvmHeapBufferMode(config.getFluentdClientJvmHeapBufferMode());
try {
fluency = Fluency.defaultFluency(config.getFluentdConnectAddresses(), fluencyConfig);
} catch (IOException e) {
throw new ConnectException(e);
}
converter = new SinkRecordConverter(config);
}
示例10: getWriter
import org.apache.kafka.connect.errors.ConnectException; //導入依賴的package包/類
private RecordWriter<SinkRecord> getWriter(SinkRecord record, String encodedPartition)
throws ConnectException {
try {
if (writers.containsKey(encodedPartition)) {
return writers.get(encodedPartition);
}
String tempFile = getTempFile(encodedPartition);
RecordWriter<SinkRecord> writer = writerProvider.getRecordWriter(conf, tempFile, record, avroData);
writers.put(encodedPartition, writer);
if (hiveIntegration && !hivePartitions.contains(encodedPartition)) {
addHivePartition(encodedPartition);
hivePartitions.add(encodedPartition);
}
return writer;
} catch (IOException e) {
throw new ConnectException(e);
}
}
示例11: put
import org.apache.kafka.connect.errors.ConnectException; //導入依賴的package包/類
@Override
public void put(final Collection<SinkRecord> records) {
if (records == null || records.isEmpty()) {
return;
}
log.info("===>>>records size:{}", records.size());
try {
writer.batchWrite(records);
} catch (SQLException e) {
log.error(e.getMessage(), e);
if (remainRetries <= 0) {
throw new ConnectException(e);
} else {
writer.closeQuietly();
writer = new MySqlDbWriter(config);
remainRetries--;
context.timeout(config.retryBackoffMs);
throw new RetriableException(e);
}
}
remainRetries = config.maxRetries;
}
示例12: timestampTypeFromSchema
import org.apache.kafka.connect.errors.ConnectException; //導入依賴的package包/類
/**
* Determine the type/format of the timestamp based on the schema
*/
private String timestampTypeFromSchema(Schema schema) {
if (Timestamp.LOGICAL_NAME.equals(schema.name())) {
return TYPE_TIMESTAMP;
} else if (org.apache.kafka.connect.data.Date.LOGICAL_NAME.equals(schema.name())) {
return TYPE_DATE;
} else if (Time.LOGICAL_NAME.equals(schema.name())) {
return TYPE_TIME;
} else if (schema.type().equals(Schema.Type.STRING)) {
// If not otherwise specified, string == user-specified string format for timestamps
return TYPE_STRING;
} else if (schema.type().equals(Schema.Type.INT64)) {
// If not otherwise specified, long == unix time
return TYPE_UNIX;
}
throw new ConnectException("Schema " + schema + " does not correspond to a known timestamp type format");
}
示例13: convertTimestamp
import org.apache.kafka.connect.errors.ConnectException; //導入依賴的package包/類
/**
* Convert the given timestamp to the target timestamp format.
* @param timestamp the input timestamp
* @param timestampFormat the format of the timestamp, or null if the format should be inferred
* @return the converted timestamp
*/
private Object convertTimestamp(Object timestamp, String timestampFormat) {
if (timestampFormat == null) {
timestampFormat = inferTimestampType(timestamp);
}
TimestampTranslator sourceTranslator = TRANSLATORS.get(timestampFormat);
if (sourceTranslator == null) {
throw new ConnectException("Unsupported timestamp type: " + timestampFormat);
}
Date rawTimestamp = sourceTranslator.toRaw(config, timestamp);
TimestampTranslator targetTranslator = TRANSLATORS.get(config.type);
if (targetTranslator == null) {
throw new ConnectException("Unsupported timestamp type: " + config.type);
}
return targetTranslator.toType(config, rawTimestamp);
}
示例14: put
import org.apache.kafka.connect.errors.ConnectException; //導入依賴的package包/類
@Override
public void put(final Collection<SinkRecord> records) {
if (records.isEmpty()) {
return;
}
log.info("===>>>records size:{}", records.size());
try {
writer.batchWrite(records);
} catch (SQLException e) {
log.error(e.getMessage(), e);
if (remainRetries <= 0) {
throw new ConnectException(e);
} else {
writer.closeQuietly();
writer = new MySqlDbWriter(config);
remainRetries--;
context.timeout(config.retryBackoffMs);
throw new RetriableException(e);
}
}
remainRetries = config.maxRetries;
}
示例15: deleteConnectorConfig
import org.apache.kafka.connect.errors.ConnectException; //導入依賴的package包/類
@Override
public synchronized void deleteConnectorConfig(String connName, Callback<Created<ConnectorInfo>> callback) {
try {
if (!configState.contains(connName)) {
// Deletion, must already exist
callback.onCompletion(new NotFoundException("Connector " + connName + " not found", null), null);
return;
}
removeConnectorTasks(connName);
worker.stopConnector(connName);
configBackingStore.removeConnectorConfig(connName);
onDeletion(connName);
callback.onCompletion(null, new Created<ConnectorInfo>(false, null));
} catch (ConnectException e) {
callback.onCompletion(e, null);
}
}