欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

微服務(wù)eureka和nacos案例詳解

 更新時(shí)間:2023年06月16日 09:14:19   作者:bubbleJessica  
這篇文章主要介紹了微服務(wù)eureka和nacos,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

服務(wù)遠(yuǎn)程調(diào)用

/**
     * 創(chuàng)建RestTemplate并注入Spring容器
     * @return
     */
    @Bean
    public RestTemplate restTemplate(){
        return new RestTemplate();
    }
@Autowired
    private RestTemplate restTemplate;
    public Order queryOrderById(Long orderId) {
        // 1.查詢(xún)訂單
        Order order = orderMapper.findById(orderId);
        // 2.利用RestTemplate發(fā)起HTTP請(qǐng)求,查詢(xún)用戶(hù)
        // 2.1.url路徑
        String url="http://localhost:8081/user/"+order.getUserId();
        // 2.2.發(fā)送HTTP請(qǐng)求,實(shí)現(xiàn)遠(yuǎn)程調(diào)用
        User user = restTemplate.getForObject(url, User.class);
        // 3.封裝user到order對(duì)象
        order.setUser(user);
        // 4.返回
        return order;
    }

搭建eureka服務(wù) 

第一步:注入依賴(lài) 

<dependency>
            <!--eureka服務(wù)端-->
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-server</artifact
</dependency>

第二步:使用@EnableEurekaServer 

@EnableEurekaServer
@SpringBootApplication
public class EurekaApplication {
    public static void main(String[] args) {
        SpringApplication.run(EurekaApplication.class,args);
    }
}

第三步:application.yml文件

server:
  port: 10086 # 服務(wù)端口
spring:
  application:
    name: eurekaserver # eureka的服務(wù)名稱(chēng)
eureka:
  client:
    service-url: # eureka的地址信息
      defaultZone: http://127.0.0.1:10086/eureka

解釋說(shuō)明: eureka-server自己也是個(gè)微服務(wù),也需要服務(wù)名稱(chēng),而且還需要配置eureka的地址(疑問(wèn):我自己就是eureka,為什么還要配置地址信息)剛才說(shuō)了eureka-server自己就是微服務(wù),所以eureka-server在啟動(dòng)的時(shí)候自己也注冊(cè)到eureka上(這是為了將來(lái)eureka集群之間通信去用的,比方說(shuō)我啟動(dòng)2個(gè)或3個(gè)eureka,將來(lái)3個(gè)eureka之間會(huì)互相做注冊(cè),那么這樣他們就可以做數(shù)據(jù)交流)上面defaultZone配置的是eureka集群的地址,有多個(gè)的話用逗號(hào)隔開(kāi),因?yàn)檫@里是單機(jī),所以配置的只有自己(重點(diǎn)來(lái)了:這里的服務(wù)名稱(chēng)和地址信息都是做服務(wù)的注冊(cè))

服務(wù)注冊(cè)

第一步:項(xiàng)目user-service引入依賴(lài)

<!--eureka客戶(hù)端依賴(lài)-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>

第二步:配置application.yml文件 

spring:
  application:
    name: userservice # eureka的服務(wù)名稱(chēng)
eureka:
  client:
    service-url: # eureka的地址信息
      defaultZone: http://127.0.0.1:10086/eureka

idea創(chuàng)建多個(gè)實(shí)例,可以在UserApplication右擊出現(xiàn)copy Configuration彈出窗口,環(huán)境配置端口點(diǎn)擊應(yīng)用就行了

服務(wù)發(fā)現(xiàn)(服務(wù)注冊(cè)基礎(chǔ)上添加額外2個(gè)步驟)

第一步:在RestTemplate上添加@LoadBalanced注解

/**
     * 創(chuàng)建RestTemplate并注入Spring容器
     * @return
     */
    @LoadBalanced
    @Bean
    public RestTemplate restTemplate(){
        return new RestTemplate();
    }

第二步:使用服務(wù)名稱(chēng)來(lái)代替原來(lái)的ip和端口

