カテゴリ: Kotlin 更新日: 2026/02/05

KotlinのAPI通信でタイムアウト・リトライ設定を行う方法をやさしく解説!初心者向けネットワーク入門

KotlinのAPI通信でタイムアウト・リトライ設定を行う方法
KotlinのAPI通信でタイムアウト・リトライ設定を行う方法

先生と生徒の会話形式で理解しよう

生徒

「アプリでインターネットを使うときに、通信が遅くて固まっちゃうことがあるんですけど、どうにかできないんですか?」

先生

「とても大事なところに気づきましたね。KotlinでAPI通信をする場合、タイムアウトリトライの設定を行うことで、そういった問題を防ぐことができますよ。」

生徒

「タイムアウトとリトライって何ですか?初心者でもわかるように教えてください!」

先生

「もちろんです。実際の使い方と一緒に、基礎からしっかり説明していきましょう!」

1. タイムアウトとリトライって何?

1. タイムアウトとリトライって何?
1. タイムアウトとリトライって何?

タイムアウトとは、ネットワーク通信で返事が返ってこないときに「もう待つのをやめる時間」のことです。例えば、自動販売機にお金を入れてもジュースが出てこなければ、しばらくして諦めますよね?それと同じです。

リトライは、「通信が失敗したから、もう一度試してみよう」という再試行の仕組みです。機械が自動で「もう一回!」ってやってくれます。

この2つを組み合わせることで、通信のトラブルが起きたときでも、アプリが賢く対応できるようになります。

2. Kotlinで使うライブラリ「OkHttp」

2. Kotlinで使うライブラリ「OkHttp」
2. Kotlinで使うライブラリ「OkHttp」

KotlinでAPI通信を行うときによく使われるのが、OkHttp(オーケー・エイチ・ティー・ティー・ピー)というライブラリです。これを使えば、タイムアウトやリトライの設定も簡単にできます。

まずはbuild.gradleファイルに以下の依存関係を追加して、OkHttpを使えるようにします。


dependencies {
    implementation("com.squareup.okhttp3:okhttp:4.12.0")
}

3. タイムアウトを設定する方法

3. タイムアウトを設定する方法
3. タイムアウトを設定する方法

タイムアウトには次の3種類があります。

  • 接続タイムアウト:サーバーに接続するまでの待ち時間
  • 読み取りタイムアウト:サーバーからの返事を待つ時間
  • 書き込みタイムアウト:データを送るときの制限時間

以下は、各タイムアウトを10秒に設定した例です。


val client = OkHttpClient.Builder()
    .connectTimeout(10, TimeUnit.SECONDS)
    .readTimeout(10, TimeUnit.SECONDS)
    .writeTimeout(10, TimeUnit.SECONDS)
    .build()

この設定により、通信が10秒以内に終わらなければ、自動的に中断されます。

4. リトライを設定する方法

4. リトライを設定する方法
4. リトライを設定する方法

OkHttpでは、retryOnConnectionFailure(true)を使うと、接続に失敗したときに自動で再試行してくれます。


val client = OkHttpClient.Builder()
    .retryOnConnectionFailure(true)
    .build()

ただし、何回リトライするかを細かく設定したい場合や、サーバー側のエラーに対応したい場合は、カスタムインターセプターを作る必要があります。

5. カスタムでリトライ回数を制御する

5. カスタムでリトライ回数を制御する
5. カスタムでリトライ回数を制御する

下のコードでは、最大3回までリトライするように設定した例を紹介します。


class RetryInterceptor(private val maxRetry: Int) : Interceptor {
    override fun intercept(chain: Interceptor.Chain): Response {
        var request = chain.request()
        var response: Response
        var tryCount = 0
        while (true) {
            try {
                response = chain.proceed(request)
                if (response.isSuccessful) return response
            } catch (e: IOException) {
                if (tryCount >= maxRetry) throw e
            }
            tryCount++
        }
    }
}

val client = OkHttpClient.Builder()
    .addInterceptor(RetryInterceptor(3))
    .build()

このようにすることで、「失敗したら最大3回まで自動で再試行する」仕組みを作れます。

6. 実際にAPIリクエストを送ってみよう

6. 実際にAPIリクエストを送ってみよう
6. 実際にAPIリクエストを送ってみよう

最後に、タイムアウトとリトライを設定したOkHttpClientで、実際にAPIリクエストを送る方法を紹介します。


val request = Request.Builder()
    .url("https://api.example.com/data")
    .build()

