java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > Java 重连机制

Java 重连机制的几种实现方法

作者:思静鱼

本文主要介绍了Java 重连机制的几种实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

Java 重连机制一般是指在网络通信(HTTP、WebSocket、MQ、数据库连接等)中,客户端和服务端断开后,客户端需要具备 自动重试 + 重连 的能力,保证服务高可用。

1.通用重连机制设计思路

2.HTTP 接口重连(以 OkHttp 为例)

import okhttp3.*;

import java.io.IOException;
import java.util.concurrent.TimeUnit;

public class HttpRetryClient {
    private final OkHttpClient client;

    public HttpRetryClient() {
        this.client = new OkHttpClient.Builder()
                .connectTimeout(5, TimeUnit.SECONDS)
                .readTimeout(5, TimeUnit.SECONDS)
                .retryOnConnectionFailure(true) // 启用连接失败自动重试
                .build();
    }

    public String get(String url) {
        int maxRetries = 3;
        int attempt = 0;

        while (attempt < maxRetries) {
            try {
                Request request = new Request.Builder().url(url).build();
                Response response = client.newCall(request).execute();
                if (response.isSuccessful()) {
                    return response.body().string();
                }
            } catch (IOException e) {
                System.out.println("请求失败,正在重试: " + attempt);
            }
            attempt++;
            try {
                Thread.sleep((long) Math.pow(2, attempt) * 1000); // 指数退避
            } catch (InterruptedException ignored) {}
        }
        throw new RuntimeException("请求失败超过最大次数");
    }

    public static void main(String[] args) {
        HttpRetryClient client = new HttpRetryClient();
        System.out.println(client.get("http://example.com"));
    }
}

3.WebSocket 重连

import okhttp3.*;

public class WebSocketReconnect {
    private OkHttpClient client = new OkHttpClient();
    private WebSocket webSocket;
    private final String url = "ws://localhost:8080/ws";
    private int retryCount = 0;

    public void connect() {
        Request request = new Request.Builder().url(url).build();
        webSocket = client.newWebSocket(request, new WebSocketListener() {
            @Override
            public void onFailure(WebSocket ws, Throwable t, Response resp) {
                System.out.println("连接失败: " + t.getMessage());
                reconnect();
            }

            @Override
            public void onClosed(WebSocket ws, int code, String reason) {
                System.out.println("连接关闭: " + reason);
                reconnect();
            }
        });
    }

    private void reconnect() {
        if (retryCount < 5) {
            retryCount++;
            try {
                Thread.sleep(2000L * retryCount); // 逐渐延迟重连
            } catch (InterruptedException ignored) {}
            connect();
        } else {
            System.out.println("超过最大重连次数");
        }
    }

    public static void main(String[] args) {
        new WebSocketReconnect().connect();
    }
}

4.数据库重连(以 JDBC 为例)

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;

public class JdbcReconnect {
    private static final String URL = "jdbc:mysql://localhost:3306/test";
    private static final String USER = "root";
    private static final String PASS = "123456";

    public static Connection getConnection() {
        int retries = 0;
        while (retries < 5) {
            try {
                return DriverManager.getConnection(URL, USER, PASS);
            } catch (SQLException e) {
                retries++;
                System.out.println("数据库连接失败,重试中..." + retries);
                try {
                    Thread.sleep(2000 * retries);
                } catch (InterruptedException ignored) {}
            }
        }
        throw new RuntimeException("数据库连接失败超过最大次数");
    }

    public static void main(String[] args) {
        Connection conn = getConnection();
        System.out.println("数据库连接成功: " + conn);
    }
}

5.MQ(Kafka/RabbitMQ)重连

6.最佳实践总结

到此这篇关于Java 重连机制的几种实现方法的文章就介绍到这了,更多相关Java 重连机制内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文