亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

SpringBoot集成Kafka的實(shí)現(xiàn)示例

 更新時間:2025年01月13日 08:32:58   作者:一葉飄零_sweeeet  
本文主要介紹了SpringBoot集成Kafka的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

在現(xiàn)代軟件開發(fā)中,分布式系統(tǒng)和微服務(wù)架構(gòu)越來越受到關(guān)注。為了實(shí)現(xiàn)系統(tǒng)之間的異步通信和解耦,消息隊(duì)列成為了一種重要的技術(shù)手段。Kafka 作為一種高性能、分布式的消息隊(duì)列系統(tǒng),被廣泛應(yīng)用于各種場景。而 Spring Boot 作為一種流行的 Java 開發(fā)框架,提供了便捷的方式來構(gòu)建應(yīng)用程序。本文將介紹如何在 Spring Boot 項(xiàng)目中集成 Kafka,包括 Kafka 的基本概念、Spring Boot 集成 Kafka 的步驟、配置項(xiàng)以及實(shí)際應(yīng)用案例。

一、引言

隨著軟件系統(tǒng)的規(guī)模和復(fù)雜性不斷增加,傳統(tǒng)的同步通信方式已經(jīng)無法滿足需求。消息隊(duì)列作為一種異步通信機(jī)制,可以有效地解耦系統(tǒng)之間的依賴關(guān)系,提高系統(tǒng)的可擴(kuò)展性和可靠性。Kafka 以其高吞吐量、可擴(kuò)展性和分布式特性,成為了許多企業(yè)級應(yīng)用的首選消息隊(duì)列系統(tǒng)。Spring Boot 則提供了一種快速、便捷的方式來構(gòu)建應(yīng)用程序,使得開發(fā)者可以更加專注于業(yè)務(wù)邏輯的實(shí)現(xiàn)。將 Spring Boot 與 Kafka 集成,可以充分發(fā)揮兩者的優(yōu)勢,構(gòu)建出高效、可靠的消息驅(qū)動應(yīng)用。

二、Kafka 基礎(chǔ)概念

(一)Kafka 簡介

Kafka 是一個分布式的流處理平臺,同時也可以作為一個高性能的消息隊(duì)列系統(tǒng)使用。它最初由 LinkedIn 開發(fā),后來成為了 Apache 軟件基金會的一個開源項(xiàng)目。Kafka 具有以下幾個主要特點(diǎn):

  • 高吞吐量:Kafka 能夠處理大量的消息,每秒可以處理數(shù)十萬條消息。
  • 分布式架構(gòu):Kafka 可以在多個服務(wù)器上運(yùn)行,實(shí)現(xiàn)分布式存儲和處理消息。
  • 可擴(kuò)展性:可以根據(jù)需要動態(tài)地增加或減少服務(wù)器數(shù)量,以滿足不同的負(fù)載需求。
  • 持久化存儲:Kafka 可以將消息持久化存儲在磁盤上,保證消息不會丟失。
  • 多消費(fèi)者支持:多個消費(fèi)者可以同時從同一個主題中讀取消息,實(shí)現(xiàn)消息的廣播和訂閱。

