Есть ли какое-нибудь простое решение для сохранения данных в базу данных с использованием JPA в новом потоке?
Мое веб-приложение Spring позволяет пользователю управлять запланированными задачами. Во время выполнения он может создавать и запускать новые экземпляры предопределенных задач. Я использую Spring TaskScheduler, и все работает хорошо.
Но мне нужно сохранить логический результат каждой запущенной задачи в базу данных. Как я могу это сделать?
EDIT: Я должен обобщить свой вопрос: мне нужно вызвать метод из моего класса @Service из задач. Поскольку результат задачи должен быть "обработан" перед сохранением в базе данных.
ИЗМЕНИТЬ 2: Здесь добавлена упрощенная версия моего проблемного кода. Когда saveTaskResult() вызывается из планировщика, сообщение распечатывается, но ничего не сохраняется в db. Но всякий раз, когда я вызываю saveTaskResult() из контроллера, запись корректно сохраняется в базе данных.
@Service
public class DemoService {
@Autowired
private TaskResultDao taskResultDao;
@Autowired
private TaskScheduler scheduler;
public void scheduleNewTask() {
scheduler.scheduleWithFixedDelay(new Runnable() {
public void run() {
// do some action here
saveTaskResult(new TaskResult("result"));
}
}, 1000L);
}
@Transactional
public void saveTaskResult(TaskResult result) {
System.out.println("saving task result");
taskResultDao.persist(result);
}
}