成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Spring Boot 3.3 五種異步處理提升系統吞吐量的策略與實踐,徹底愛了!

開發 前端
通過本文介紹的五種異步處理方式,包括 @Async? 注解、CompletableFuture?、WebFlux、WebAsyncTask? 和 DeferredResult,我們可以有效地提升 Spring Boot 應用的性能。

在現代應用程序中,系統吞吐量和響應速度是關鍵的性能指標。在高并發環境下,傳統的同步處理方式可能會成為系統瓶頸,導致資源浪費和響應延遲。為了應對這種挑戰,Spring Boot 3.3 提供了強大的異步處理能力,使我們能夠通過異步接口顯著提高系統的吞吐量和響應速度。

異步接口的必要性

異步接口的核心在于能夠并行處理多個請求,而不阻塞主線程。這對于提高系統吞吐量和用戶體驗至關重要。傳統的同步處理方式需要等待每個請求完成才能處理下一個請求,這種模型在處理大量請求時容易造成資源的緊張和延遲的積累。異步處理則通過將任務分配給后臺線程,允許主線程繼續處理其他請求,從而有效減少了請求的等待時間和系統的負載。

異步接口的實現方式

在 Spring Boot 中,實現異步接口主要有以下幾種方式:

  1. 使用 @Async 注解:Spring 的 @Async 注解可以將方法標記為異步執行。被注解的方法將會在一個獨立的線程中運行,允許主線程繼續執行其他操作。
  2. 使用 CompletableFuture: CompletableFuture 提供了一種更靈活的方式來處理異步任務。它不僅支持簡單的異步操作,還提供了豐富的 API 來處理任務的組合、異常處理和結果回調。
  3. 使用 WebFlux:對于更復雜的異步場景,Spring WebFlux 提供了反應式編程模型,支持高效的非阻塞操作。雖然本文主要集中于傳統的異步處理方式,WebFlux 也是一種值得關注的異步解決方案。
  4. 使用 WebAsyncTask:是 Spring MVC 提供的一種異步處理機制,允許在后臺線程中執行長時間運行的任務,并在任務完成后將結果返回給客戶端。
  5. 使用 DeferredResult:是 Spring MVC 提供的一種異步處理機制,可以在后臺線程中執行任務并將結果返回給客戶端。它提供了更靈活的結果處理方式。

運行效果:

圖片圖片

若想獲取項目完整代碼以及其他文章的項目源碼,且在代碼編寫時遇到問題需要咨詢交流,歡迎加入下方的知識星球。

項目結構

本文將展示如何使用 Spring Boot 3.3 的異步功能來創建一個示例項目,通過簡單的示例來說明如何配置異步接口,并在前端使用 jQuery 實現異步請求的觸發和結果展示。項目結構如下:

async-demo
│
├── src
│   ├── main
│   │   ├── java
│   │   │   └── com
│   │   │       └── icoderoad
│   │   │           └── async
│   │   │               ├── AsyncDemoApplication.java
│   │   │               ├── controller
│   │   │               │   └── AsyncController.java
│   │   │               └── service
│   │   │                   └── AsyncService.java
│   │   └── resources
│   │       ├── application.yml
│   │       └── templates
│   │           └── index.html
└── pom.xml

Maven 配置

首先,配置 pom.xml 文件,添加所需的依賴:

<?xml versinotallow="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
	<modelVersion>4.0.0</modelVersion>
	<parent>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-parent</artifactId>
		<version>3.3.3</version>
		<relativePath/> <!-- lookup parent from repository -->
	</parent>
	<groupId>com.icoderoad</groupId>
	<artifactId>async-demo</artifactId>
	<version>0.0.1-SNAPSHOT</version>
	<name>async-demo</name>
	<description>Demo project for Spring Boot</description>
	
	<properties>
		<java.version>17</java.version>
	</properties>
	<dependencies>
		
		<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-thymeleaf</artifactId>
        </dependency>
        
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>
        
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-webflux</artifactId>
        </dependency>

		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-test</artifactId>
			<scope>test</scope>
		</dependency>
	</dependencies>

	<build>
		<plugins>
			<plugin>
				<groupId>org.springframework.boot</groupId>
				<artifactId>spring-boot-maven-plugin</artifactId>
			</plugin>
		</plugins>
	</build>

</project>

配置 application.yml

配置文件 application.yml 用于設置應用程序屬性:

server:
  port: 8080
  
spring:
  application:
    name: async-demo
  thymeleaf:
    cache: false
  web:
    resources:
      add-mappings: false

配置異步支持

在 Spring Boot 中啟用異步支持,需要在主應用類上添加 @EnableAsync 注解:

package com.icoderoad.async;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.scheduling.annotation.EnableAsync;

@SpringBootApplication
@EnableAsync
public class AsyncDemoApplication {

	public static void main(String[] args) {
		SpringApplication.run(AsyncDemoApplication.class, args);
	}

}

創建異步服務

創建一個服務類 AsyncService,實現以下五種異步處理方式:

使用 @Async 注解

package com.icoderoad.async.service;