(二)Kafka 核心概念

  • 主題(Topic)
    • 主題是 Kafka 中消息的邏輯分類。生產(chǎn)者將消息發(fā)送到特定的主題,消費(fèi)者從相應(yīng)的主題中讀取消息。一個主題可以被分為多個分區(qū)(Partition),每個分區(qū)可以在不同的服務(wù)器上存儲,以實(shí)現(xiàn)高吞吐量和可擴(kuò)展性。
  • 分區(qū)(Partition)
    • 分區(qū)是主題的物理劃分。每個分區(qū)都是一個有序的、不可變的消息序列。分區(qū)可以在不同的服務(wù)器上存儲,以實(shí)現(xiàn)分布式存儲和處理。消費(fèi)者可以從一個或多個分區(qū)中讀取消息,以實(shí)現(xiàn)并行處理。
  • 生產(chǎn)者(Producer)
    • 生產(chǎn)者是向 Kafka 主題發(fā)送消息的應(yīng)用程序。生產(chǎn)者可以將消息發(fā)送到一個或多個主題,并可以指定消息的分區(qū)和鍵值對。生產(chǎn)者可以使用異步或同步的方式發(fā)送消息,以滿足不同的應(yīng)用場景需求。
  • 消費(fèi)者(Consumer)
    • 消費(fèi)者是從 Kafka 主題讀取消息的應(yīng)用程序。消費(fèi)者可以訂閱一個或多個主題,并可以從一個或多個分區(qū)中讀取消息。消費(fèi)者可以使用自動提交偏移量(Offset)或手動提交偏移量的方式來處理消息,以滿足不同的應(yīng)用場景需求。
  • 偏移量(Offset)
    • 偏移量是消費(fèi)者在分區(qū)中讀取消息的位置。每個分區(qū)都有一個唯一的偏移量,消費(fèi)者可以通過偏移量來確定下一個要讀取的消息。消費(fèi)者可以自動提交偏移量或手動提交偏移量,以保證消息的處理順序和可靠性。

(三)Kafka 架構(gòu)

  • Broker
    • Broker 是 Kafka 中的服務(wù)器節(jié)點(diǎn)。每個 Broker 可以存儲多個主題的分區(qū),并可以接收生產(chǎn)者發(fā)送的消息和向消費(fèi)者提供消息。Broker 之間通過網(wǎng)絡(luò)通信,實(shí)現(xiàn)分布式存儲和處理消息。
  • Zookeeper
    • Zookeeper 是一個分布式協(xié)調(diào)服務(wù),用于管理 Kafka 集群的元數(shù)據(jù)。Zookeeper 存儲了 Kafka 集群的配置信息、主題和分區(qū)的元數(shù)據(jù)、消費(fèi)者的偏移量等信息。Kafka 客戶端通過與 Zookeeper 通信,獲取集群的元數(shù)據(jù)信息,并進(jìn)行生產(chǎn)者和消費(fèi)者的協(xié)調(diào)。

三、Spring Boot 集成 Kafka 的步驟

(一)添加依賴

在 Spring Boot 項(xiàng)目的 pom.xml 文件中添加以下依賴:

<dependency>
    <groupId>org.springframework.kafka</groupId>
    <artifactId>spring-kafka</artifactId>
</dependency>

這個依賴將引入 Spring Kafka 模塊,使我們能夠在 Spring Boot 項(xiàng)目中使用 Kafka。

(二)配置 Kafka

在 application.properties 或 application.yml 文件中添加 Kafka 的配置信息:

spring.kafka.bootstrap-servers=localhost:9092

這個配置指定了 Kafka 服務(wù)器的地址和端口??梢愿鶕?jù)實(shí)際情況進(jìn)行修改。

(三)創(chuàng)建生產(chǎn)者

  • 創(chuàng)建一個生產(chǎn)者配置類,用于配置生產(chǎn)者的屬性:
import org.apache.kafka.clients.producer.ProducerConfig;
import org.apache.kafka.common.serialization.StringSerializer;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.kafka.core.DefaultKafkaProducerFactory;
import org.springframework.kafka.core.KafkaTemplate;
import org.springframework.kafka.core.ProducerFactory;

import java.util.HashMap;
import java.util.Map;

@Configuration
public class KafkaProducerConfig {

    @Bean
    public ProducerFactory<String, String> producerFactory() {
        Map<String, Object> configProps = new HashMap<>();
        configProps.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG, "localhost:9092");
        configProps.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, StringSerializer.class);
        configProps.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG, StringSerializer.class);
        return new DefaultKafkaProducerFactory<>(configProps);
    }

    @Bean
    public KafkaTemplate<String, String> kafkaTemplate() {
        return new KafkaTemplate<>(producerFactory());
    }
}