val response = client.newCall(request).execute()
if (response.isSuccessful) {
    println(response.body?.string())
} else {
    println("通信に失敗しました。")
}

このコードを実行すると、インターネットに接続してデータを取得し、うまくいけば中身を表示してくれます。

Kotlinを基礎からしっかり学びたい人や、 Java経験を活かしてモダンな言語にステップアップしたい人には、 定番の入門書がこちらです。

基礎からわかるKotlinをAmazonで見る

※ Amazon広告リンク

7. どんなときに使うべき?

7. どんなときに使うべき?
7. どんなときに使うべき?

タイムアウトやリトライは、スマホの電波が弱い場所や、サーバーが一時的に混雑しているときなど、通信が不安定になりやすい状況で特に重要です。

アプリが「フリーズした」と思われないように、こうした仕組みでユーザーのストレスを減らすことができます。

関連セミナーのご案内

【未経験OK】Kotlinで始めるプログラミング入門|ゼロから「動く喜び」を体験する60分

「プログラミングを始めたい」を形にする。最新言語Kotlinで楽しむ、ものづくりの第一歩。

本講座は、プログラミング経験が全くない方のためのエントリー講座です。「コードを書くってどういうこと?」という基本から、世界中で使われている最新言語Kotlin(コトリン)を使って、実際にプログラムを動かすまでを体験します。難しい理屈よりも、まずは「自分の手で動かす楽しさ」を最短距離で実感していただきます。

具体的な体験内容と環境

【つくるもの】
簡単な言葉を入力すると自動で返答してくれる「対話型ミニプログラム」や、計算を自動化する「便利ツール」をゼロから作成します。黒い画面に自分の書いた文字が表示される瞬間は、最高の感動体験です。

【開発環境】
プロのエンジニアが実際に使っている開発ツールIntelliJ IDEA(インテリジェイ)をインストールします。ボタン一つで日本語化し、初心者でも迷わず操作できる「魔法の設定」を一緒に行います。

この60分で得られる3つの体験

1. 自分のパソコンが「開発基地」に

プロと同じ道具を揃えることで、明日から一人でもプログラミングを続けられる環境が整います。

2. プログラミングの「仕組み」がスッキリ

「変数」や「型」といった難しい言葉も、身近な例え話で解説。モヤモヤをゼロにします。

3. 「読みやすい」から「直せる」へ

Kotlinは英語に近くて読みやすいのが特徴。自分でコードを読んで、間違いを見つけるコツも伝授します。

※本講座は、パソコン操作が不安な方でも安心して受講いただける完全マンツーマンです。あなたのペースに合わせて、一つずつ丁寧に進めていきます。

セミナー画像

Kotlinで始めるプログラミング入門|ゼロから「動く喜び」を体験

関連記事:
カテゴリの一覧へ
新着記事
New1
Go言語
Go言語のコメント活用術!TODO・FIXME・ドキュメンテーションコメントの書き方
New2
Go言語
Go言語のクロスコンパイルの基本!GOOSとGOARCHの使い方を初心者向けにやさしく解説
New3
Go言語
Go言語のテストでタイムアウト・並行処理を扱うポイント
New4
Go言語
Go言語のgo fmtでコードフォーマットを統一する方法!初心者でも簡単に整形
人気記事
No.1
Java&Spring記事人気No1
Kotlin
Gradleファイル(build.gradle.kts)の書き方と役割をやさしく解説!Kotlin初心者向け完全ガイド
No.2
Java&Spring記事人気No2
Kotlin
Android Studioのインストール手順と初期設定を初心者向けに完全解説!
No.3
Java&Spring記事人気No3
Swift
Swift開発環境の構築方法を徹底解説!Xcode・Windows・Linux対応
No.4
Java&Spring記事人気No4
Swift
Swift Playgroundの使い方を完全解説!初心者に最適な学習環境の始め方
No.5
Java&Spring記事人気No5
Kotlin
KotlinのRoomで複雑なクエリを使いこなす!初心者でもわかる応用テクニック
No.6
Java&Spring記事人気No6
Kotlin
Kotlinのインストール方法まとめ!Windows・Mac・Linux別にステップ解説
No.7
Java&Spring記事人気No7
Kotlin
Kotlinのsettings.gradleファイルを完全解説!初心者でもわかるプロジェクト設定の基本
No.8
Java&Spring記事人気No8
Go言語
Go言語の関数でエラーハンドリングする基本的な方法