如何设置一个计时器(例如2分钟)尝试连接数据库,然后在连接中出现任何问题时引发异常?
因此,答案的第一部分是如何做主题所要求的,因为这是我最初对它的解释方式,并且似乎有人发现有所帮助。此后,问题得到了澄清,我已经扩展了答案以解决该问题。
设定计时器
首先,你需要创建一个计时器(我在java.util这里使用版本):
import java.util.Timer;
..
Timer timer = new Timer();
要执行任务,请执行以下操作:
timer.schedule(new TimerTask() { @Override public void run() { // Your database code here } }, 2*60*1000); // Since Java-8 timer.schedule(() -> /* your database code here */, 2*60*1000);
要在持续时间之后重复执行任务,你可以执行以下操作:
timer.scheduleAtFixedRate(new TimerTask() { @Override public void run() { // Your database code here } }, 2*60*1000, 2*60*1000); // Since Java-8 timer.scheduleAtFixedRate(() -> /* your database code here */, 2*60*1000, 2*60*1000);
使任务超时
要专门执行所澄清的问题所要求的,即尝试在给定时间段内执行任务,可以执行以下操作:
ExecutorService service = Executors.newSingleThreadExecutor(); try { Runnable r = new Runnable() { @Override public void run() { // Database task } }; Future<?> f = service.submit(r); f.get(2, TimeUnit.MINUTES); // attempt the task for two minutes } catch (final InterruptedException e) { // The thread was interrupted during sleep, wait or join } catch (final TimeoutException e) { // Took too long! } catch (final ExecutionException e) { // An exception from within the Runnable task } finally { service.shutdown(); }
如果任务在2分钟内完成,此操作将正常执行,但有例外。如果运行时间超过该时间,则将抛出TimeoutException。
一个问题是,尽管两分钟后你将收到TimeoutException,但该任务实际上将继续运行,尽管推测数据库或网络连接最终将超时并在线程中引发异常。但是请注意,在这种情况发生之前,它可能会消耗资源。