在這個配置類中,我們創(chuàng)建了一個ProducerFactory和一個KafkaTemplate。ProducerFactory用于創(chuàng)建生產(chǎn)者實(shí)例,KafkaTemplate是一個方便的工具類,用于發(fā)送消息。

2. 創(chuàng)建一個生產(chǎn)者服務(wù)類,用于發(fā)送消息:

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.kafka.core.KafkaTemplate;
import org.springframework.stereotype.Service;

@Service
public class KafkaProducerService {

    @Autowired
    private KafkaTemplate<String, String> kafkaTemplate;

    public void sendMessage(String topic, String message) {
        kafkaTemplate.send(topic, message);
    }
}

這個服務(wù)類使用KafkaTemplate來發(fā)送消息??梢栽谄渌胤阶⑷脒@個服務(wù)類,并調(diào)用sendMessage方法來發(fā)送消息。

(四)創(chuàng)建消費(fèi)者

  • 創(chuàng)建一個消費(fèi)者配置類,用于配置消費(fèi)者的屬性:
import org.apache.kafka.clients.consumer.ConsumerConfig;
import org.apache.kafka.common.serialization.StringDeserializer;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.kafka.config.ConcurrentKafkaListenerContainerFactory;
import org.springframework.kafka.core.ConsumerFactory;
import org.springframework.kafka.core.DefaultKafkaConsumerFactory;

import java.util.HashMap;
import java.util.Map;

@Configuration
public class KafkaConsumerConfig {

    @Bean
    public ConsumerFactory&lt;String, String&gt; consumerFactory() {
        Map&lt;String, Object&gt; configProps = new HashMap&lt;&gt;();
        configProps.put(ConsumerConfig.BOOTSTRAP_SERVERS_CONFIG, "localhost:9092");
        configProps.put(ConsumerConfig.KEY_DESERIALIZER_CLASS_CONFIG, StringDeserializer.class);
        configProps.put(ConsumerConfig.VALUE_DESERIALIZER_CLASS_CONFIG, StringDeserializer.class);
        configProps.put(ConsumerConfig.GROUP_ID_CONFIG, "my-consumer-group");
        return new DefaultKafkaConsumerFactory&lt;&gt;(configProps);
    }

    @Bean
    public ConcurrentKafkaListenerContainerFactory&lt;String, String&gt; kafkaListenerContainerFactory() {
        ConcurrentKafkaListenerContainerFactory&lt;String, String&gt; factory = new ConcurrentKafkaListenerContainerFactory&lt;&gt;();
        factory.setConsumerFactory(consumerFactory());
        return factory;
    }
}

在這個配置類中,我們創(chuàng)建了一個ConsumerFactory和一個ConcurrentKafkaListenerContainerFactoryConsumerFactory用于創(chuàng)建消費(fèi)者實(shí)例,ConcurrentKafkaListenerContainerFactory是一個用于處理多個消費(fèi)者的容器工廠。

2. 創(chuàng)建一個消費(fèi)者服務(wù)類,用于處理接收到的消息:

import org.springframework.kafka.annotation.KafkaListener;
import org.springframework.stereotype.Service;

@Service
public class KafkaConsumerService {

    @KafkaListener(topics = "my-topic", groupId = "my-consumer-group")
    public void consumeMessage(String message) {
        System.out.println("Received message: " + message);
    }
}

這個服務(wù)類使用@KafkaListener注解來定義一個消費(fèi)者方法,該方法將在接收到消息時被調(diào)用??梢愿鶕?jù)實(shí)際需求對消息進(jìn)行處理。

四、Spring Boot 集成 Kafka 的配置項(xiàng)

(一)生產(chǎn)者配置項(xiàng)

  • bootstrap.servers:Kafka 服務(wù)器的地址和端口,多個服務(wù)器之間用逗號分隔。
  • key.serializer:消息鍵的序列化器類名。
  • value.serializer:消息值的序列化器類名。
  • acks:生產(chǎn)者發(fā)送消息后,需要等待多少個副本確認(rèn)才能認(rèn)為消息發(fā)送成功??蛇x值有0(不等待確認(rèn))、1(等待首領(lǐng)副本確認(rèn))和all(等待所有副本確認(rèn))。
  • retries:生產(chǎn)者發(fā)送消息失敗后,重試的次數(shù)。

