Javaアプリをおかしくする「外部システム」の厄介な問題とは? 対策はJavaのよくあるランタイムエラーの5大原因【第4回】

Javaのランタイムエラーは、アプリケーションとやりとりする外部システムに起因する場合がある。こうしたランタイムエラーの対処方法を紹介しよう。

2022年07月06日 05時00分 公開
[Cameron McKenzieTechTarget]

関連キーワード

Java | アプリケーション開発


 プログラミング言語および実行・開発環境「Java」を使用したアプリケーションの安定した実行のためには、実行中のエラーである「ラインタイムエラー」(実行時エラー)の原因を正しく理解し、対策を取ることが欠かせない。Javaの主要なランタイムエラーの5つの原因のうち、4つ目を解説する。

4.外部システムとの接続エラー

 アプリケーションが単独で存在することはほとんどない。データベース管理システムやメッセージキュー/ストリーム(連続的に発生し続けるデータ)処理ミドルウェアなど、さまざまな外部システムとやりとりする。外部システムとの接続が必要なアプリケーションが、外部システムに接続できなければ、結果としてランタイムエラーが生じることは避けられない。

 外部システムにおいて次のいずれかの状況が発生した際に、開発者が呼び出し元のアプリケーションに更新を加えないと、外部システムを原因とするランタイムエラーが生じる恐れがある。

  • IPアドレスの変更
  • 認証に必要な資格情報の変更
  • ファイアウォールの構成の変更
  • メンテナンスによる外部リソースの停止

 外部システムに変更が生じたら、開発者は速やかにアプリケーションを修正する必要がある。モダンなWebアプリケーションに関するベストプラクティス集「The Twelve-Factor App」は、全ての設定用データをアプリケーションの外部に保持することを推奨する。外部システムが変更されたときに、アプリケーションを迅速に修正できるようにするためだ。これによりソースコードを変更せず、ファイルを更新することで外部システムの変更に対処できるようになり、アプリケーションの再構築を回避しやすくなる。

 本番環境が不安定な状態でも稼働できるようにするアプリケーション設計手法を「カオスエンジニアリング」と呼ぶ。カオスエンジニアリングツールは、アプリケーションのプロセスをランダムに終了させることで、アプリケーションの耐障害性をテストするツールだ。カオスエンジニアリングツールは、外部システムで障害が発生しても応答性と回復性を保ったアプリケーションの開発を後押しする。

 外部システムを利用すると、そのシステムを開発者が制御できないという問題が必然的に生じる。それでも外部システムが原因で障害が発生した場合の、アプリケーションの対処方法は制御できる。開発者は、自身の制御が及ばない外部システム起因のランタイムエラーを見込んで、外部システムでの障害発生時に適切に対処可能なアプリケーションを開発することが重要だ。

TechTarget発 エンジニア虎の巻

米国TechTargetの豊富な記事の中から、開発のノウハウや技術知識など、ITエンジニアの問題解決に役立つ情報を厳選してお届けします。

Copyright © ITmedia, Inc. All Rights Reserved.

ITmedia マーケティング新着記事

news175.jpg

日清食品がカップ麺の1〜5位を独占 2024年、最も手に取られた新商品は?
カタリナマーケティングジャパンは、カタリナネットワーク内小売店における年間売り上げ...

news070.jpg

「イカゲーム」人気にドミノ・ピザも便乗 NetflixとCM共同制作の狙いは?
ケイト・トランブル氏がDomino’sのCMO(最高マーケティング責任者)に正式に就任して初...

news082.jpg

2024年記憶に残った「生成AI活用事例」は? 課長以上に聞くマーケトレンド
アイブリッジは、マーケティング業務に携わっている従業員数100人以上の企業在籍の課長以...