OkHttp3でリクエストを発行後、速やかにプログラムを終了したい
OkHttp3を使ってHTTPSリクエストをいくつか発行すると、プログラム終了時に数分待たされてしまいます。
待ち時間が数秒ならともかく、数分待たされるのは改善したいのですが、どうにも方法が分からず困っています。
発生している問題
Eclipseでデバッグすると、以下の画像の状態で終了待ちが続く。エラーは特に出ていない。
該当のソースコード
以下のような典型的なサンプルコードで再現します。
※ここではgoogleにアクセスしていますが実際にはShopifyのREST-APIをいくつか叩く処理です。
Java
1package experimental; 2 3import okhttp3.HttpUrl; 4import okhttp3.OkHttpClient; 5import okhttp3.Request; 6 7public class Exp001 { 8 public static void main(String[] args) throws IOException { 9 var client = new OkHttpClient(); 10 var url = HttpUrl.parse("https://www.google.com/"); 11 12 Request.Builder rb = new Request.Builder(); 13 Request req = rb.url(url).build(); 14 15 try(var res = client.newCall(req).execute()) { 16 System.out.println(res.code()); 17 } 18 System.out.println("finish!"); 19 } 20}
試したこと
java
1 // OkHttpClient client = new OkHttpClient(); 2 var clientBuilder = new OkHttpClient.Builder(); 3 4 clientBuilder.callTimeout(10, TimeUnit.SECONDS); 5 clientBuilder.connectTimeout(10, TimeUnit.SECONDS); 6 clientBuilder.readTimeout(10, TimeUnit.SECONDS); 7 clientBuilder.writeTimeout(10, TimeUnit.SECONDS); 8 OkHttpClient client = clientBuilder.build();
などタイムアウト設定しても特に変化しなかった。
補足情報(FW/ツールのバージョンなど)
Java11
okhttp-3.14.9
okio-1.17.5
何かの設定が足りないのだとは思いますが、「okhttp スレッド 停止」「okhttp スレッド 終わらない」などで検索してみてもそれらしき情報を見つけられませんでした。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2021/10/21 06:49