import java.time.Duration;
import java.util.concurrent.Callable;
import java.util.concurrent.CompletableFuture;
import java.util.concurrent.Executors;
import java.util.concurrent.ThreadLocalRandom;
import java.util.concurrent.ThreadPoolExecutor;

import org.springframework.scheduling.annotation.Async;
import org.springframework.stereotype.Service;
import org.springframework.web.context.request.async.DeferredResult;
import org.springframework.web.context.request.async.WebAsyncTask;

import reactor.core.publisher.Mono;

@Service
public class AsyncService {
    private final ThreadPoolExecutor executor = (ThreadPoolExecutor) Executors.newCachedThreadPool();

    /**
     * 使用 @Async 注解的異步任務
     * @return CompletableFuture<String> 異步任務的結果
     * @throws InterruptedException 如果線程被中斷
     */
    @Async
    public CompletableFuture<String> asyncTaskWithAsyncAnnotation() throws InterruptedException {
        int delay = ThreadLocalRandom.current().nextInt(1000, 5000); // 隨機生成任務延遲時間
        Thread.sleep(delay); // 模擬任務執行時間
        return CompletableFuture.completedFuture("使用 @Async 注解的任務完成,耗時 " + delay + " 毫秒");
    }

    /**
     * 使用 CompletableFuture 進行異步任務
     * @return CompletableFuture<String> 異步任務的結果
     * @throws InterruptedException 如果線程被中斷
     */
    public CompletableFuture<String> asyncTaskWithCompletableFuture() throws InterruptedException {
        int delay = ThreadLocalRandom.current().nextInt(1000, 5000); // 隨機生成任務延遲時間
        return CompletableFuture.supplyAsync(() -> {
            try {
                Thread.sleep(delay); // 模擬任務執行時間
            } catch (InterruptedException e) {
                Thread.currentThread().interrupt(); // 恢復中斷狀態
            }
            return "使用 CompletableFuture 任務完成,耗時 " + delay + " 毫秒";
        });
    }

    /**
     * 使用 WebFlux 進行異步任務
     * @return Mono<String> 異步任務的結果
     */
    public Mono<String> asyncTaskWithWebFlux() {
        return Mono.fromCallable(() -> {
            int delay = ThreadLocalRandom.current().nextInt(1000, 5000); // 隨機生成任務延遲時間
            Thread.sleep(delay); // 模擬任務執行時間
            return "使用 WebFlux 任務完成,耗時 " + delay + " 毫秒";
        }).delayElement(Duration.ofMillis(1000)); // 添加延遲以模擬任務
    }

    /**
     * 使用 WebAsyncTask 進行異步任務
     * @return WebAsyncTask<String> 異步任務的結果
     */
    public WebAsyncTask<String> asyncTaskWithWebAsyncTask() {
        Callable<String> callable = () -> {
            int delay = ThreadLocalRandom.current().nextInt(1000, 5000); // 隨機生成任務延遲時間
            Thread.sleep(delay); // 模擬任務執行時間
            return "使用 WebAsyncTask 任務完成,耗時 " + delay + " 毫秒";
        };
        return new WebAsyncTask<>(callable); // 創建并返回 WebAsyncTask
    }

    /**
     * 使用 DeferredResult 進行異步任務
     * @return DeferredResult<String> 異步任務的結果
     */
    public DeferredResult<String> asyncTaskWithDeferredResult() {
        DeferredResult<String> deferredResult = new DeferredResult<>();
        executor.submit(() -> {
            try {
                int delay = ThreadLocalRandom.current().nextInt(1000, 5000); // 隨機生成任務延遲時間
                Thread.sleep(delay); // 模擬任務執行時間
                deferredResult.setResult("使用 DeferredResult 任務完成,耗時 " + delay + " 毫秒");
            } catch (InterruptedException e) {
                Thread.currentThread().interrupt(); // 恢復中斷狀態
                deferredResult.setErrorResult("發生錯誤"); // 設置錯誤結果
            }
        });
        return deferredResult; // 返回 DeferredResult
    }
}

創建控制器

創建控制器 AsyncController 來處理 HTTP 請求:

package com.icoderoad.async.controller;

import java.util.concurrent.CompletableFuture;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.context.request.async.DeferredResult;
import org.springframework.web.context.request.async.WebAsyncTask;

import com.icoderoad.async.service.AsyncService;

import reactor.core.publisher.Mono;

@RestController
@RequestMapping("/api")
public class AsyncController {

    @Autowired
    private AsyncService asyncService;

    @GetMapping("/async-annotation")
    public CompletableFuture<String> asyncTaskWithAsyncAnnotation() throws InterruptedException {
        return asyncService.asyncTaskWithAsyncAnnotation();
    }

    @GetMapping("/completable-future")
    public CompletableFuture<String> asyncTaskWithCompletableFuture() throws InterruptedException {
        return asyncService.asyncTaskWithCompletableFuture();
    }

    @GetMapping("/webflux")
    public Mono<String> asyncTaskWithWebFlux() {
        return asyncService.asyncTaskWithWebFlux();
    }
  
