ホームページ > Java > &#&チュートリアル > Java でデータベース接続のタイムアウトを実装するにはどうすればよいですか?

Java でデータベース接続のタイムアウトを実装するにはどうすればよいですか?

DDD
リリース: 2024-12-31 17:18:11
オリジナル
1038 人が閲覧しました

How Can I Implement Timeouts for Database Connections in Java?

Java でのタイマー実装を理解する

多くの場合、開発者は、特にデータベースへの接続を確立するときに、特定のタスクに対してタイマーを設定する必要に直面します。この記事は、特に接続試行がタイムアウトして例外をスローする必要があるシナリオで、Java でタイマーを設定する方法を説明することを目的としています。

タイマーの設定

java.util パッケージを使用して Java でタイマーを設定するには、次の手順に従います。

import java.util.Timer;

Timer timer = new Timer();
timer.schedule(new TimerTask() {
  @Override
  public void run() {
    // Your database connection logic
  }
}, 2 * 60 * 1000); // 2 minutes
ログイン後にコピー

または、繰り返しタスクの場合:

timer.scheduleAtFixedRate(new TimerTask() {
  @Override
  public void run() {
    // Your database connection logic
  }
}, 2 * 60 * 1000, 2 * 60 * 1000); // 2 minutes
ログイン後にコピー

タスクのタイムアウトの作成

タイムアウト メカニズムを実装するには、次のアプローチの使用を検討してください:

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;
import java.util.concurrent.TimeUnit;

ExecutorService service = Executors.newSingleThreadExecutor();

try {
    // Database task
    Runnable r = () -> {
      // Your database code here
    };

    Future<?> f = service.submit(r);

    // Attempt task for two minutes
    f.get(2, TimeUnit.MINUTES);
} catch (final InterruptedException e) {
    // Thread interrupted during sleep/wait/join
} catch (final TimeoutException e) {
    // Took too long
} catch (final ExecutionException e) {
    // Exception within task
} finally {
    service.shutdown();
}
ログイン後にコピー

このアプローチではタスクが通常どおり実行され、タイムアウト期間内に完了した場合は例外がスローされます。ただし、タイムアウトを超えてもタスクは実行を継続しますが、接続障害によりさらに例外が生成される可能性があることに注意してください。

以上がJava でデータベース接続のタイムアウトを実装するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート