我试图直接使用自定义java类将消息从Oracle发布到Kafka代理,因为我在oracle中上传了所需的库并使用oracle function / procedure调用java函数。基本的java函数工作正常但函数中Kafka正在初始化并使用抛出未捕获的异常。即使我将整个函数体放在try-catch块中,但仍然没有将我的自定义异常作为消息。
我正在使用具有JVM版本1.8的Oracle 12C。
此消息在java函数调用(java.lang.NoClassDefFound Error)的oracle SQL提示符上弹出。
我为我的自定义类创建了一个jar文件,并将它与其受尊重的库一起上传到oracle DB。 我使用下面的命令上传了库文件。
loadjava -u <user>/<Password>@DB -resolve <library>.jar
请告诉我如何从oracle内部初始化Kafka Producer并开始发送消息
如何调试oracle DB中加载的java函数。
我的自定义类在下面给出
public class KafkaPublisher {
static ProducerRecord<String, String> PR = null;
static Producer<String, String> producer = null;
static Properties prop = new Properties();
public static void init() {
prop.put("bootstrap.servers", "111.11.11.11:9092");
prop.put("acks", "1");
prop.put("retries", "0");
prop.put("batch.size", "16384");
prop.put("linger.ms", "1");
prop.put("buffer.memory", "33554432");
prop.put("key.serializer", "org.apache.kafka.common.serialization.StringSerializer");
prop.put("value.serializer", "org.apache.kafka.common.serialization.StringSerializer");
}
public static String push(String data) {
String response = "No responce";
init();
try {
producer = new KafkaProducer<String, String>(prop);
PR = new ProducerRecord<String, String>("topic1", data);
Future<RecordMetadata> future = producer.send(PR);
RecordMetadata rMetaData = future.get();
response = "Current Offset: " + rMetaData.offset();
} catch (Exception e) {
response = "Message: " + e.getMessage() + " Cause: " + e.getCause();
}
return response;
}
public static String getProperties(String msg) {
return "My message: " + msg + prop.toString();
}
}
function getProperties(String msg)工作正常,但功能正常 push(字符串数据)不起作用。
答案 0 :(得分:1)
您究竟加载了哪些库到数据库? 对我来说,我缺少 slf4j-simple jar 库。
您还需要向 dbuser 授予这些权限:
exec dbms_java.grant_permission( <DB_USER>, 'SYS:javax.management.MBeanServerPermission', 'createMBeanServer', '' )
exec dbms_java.grant_permission( <DB_USER>, 'SYS:javax.management.MBeanTrustPermission', 'register', '' )
exec dbms_java.grant_permission( <DB_USER>, 'SYS:javax.management.MBeanPermission', '*', '*' )