  	@GetMapping("/webasync")
    public WebAsyncTask<String> webAsyncTask() {
        return asyncService.asyncTaskWithWebAsyncTask();
    }
  
  	@GetMapping("/deferredresult")
    public DeferredResult<String> deferredResult() {
        return asyncService.asyncTaskWithDeferredResult();
    }
}

視圖控制器

package com.icoderoad.async.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;

@Controller
public class IndexController {

    @GetMapping("/")
    public String index() {
        return "index";
    }
    
}

創建前端頁面

在src/main/resources/templates目錄下創建 index.html 頁面來展示五種異步請求的結果,并使用 jQuery 實現異步請求的觸發:

<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
    <title>Spring Boot 異步接口示例</title>
    <link rel="stylesheet" >
    <script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
</head>
<body>
    <div class="container">
        <h1 class="mt-5">Spring Boot 異步接口示例</h1>
        <button id="async-annotation" class="btn btn-primary mt-3">調用 @Async 注解接口</button>
        <p id="result-async-annotation"></p>

        <button id="completable-future" class="btn btn-primary mt-3">調用 CompletableFuture 接口</button>
        <p id="result-completable-future"></p>

        <button id="webflux" class="btn btn-primary mt-3">調用 WebFlux 接口</button>
        <p id="result-webflux"></p>

        <button id="webasync" class="btn btn-primary mt-3">調用 WebAsyncTask 接口</button>
        <p id="result-webasync"></p>

        <button id="deferredresult" class="btn btn-primary mt-3">調用 DeferredResult 接口</button>
        <p id="result-deferredresult"></p>
    </div>

    <script>
        $(document).ready(function () {
            $('#async-annotation').click(function () {
                $.get('/api/async-annotation', function (data) {
                    $('#result-async-annotation').text(data);
                });
            });

            $('#completable-future').click(function () {
                $.get('/api/completable-future', function (data) {
                    $('#result-completable-future').text(data);
                });
            });

            $('#webflux').click(function () {
                $.get('/api/webflux', function (data) {
                    $('#result-webflux').text(data);
                });
            });

            $('#webasync').click(function () {
                $.get('/api/webasync', function (data) {
                    $('#result-webasync').text(data);
                });
            });

            $('#deferredresult').click(function () {
                $.get('/api/deferredresult', function (data) {
                    $('#result-deferredresult').text(data);
                });
            });
        });
    </script>
</body>
</html>

總結

通過本文介紹的五種異步處理方式,包括 @Async 注解、CompletableFuture、WebFlux、WebAsyncTask 和 DeferredResult,我們可以有效地提升 Spring Boot 應用的性能。每種方式都有其特定的適用場景和優缺點,開發者可以根據實際需求選擇合適的方式來優化應用的吞吐量和響應速度。希望這些示例能夠幫助你更好地理解和應用 Spring Boot 中的異步處理功能。

責任編輯:武曉燕 來源: 路條編程
相關推薦

2024-09-12 15:24:29

2024-09-09 14:12:38

2024-05-23 16:41:40

2025-06-05 03:00:00

Spring異步接口

2023-08-03 14:18:29

Rust阻塞函數

2021-12-26 00:03:27

響應式編程異步

2024-06-06 16:15:00

2025-05-09 02:00:00

代碼接口吞吐量

2024-12-13 13:58:53

2024-06-28 09:39:58

2023-02-09 08:57:11

Callable異步java

2024-01-19 13:42:00

模型訓練

2010-04-14 16:02:09

IDF

2023-11-07 15:11:46

Kafka技巧

2025-03-28 01:03:46

高并發技術異步

2013-04-19 09:45:20

AMPLabHadoopHDFS

2024-10-11 11:46:40

2022-12-23 09:49:42

算法開源

2019-08-20 00:20:47

TCPHOL吞吐量

2025-03-04 08:52:21

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 午夜国产一区 | 日韩a在线观看 | 国产目拍亚洲精品99久久精品 | 欧美综合国产精品久久丁香 | 久久精品无码一区二区三区 | 欧美久久久电影 | 午夜精品久久久久久久星辰影院 | 天天干天天谢 | 亚洲精品视频免费 | 精品视频一区二区三区在线观看 | 中文字幕影院 | 激情一区二区三区 | 天堂在线www | 亚洲一区在线日韩在线深爱 | 成人在线不卡 | 综合欧美亚洲 | 久久中文一区二区 | 日韩 国产 在线 | 一区二区高清 | 国产 亚洲 网红 主播 | av网站在线看 | 国产高清一区二区三区 | 久久久成人精品 | av天天看 | 男女羞羞视频在线免费观看 | 99re在线播放 | 91在线观看免费视频 | 久久久久国产一区二区三区四区 | 中文字幕一级毛片视频 | 皇色视频在线 | 久草欧美视频 | 一区二区不卡 | 久久久91精品国产一区二区三区 | 在线观看中文字幕 | 在线中文字幕日韩 | 超碰电影| 国产成人精品免费视频大全最热 | 99精品视频免费在线观看 | 精品国产乱码久久久久久图片 | 国产一区二区精品在线观看 | 日本免费一区二区三区四区 |