Запись журналов в базу данных в приложении QuarkusJAVA

Программисты JAVA общаются здесь
Ответить
Anonymous
 Запись журналов в базу данных в приложении Quarkus

Сообщение Anonymous »

Как я могу записывать сообщения журнала в базу данных в моем приложении Quarkus?
Я пытался создать ExtHandler следующим образом:

Код: Выделить всё

package org.myorg;

import io.agroal.api.AgroalDataSource;
import jakarta.enterprise.context.ApplicationScoped;
import jakarta.inject.Inject;
import org.jboss.logmanager.ExtHandler;
import org.jboss.logmanager.ExtLogRecord;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;

@ApplicationScoped
public class DatabaseLogHandler extends ExtHandler {

@Inject
private AgroalDataSource dataSource;

@Override
protected void doPublish(final ExtLogRecord record) {
try (final Connection conn = this.dataSource.getConnection();
final PreparedStatement ps = conn.prepareStatement(
"INSERT INTO logs(timestamp, level, logger, message) VALUES (?, ?, ?, ?)")) {

ps.setLong(1, record.getMillis());
ps.setString(2, record.getLevel().toString());
ps.setString(3, record.getLoggerName());
ps.setString(4, record.getMessage());
ps.executeUpdate();

} catch (final SQLException e) {
e.printStackTrace();
}
}
}
и добавлено

Код: Выделить всё

quarkus.log.handler.database=DatabaseLogHandler
в мои application.properties, но код не выполняется.

Подробнее здесь: https://stackoverflow.com/questions/798 ... pplication
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «JAVA»