SpringBootNacos——微服務治理的好幫手

一、服務註冊和發現

服務註冊和發現是微服務架構中比較重要的一環,而SpringBootNacos提供了強大的服務註冊和發現功能,讓我們的微服務架構更加健壯。關於Nacos的安裝和配置,這裡就不詳細闡述了,下面直接從使用SpringBootNacos註冊服務開始說明。

首先配置pom.xml文件,添加以下依賴(同時需要保證SpringBoot的版本不低於2.0.4):


    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        <version>2.2.5.RELEASE</version>
    </dependency>

接着在application.yml中配置註冊中心的地址:


spring:
  application:
    name: service-provider  #服務名稱
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848  #Nacos服務端地址

然後在啟動類上添加註解@EnableDiscoveryClient即可實現服務的註冊和發現。

二、動態配置管理

SpringBootNacos還提供了強大的動態配置管理功能,可以輕鬆實現配置的熱更新、多環境配置等功能。下面我將從實際應用的角度來介紹。

我們可以在配置Nacos上配置多個配置集和多個配置文件。例如:


data-id: example
group: test
refreshable-dataid: true
data-type: json
content:
  server:
    port: 8080
    context-path: /api
    #讀取其他配置文件
    bootstrap:
      #指定環境
      profiles:
        active: dev
      cloud:
        #指定從Nacos讀取配置文件
        nacos:
          config:
            server-addr: localhost:8848
            file-extension: yaml #讀取解析yaml格式文件
            group: test
            prefix: service-pro #配置文件的前綴
            refreshable: true

可以看到我們使用的是yaml格式的配置文件,SpringBootNacos也支持其他常見的配置格式(properties、json等)。其中,bootstrap.yml用來設置環境變量,因為SpringBoot默認會讀取配置文件中的application.yml,而bootstrap.yml比它的優先級更高。

配置好這些文件後,我們就可以在業務代碼中直接使用@Value去讀取配置文件中的值,如下所示:


@Configuration
public class AppConfig {
    @Value("${server.port}")
    private int port;   //讀取端口號

    @Bean
    public RestHighLevelClient restHighLevelClient(){
        return new RestHighLevelClient(
                RestClient.builder(
                        new HttpHost(host, port, "http")));
    }
}

配置的變動會自動觸發SpringBoot的刷新機制,幾乎不需要進行額外的配置和代碼編寫。

三、分布式事務管理

SpringBootNacos提供了完整的分布式事務管理解決方案。本節介紹如何使用TXC透明分布式事務來實現跨數據庫事務。

在pom.xml中引入相應的依賴:


<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-alibaba-seata-all</artifactId>
    <version>2.2.1.RELEASE</version>
    <exclusions>
        <exclusion>
            <groupId>io.seata</groupId>
            <artifactId>seata-all</artifactId>
        </exclusion>
    </exclusions>
</dependency>
<dependency>
    <groupId>io.seata</groupId>
    <artifactId>seata-all</artifactId>
    <version>1.4.2</version>
</dependency>

然後需要在application.yml中添加seata的配置:


spring:
  application:
    name: txc-service
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848
    alibaba:
      seata:
        tx-service-group: my_test_tx_group  #開啟分布式事務
    config:
        enabled: true
        type: nacos
        nacos:
          server-addr: localhost:8848
          group: DEFAULT_GROUP                         #對應配置文件中的GROUP
          namespace: 4ba55e16-16df-4bd7-a436-075a2bde0c32 #對應命名空間ID
        label: master

在業務代碼上通過添加@GlobalTransactional註解來實現分布式事務,其中TXC是Seata中專為分庫分表場景設計的事務管理模式,可以在較低的性能損耗下完成一致性事務操作。


@Service
@Slf4j
public class TxcDemoServiceImpl implements ITxcDemoService {

    @Autowired
    private TxcMapper txcMapper;

    @GlobalTransactional
    public void insertUser(UserDO user) {
        txcMapper.insertUser(user);
        // insert other tables...
    }

    @GlobalTransactional
    public void deleteAll() {
        txcMapper.deleteAll();
        // delete other tables...
    }
}

結語

本文介紹了SpringBootNacos的三個重要功能:服務註冊和發現、動態配置管理、分布式事務管理。不得不說,SpringBootNacos為微服務架構的實現提供了非常便捷的幫助,極大地降低了開發的難度和維護的成本。希望本文對大家了解SpringBootNacos有所幫助。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/310107.html

相關推薦

  • JS Proxy(array)用法介紹

    JS Proxy(array)可以說是ES6中非常重要的一個特性,它可以代理一個數組,監聽數據變化並進行攔截、處理。在實際開發中,使用Proxy(array)可以方便地實現數據的監…

    編程 2025-04-29
  • at least one option must be selected

    問題解答:當我們需要用戶在一系列選項中選擇至少一項時,我們需要對用戶進行限制,即“at least one option must be selected”(至少選擇一項)。 一、…

    編程 2025-04-29
  • Python官網中文版:解決你的編程問題

    Python是一種高級編程語言,它可以用於Web開發、科學計算、人工智能等領域。Python官網中文版提供了全面的資源和教程,可以幫助你入門學習和進一步提高編程技能。 一、Pyth…

    編程 2025-04-29
  • Python計算陽曆日期對應周幾

    本文介紹如何通過Python計算任意陽曆日期對應周幾。 一、獲取日期 獲取日期可以通過Python內置的模塊datetime實現,示例代碼如下: from datetime imp…

    編程 2025-04-29
  • 銀行資金管理系統總結

    銀行資金管理系統是銀行日常業務運營的核心支撐系統,主要負責處理銀行的資金流動、結算、清算等業務。本文將從功能特點、技術架構、安全性以及未來發展趨勢等多個方面對銀行資金管理系統進行詳…

    編程 2025-04-29
  • 如何查看Anaconda中Python路徑

    對Anaconda中Python路徑即conda環境的查看進行詳細的闡述。 一、使用命令行查看 1、在Windows系統中,可以使用命令提示符(cmd)或者Anaconda Pro…

    編程 2025-04-29
  • 如何修改mysql的端口號

    本文將介紹如何修改mysql的端口號,方便開發者根據實際需求配置對應端口號。 一、為什麼需要修改mysql端口號 默認情況下,mysql使用的端口號是3306。在某些情況下,我們需…

    編程 2025-04-29
  • 英語年齡用連字符號(Hyphenation for English Age)

    英語年齡通常使用連字符號表示,比如 “five-year-old boy”。本文將從多個方面探討英語年齡的連字符使用問題。 一、英語年齡的表達方式 英語中表…

    編程 2025-04-29
  • Idea新建文件夾沒有java class的解決方法

    如果你在Idea中新建了一個文件夾,卻沒有Java Class,應該如何解決呢?下面從多個方面來進行解答。 一、檢查Idea設置 首先,我們應該檢查Idea的設置是否正確。打開Id…

    編程 2025-04-29
  • 金額選擇性序列化

    本文將從多個方面對金額選擇性序列化進行詳細闡述,包括其定義、使用場景、實現方法等。 一、定義 金額選擇性序列化指根據傳入的金額值,選擇是否進行序列化,以達到減少數據傳輸的目的。在實…

    編程 2025-04-29