(二)消費(fèi)者配置項(xiàng)

  • bootstrap.servers:Kafka 服務(wù)器的地址和端口,多個服務(wù)器之間用逗號分隔。
  • key.deserializer:消息鍵的反序列化器類名。
  • value.deserializer:消息值的反序列化器類名。
  • group.id:消費(fèi)者組的名稱,用于區(qū)分不同的消費(fèi)者組。
  • auto.offset.reset:當(dāng)消費(fèi)者從沒有偏移量的分區(qū)開始讀取消息時,應(yīng)該從哪里開始讀取??蛇x值有earliest(從最早的消息開始讀?。?code>latest(從最新的消息開始讀?。┖?code>none(如果沒有偏移量,則拋出異常)。

五、Spring Boot 集成 Kafka 的實(shí)際應(yīng)用案例

(一)日志收集

  • 場景描述
    • 在一個分布式系統(tǒng)中,各個服務(wù)產(chǎn)生的日志需要集中收集和處理。可以使用 Kafka 作為日志收集的中間件,將各個服務(wù)的日志發(fā)送到 Kafka 主題中,然后由一個專門的日志處理服務(wù)從 Kafka 中讀取日志并進(jìn)行處理。
  • 實(shí)現(xiàn)步驟
    • 在各個服務(wù)中,使用 Spring Boot 集成 Kafka 的生產(chǎn)者功能,將日志發(fā)送到特定的 Kafka 主題中。
    • 創(chuàng)建一個日志處理服務(wù),使用 Spring Boot 集成 Kafka 的消費(fèi)者功能,從 Kafka 主題中讀取日志并進(jìn)行處理,例如存儲到數(shù)據(jù)庫、進(jìn)行分析等。

(二)訂單處理系統(tǒng)

  • 場景描述
    • 在一個電商訂單處理系統(tǒng)中,訂單的創(chuàng)建、支付、發(fā)貨等狀態(tài)變化需要通知各個相關(guān)系統(tǒng)??梢允褂?Kafka 作為消息中間件,將訂單狀態(tài)變化的消息發(fā)送到 Kafka 主題中,各個相關(guān)系統(tǒng)從 Kafka 中讀取消息并進(jìn)行相應(yīng)的處理。
  • 實(shí)現(xiàn)步驟
    • 當(dāng)訂單狀態(tài)發(fā)生變化時,使用 Spring Boot 集成 Kafka 的生產(chǎn)者功能,將訂單狀態(tài)變化的消息發(fā)送到特定的 Kafka 主題中。
    • 各個相關(guān)系統(tǒng),如庫存管理系統(tǒng)、物流管理系統(tǒng)等,使用 Spring Boot 集成 Kafka 的消費(fèi)者功能,從 Kafka 主題中讀取訂單狀態(tài)變化的消息并進(jìn)行相應(yīng)的處理。

(三)實(shí)時數(shù)據(jù)處理

  • 場景描述
    • 在一個實(shí)時數(shù)據(jù)處理系統(tǒng)中,需要對大量的實(shí)時數(shù)據(jù)進(jìn)行處理和分析。可以使用 Kafka 作為數(shù)據(jù)傳輸?shù)闹虚g件,將實(shí)時數(shù)據(jù)發(fā)送到 Kafka 主題中,然后由一個實(shí)時數(shù)據(jù)處理服務(wù)從 Kafka 中讀取數(shù)據(jù)并進(jìn)行處理。
  • 實(shí)現(xiàn)步驟
    • 數(shù)據(jù)源(如傳感器、日志文件等)將實(shí)時數(shù)據(jù)發(fā)送到 Kafka 主題中。
    • 使用 Spring Boot 集成 Kafka 的消費(fèi)者功能,創(chuàng)建一個實(shí)時數(shù)據(jù)處理服務(wù),從 Kafka 主題中讀取實(shí)時數(shù)據(jù)并進(jìn)行處理,例如進(jìn)行數(shù)據(jù)分析、生成報表等。

六、性能優(yōu)化和故障排除

(一)性能優(yōu)化

  • 調(diào)整 Kafka 服務(wù)器配置
    • 根據(jù)實(shí)際情況調(diào)整 Kafka 服務(wù)器的配置參數(shù),如內(nèi)存分配、磁盤空間、網(wǎng)絡(luò)參數(shù)等,以提高 Kafka 的性能。
  • 優(yōu)化生產(chǎn)者和消費(fèi)者代碼
    • 在生產(chǎn)者和消費(fèi)者代碼中,避免不必要的序列化和反序列化操作,減少網(wǎng)絡(luò)傳輸開銷。
    • 合理設(shè)置生產(chǎn)者的重試次數(shù)和等待確認(rèn)的參數(shù),以提高消息發(fā)送的成功率和性能。
    • 對于消費(fèi)者,可以根據(jù)實(shí)際情況調(diào)整拉取消息的頻率和批量處理的大小,以提高消費(fèi)效率。
  • 使用分區(qū)和多消費(fèi)者
    • 根據(jù)業(yè)務(wù)需求合理劃分 Kafka 主題的分區(qū),并使用多個消費(fèi)者同時從不同的分區(qū)中讀取消息,以提高消費(fèi)的并行度和性能。

(二)故障排除

  • 消息丟失或重復(fù)
    • 檢查生產(chǎn)者和消費(fèi)者的配置參數(shù),確保消息的發(fā)送和消費(fèi)過程正確。
    • 檢查 Kafka 服務(wù)器的配置參數(shù),確保消息的持久化和副本機(jī)制正常工作。
    • 如果出現(xiàn)消息丟失或重復(fù)的情況,可以通過調(diào)整生產(chǎn)者和消費(fèi)者的配置參數(shù),或者使用 Kafka 的事務(wù)功能來保證消息的一致性。
  • 消費(fèi)延遲
    • 檢查消費(fèi)者的拉取頻率和批量處理大小,是否設(shè)置合理。
    • 檢查 Kafka 服務(wù)器的負(fù)載情況,是否存在性能瓶頸。
    • 如果消費(fèi)延遲較高,可以考慮增加消費(fèi)者的數(shù)量,或者調(diào)整 Kafka 服務(wù)器的配置參數(shù),以提高消費(fèi)效率。
  • 連接問題
    • 檢查 Kafka 服務(wù)器的地址和端口是否正確配置。
    • 檢查網(wǎng)絡(luò)連接是否正常,是否存在防火墻等限制。
    • 如果出現(xiàn)連接問題,可以通過檢查網(wǎng)絡(luò)配置、調(diào)整防火墻規(guī)則等方式來解決。

七、總結(jié)

本文介紹了如何在 Spring Boot 項(xiàng)目中集成 Kafka,包括 Kafka 的基本概念、Spring Boot 集成 Kafka 的步驟、配置項(xiàng)以及實(shí)際應(yīng)用案例。通過集成 Kafka,我們可以構(gòu)建出高效、可靠的消息驅(qū)動應(yīng)用,實(shí)現(xiàn)系統(tǒng)之間的異步通信和解耦。在實(shí)際應(yīng)用中,我們還可以根據(jù)需要進(jìn)行性能優(yōu)化和故障排除,以確保系統(tǒng)的穩(wěn)定運(yùn)行。希望本文對大家在 Spring Boot 集成 Kafka 方面有所幫助。

到此這篇關(guān)于SpringBoot集成Kafka的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)SpringBoot集成Kafka內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java基礎(chǔ)-Java編程語言發(fā)展史

    Java基礎(chǔ)-Java編程語言發(fā)展史

    這篇文章主要介紹了Java基礎(chǔ)-Java編程語言發(fā)展簡史,Java源自Sun公司的一個叫Green的項(xiàng)目,其原先的目的是為家用電子消費(fèi)產(chǎn)品開發(fā)一個分布式代碼系統(tǒng),這樣就可以將通信和控制信息發(fā)給電冰箱、電視機(jī)、烤面包機(jī)等家用電器,對它們進(jìn)行控制和信息交流,需要的朋友可以參考一下
    2022-01-01
  • SpringBoot 創(chuàng)建容器的實(shí)現(xiàn)

    SpringBoot 創(chuàng)建容器的實(shí)現(xiàn)

    這篇文章主要介紹了SpringBoot 創(chuàng)建容器的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10
  • java中如何調(diào)用js

    java中如何調(diào)用js

    Nashorn是Java8中引入的一個新的JavaScript引擎,它允許在JVM上運(yùn)行JavaScript代碼,并且可以與Java代碼相互調(diào)用,Nashorn遵循JSR233規(guī)范,是一個純Java實(shí)現(xiàn)的JavaScript引擎,可以與Java程序無縫集成,提供動態(tài)腳本執(zhí)行和靈活性
    2025-01-01
  • Spring?Data?Jpa框架最佳實(shí)踐示例

    Spring?Data?Jpa框架最佳實(shí)踐示例

    這篇文章主要為大家介紹了Spring?Data?Jpa框架最佳實(shí)踐示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪
    2022-02-02
  • linux系統(tǒng)下查看jdk版本、路徑及配置環(huán)境變量

    linux系統(tǒng)下查看jdk版本、路徑及配置環(huán)境變量

    在Linux系統(tǒng)中,配置JDK環(huán)境變量是非常重要的,它可以讓你在終端中直接使用Java命令,這篇文章主要給大家介紹了關(guān)于linux系統(tǒng)下查看jdk版本、路徑及配置環(huán)境變量的相關(guān)資料,需要的朋友可以參考下
    2024-01-01
  • SSH框架網(wǎng)上商城項(xiàng)目第19戰(zhàn)之訂單信息級聯(lián)入庫以及頁面緩存問題

    SSH框架網(wǎng)上商城項(xiàng)目第19戰(zhàn)之訂單信息級聯(lián)入庫以及頁面緩存問題

    這篇文章主要介紹了SSH框架網(wǎng)上商城項(xiàng)目第19戰(zhàn)之訂單信息級聯(lián)入庫以及頁面緩存問題,感興趣的小伙伴們可以參考一下
    2016-06-06
  • Spring Cache的基本使用與實(shí)現(xiàn)原理詳解

    Spring Cache的基本使用與實(shí)現(xiàn)原理詳解

    緩存是實(shí)際工作中非經(jīng)常常使用的一種提高性能的方法, 我們會在很多場景下來使用緩存。下面這篇文章主要給大家介紹了關(guān)于Spring Cache的基本使用與實(shí)現(xiàn)原理的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2018-05-05
  • Java基于socket實(shí)現(xiàn)的客戶端和服務(wù)端通信功能完整實(shí)例

    Java基于socket實(shí)現(xiàn)的客戶端和服務(wù)端通信功能完整實(shí)例

    這篇文章主要介紹了Java基于socket實(shí)現(xiàn)的客戶端和服務(wù)端通信功能,結(jié)合完整實(shí)例形式分析了Java使用socket建立客戶端與服務(wù)器端連接與通信功能,需要的朋友可以參考下
    2018-05-05
  • 如何使用java判斷是不是數(shù)字

    如何使用java判斷是不是數(shù)字

    這篇文章主要給大家介紹了關(guān)于如何使用java判斷是不是數(shù)字的相關(guān)資料,判斷一個字符串是否為數(shù)字是Java開發(fā)中很常見的業(yè)務(wù)需求,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-06-06
  • OPENCV+JAVA實(shí)現(xiàn)人臉識別

    OPENCV+JAVA實(shí)現(xiàn)人臉識別

    這篇文章主要為大家詳細(xì)介紹了OPENCV+JAVA實(shí)現(xiàn)人臉識別,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-02-02

最新評論