@Autowired
    private OrderMapper orderMapper;
    @Autowired
    private RestTemplate restTemplate;
    public Order queryOrderById(Long orderId) {
        // 1.查詢(xún)訂單
        Order order = orderMapper.findById(orderId);
        // 2.利用RestTemplate發(fā)起HTTP請(qǐng)求,查詢(xún)用戶(hù)
        // 2.1.url路徑
        // String url="http://localhost:8081/user/"+order.getUserId();
        String url="http://userservice/user/"+order.getUserId();
        // 2.2.發(fā)送HTTP請(qǐng)求,實(shí)現(xiàn)遠(yuǎn)程調(diào)用
        User user = restTemplate.getForObject(url, User.class);
        // 3.封裝user到order對(duì)象
        order.setUser(user);
        // 4.返回
        return order;
    }

負(fù)載均衡

一:代碼方式:在order-service中的OrderApplication類(lèi)中,定義一個(gè)新的IRule(全局生效) 

@Bean
    public IRule randomRule(){
        return new RandomRule();
    }

二:配置文件方式(局部生效)

userservice:
  ribbon:
    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule # 負(fù)載均衡規(guī)則

饑餓加載 

Ribbon默認(rèn)采用懶加載,即第一次訪問(wèn)時(shí)才會(huì)去創(chuàng)建LoadBalanceClient,請(qǐng)求時(shí)間會(huì)很長(zhǎng),而饑餓加載則會(huì)在項(xiàng)目啟動(dòng)時(shí)創(chuàng)建,降低第一次訪問(wèn)的耗時(shí),通過(guò)下面配置饑餓加載

ribbon:
  eager-load:
    enabled: true  # 開(kāi)啟饑餓加載
    clients:  # 指定饑餓加載的服務(wù)名稱(chēng) 這是一個(gè)集合
      - userservice

Nacos啟動(dòng)命令

-m參數(shù)含義是模式model standalone含義是單機(jī)啟動(dòng) 

startup.cmd -m standalone

服務(wù)注冊(cè)到Nacos

第一步:在cloud-demo父工程中添加spring-cloud-alibaba的管理依賴(lài)

<!--nacos的管理依賴(lài)-->
            <dependency>
                <groupId>com.alibaba.cloud</groupId>
                <artifactId>spring-cloud-alibaba-dependencies</artifactId>
                <version>2.2.5.RELEASE</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>

第二步:注釋掉order-service和user-service中pom.xml文件原有的eureka依賴(lài)

第三步:添加nacos的客戶(hù)端依賴(lài)

<!--nacos客戶(hù)端依賴(lài)包-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>

第四步:修改user-service和order-service中的application.yml文件,注釋eureka地址,添加nacos地址

spring:
  cloud:
    nacos:
      server-addr: localhost:8848 # nacos 服務(wù)端地址

第五步:?jiǎn)?dòng)OrderApplication、UserApplication1、UserApplication2并測(cè)試

nacos服務(wù)分級(jí)存儲(chǔ)模型

服務(wù)跨集群調(diào)用問(wèn)題

服務(wù)調(diào)用盡可能選擇本地集群的服務(wù),跨集群調(diào)用延遲較高,本地集群不可訪問(wèn)時(shí),再去訪問(wèn)其它集群

服務(wù)集群屬性

修改application.yml,添加以下內(nèi)容

spring:
  cloud:
    nacos:
    server-addr: localhost:8848 # nacos 服務(wù)端地址
    discovery:
      cluster-name: HZ # 配置集群名稱(chēng),也就是機(jī)房位置 HZ杭州 SH上海

一旦停掉本地集群的服務(wù),就會(huì)發(fā)生跨集群調(diào)用,出現(xiàn)警告信息,方便運(yùn)維人員知道

A cross-cluster call occurs,name = userservice, clusterName = HZ, instance = [Instance{instanceId='192.168.31.69#8083#SH#DEFAULT_GROUP@@userservice', ip='192.168.31.69', port=8083, weight=1.0, healthy=true, enabled=true, ephemeral=true, clusterName='SH', serviceName='DEFAULT_GROUP@@userservice', metadata={preserved.register.source=SPRING_CLOUD}}]

根據(jù)權(quán)重負(fù)載均衡

編輯修改權(quán)重

環(huán)境隔離

新建命名空間

新增成功會(huì)生成一個(gè)UUID,需要去idea配置application.yml

spring:
  cloud:
    nacos:
    server-addr: localhost:8848 # nacos 服務(wù)端地址
    discovery:
      cluster-name: HZ # 配置集群名稱(chēng),也就是機(jī)房位置 HZ杭州 SH上海
      namespace: a0c14ea6-b75e-4a73-beb5-94e5f496a744 # dev 開(kāi)發(fā)環(huán)境

到此這篇關(guān)于微服務(wù)eureka和nacos的文章就介紹到這了,更多相關(guān)微服務(wù)eureka內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • java實(shí)現(xiàn)馬踏棋盤(pán)的算法

    java實(shí)現(xiàn)馬踏棋盤(pán)的算法

    這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)馬踏棋盤(pán)的算法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • MyBatis Plus 入門(mén)使用詳細(xì)教程

    MyBatis Plus 入門(mén)使用詳細(xì)教程

    這篇文章主要介紹了MyBatis Plus 入門(mén)使用詳細(xì)教程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-08-08
  • MyBatis中的JdbcType映射使用介紹

    MyBatis中的JdbcType映射使用介紹

    這篇文章主要介紹了MyBatis中的JdbcType映射使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • springBoot集成flowable的流程解析

    springBoot集成flowable的流程解析

    這篇文章主要介紹了springBoot集成flowable的流程,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-02-02
  • java字符串轉(zhuǎn)JSON簡(jiǎn)單代碼示例

    java字符串轉(zhuǎn)JSON簡(jiǎn)單代碼示例

    這篇文章主要給大家介紹了關(guān)于java字符串轉(zhuǎn)JSON的相關(guān)資料,JSON?是一種輕量級(jí)的數(shù)據(jù)交換格式,常用于Web應(yīng)用程序中的數(shù)據(jù)傳輸,文中通過(guò)代碼示例介紹的非常詳細(xì),需要的朋友可以參考下
    2023-09-09
  • Object.wait()與Object.notify()的用法詳細(xì)解析

    Object.wait()與Object.notify()的用法詳細(xì)解析

    以下是對(duì)java中Object.wait()與Object.notify()的用法進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過(guò)來(lái)參考下
    2013-09-09
  • 詳解Java如何實(shí)現(xiàn)有效的并發(fā)處理

    詳解Java如何實(shí)現(xiàn)有效的并發(fā)處理

    隨著互聯(lián)網(wǎng)的蓬勃發(fā)展,現(xiàn)代軟件系統(tǒng)對(duì)于并發(fā)性能的要求越來(lái)越高,如何學(xué)習(xí)和掌握并發(fā)編程技術(shù)成為了Java開(kāi)發(fā)人員必備的技能之一,本文主要介紹了Java并發(fā)編程的相關(guān)概念、原理和實(shí)踐技巧,感興趣的可以了解下
    2023-11-11
  • gradle構(gòu)建工具和java不兼容錯(cuò)誤的解決方案

    gradle構(gòu)建工具和java不兼容錯(cuò)誤的解決方案

    這篇文章主要介紹了如何解決AS中Gradle和Java版本不兼容的問(wèn)題,主要解決方案包括升級(jí)Gradle版本或降級(jí)Java版本,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2025-02-02
  • 淺談Java泛型讓聲明方法返回子類(lèi)型的方法

    淺談Java泛型讓聲明方法返回子類(lèi)型的方法

    下面小編就為大家?guī)?lái)一篇淺談Java泛型讓聲明方法返回子類(lèi)型的方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-02-02
  • 使用Java實(shí)現(xiàn)簽字功能的示例代碼

    使用Java實(shí)現(xiàn)簽字功能的示例代碼

    這篇文章主要為大家詳細(xì)介紹了如何使用Java實(shí)現(xiàn)簽字功能,同時(shí)支持將簽字圖像保存為PNG格式和將簽字添加到PDF文檔中,感興趣的可以了解下
    2024-02-02

最新評(píng)論