簡體   English   中英

Spring重試JPA存儲庫

[英]Spring Retry on JPA repository

我是Spring的新手,作為項目實現的一部分,我應該在調用JPA存儲庫的服務方法上添加spring retry。 代碼如下所示

@Retryable(value = {Exception.class},maxAttempts = 1,backoff = @Backoff(300))
public Page<Account> findAllAccounts(AccountSearchRequest account, Pageable pageable) {
    try {
        return map(accountSearchRepository.findAll(account, pageable));
    }catch (Exception e){
        System.out.println("SQL EXCEPTION CAUGTH!!!!!!!!!");
    }
    return null;
}
@Recover
public void recover(Exception e){
    System.out.println("!!!!!!!!!!!Failed to get connection!!!!!!");
}

數據庫 :Postgresql,

應用程序 :Java Spring Boot(Exposed Rest API以獲取所有帳戶)

HikariPool MaximumPoolSize **:** 1

Hikari ConnectionTimeout **:** 1000

JMeter用於發送10,000個 API請求。

問題 :我能看到SQL EXCEPTION CAUGTH !!!!!!!!! 打印,但我認為重試不起作用,因為我沒有看到恢復方法的打印。 我錯過了什么嗎?

下面是gradle依賴項

// https://mvnrepository.com/artifact/org.springframework.retry/spring-retry
compile group: 'org.springframework.retry', name: 'spring-retry', version: '1.2.4.RELEASE'


// https://mvnrepository.com/artifact/org.springframework/spring-aspects
compile group: 'org.springframework', name: 'spring-aspects', version: '3.2.4.RELEASE'

// https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-aop
compile group: 'org.springframework.boot', name: 'spring-boot-starter-aop', version: '2.1.3.RELEASE'


// https://mvnrepository.com/artifact/org.springframework/spring-aop
compile group: 'org.springframework', name: 'spring-aop', version: '5.1.5.RELEASE'

嘗試

@Retryable(value = {SQLException.class},maxAttempts = 1,backoff = @Backoff(300))
public Page<Account> findAllAccounts(AccountSearchRequest account, Pageable pageable) throws SQLException {    
       throw new SQLException("test");
}

@Recover
public void recover(Exception e){
    System.out.println("!!!!!!!!!!!Failed to get connection!!!!!!");
}

感謝您的支持。

我發現問題是@Recover方法的數據類型與@Retryable 在上述場景中重試的條件

@Recover@Retryable應該是公共的並且具有相同的返回類型

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM