• <noscript id="e0iig"><kbd id="e0iig"></kbd></noscript>
  • <td id="e0iig"></td>
  • <option id="e0iig"></option>
  • <noscript id="e0iig"><source id="e0iig"></source></noscript>
  • SpringCloud學習筆記

    標簽: springCoud  java  spring  

    介紹
    Spring Cloud是一系列技術的有序整合。它利用Spring Boot的開發便利性巧妙地簡化了分布式系統基礎設施的開發。
    Spring Boot擅長的是集成,把世界上最好的框架集成到自己項目中,Spring Cloud也是一樣,把非常流行的微服務的技術整合到一起。
    Spring Cloud從架構層面上降低了對大型系統構建的要求和難度,使我們以非常低的成本(技術或者硬件)搭建一套高效、分布式、容錯的平臺,但Spring Cloud也不是沒有缺點,小型獨立的項目不適合使用。

    基礎架構圖

    在這里插入圖片描述

    SpringCloud與SpringBoot版本匹配關系

    SpringBoot SpringCloud
    1.2.x Angel版本
    1.3.x Brixton版本
    1.4.x Camden版本
    1.5.x Dalston版本、Edgware
    2.0.x Finchley版本
    2.1.x Greenwich GA版本 (2019年2月發布)

    注冊中心 Spring Cloud Eureka

    簡介:

    Eureka解決了第一個問題:服務的管理,注冊和發現、狀態監管、動態路由。
    Eureka負責管理記錄服務提供者的信息。服務調用者無需自己尋找服務,Eureka自動匹配服務給調用
    者。
    Eureka與服務之間通過 心跳 機制進行監控;

    原理圖

    在這里插入圖片描述

    整合注冊中心Eureka

    1.創建eureka_server的springboot工程。
    2.勾選坐標

    • Spring Boot DevTools (熱部署插件)
    • Eureka Server (Eureka服務端)
    1. 在啟動類EurekaServerApplication聲明當前應用為Eureka服務使用 @EnableEurekaServer 注解
    2. 編寫配置文件application.yml
    # 端口
    server:
      #  從jvm中拿值,如果沒有使用默認配置8001(在VM options中配 -Dport=10086)
      port: ${port:10086}
    spring:
      application:
        name: eureka-server # 應用名稱,會在Eureka中作為服務的id標識(serviceId)
    # 服務注冊中心
    eureka:
      client:
        service-url: # EurekaServer的地址,現在是自己的地址,如果是集群,需要寫其它Server的地址。
          defaultZone: http://127.0.0.1:10086/eureka
        # 是否抓取注冊列表
        fetch-registry: false
        # 是否注冊服務中心Eureka
        register-with-eureka: false
    

    5.啟動EurekaServerApplication
    6.測試訪問地址http://127.0.0.1:10086,如下信息代表訪問成功
    在這里插入圖片描述

    服務提供者-注冊服務中心

    1.在服務提供者user_service工程中添加Eureka(客戶端)依賴

    <!--eureka客戶端starter-->
    <dependencies>
    	<dependency>
    		<groupId>org.springframework.cloud</groupId>
    		<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
    	</dependency>
    </dependencies>
    <!--SpringCloud所有依賴管理的坐標-->
    <dependencyManagement>
    	<dependencies>
    		<dependency>
    			<groupId>org.springframework.cloud</groupId>
    			<artifactId>spring-cloud-dependencies</artifactId>
    			<version>Greenwich.SR1</version>
    			<type>pom</type>
    			<scope>import</scope>
    		</dependency>
    	</dependencies>
    </dependencyManagement>
    

    2.在啟動類上開啟Eureka客戶端發現功能 @EnableDiscoveryClient
    3.修改配置文件:spring.application.name指定應用名稱,作為服務ID使用

    server:
      #  從jvm中拿值,如果沒有使用默認配置8001(在VM options中配 -Dport=8001)
      port: ${port:8001}
    spring:
      application:
        name: provider-service  # 應用名稱,會在Eureka中作為服務的id標識
      #  數據源配置
      datasource:
        driver-class-name: com.mysql.cj.jdbc.Driver
        username: root
        password: root
        url: jdbc:mysql://127.0.0.1/springcloud?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC
    # mybatis配置
    mybatis:
      #  掃描接口對應的XML映射文件
      mapper-locations: classpath:mapper/*.xml
      #  起別名
      type-aliases-package: top.zhenghy123.pojo
    # 配置eureka
    eureka:
      client:
        service-url:
          defaultZone: http://127.0.0.1:10086/eureka
    
    
    
    

    4.客戶端代碼會自動把服務注冊到EurekaServer中
    5.在Eureka監控頁面可以看到服務注冊成功信息

    服務消費者-注冊服務中心

    1.在服務消費者spring_cloud_itcast_consumer_service工程中添加Eureka(客戶端)依賴

    <!-- Eureka客戶端 -->
    <dependency>
    	<groupId>org.springframework.cloud</groupId>
    	<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
    </dependency>
    <!--SpringCloud所有依賴管理的坐標-->
    <dependencyManagement>
    	<dependencies>
    		<dependency>
    			<groupId>org.springframework.cloud</groupId>
    			<artifactId>spring-cloud-dependencies</artifactId>
    			<version>Greenwich.SR1</version>
    			<type>pom</type>
    			<scope>import</scope>
    		</dependency>
    	</dependencies>
    </dependencyManagement>
    

    2.在啟動類開啟Eureka客戶端 @EnableDiscoveryClient
    3.修改配置文件:加入EurekaServer地址

    server:
      #  從jvm中拿值,如果沒有使用默認配置8001(在VM options中配 -Dport=9002)
      port: ${port:9002}
    spring:
      application:
        name: provider-service  # 應用名稱,會在Eureka中作為服務的id標識
    # 配置eureka
    eureka:
      client:
        service-url:
          defaultZone: http://127.0.0.1:10086/eureka
    # 修改服務地址輪詢策略,默認是輪詢,配置之后變隨機
    # 配置訪問(PROVIDER-SERVICE)服務的負債均衡策略
    # RandomRule隨機策略
    # RoundRobinRule輪詢策略
    PROVIDER-SERVICE:
      ribbon:
        NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule
    feign:
      hystrix:
        # 開啟feign熔斷器的支持
        enabled: true
      compression:
        # 請求壓縮
        request:
          enabled: true
          # 起步壓縮大小
          min-request-size: 1024
          # 請求壓縮的數據類型
          mime-types: text/xml,application/xml,josn
        # 響應壓縮
        response:
          enabled: true
    

    4.啟動服務,在服務中心查看是否注冊成功

    消費者通過Eureka訪問提供者

    什么是Feign:

    Feign是一個聲明式的偽Http客戶端,它使得寫Http客戶端變得更簡單。使用Feign,只需要創建一個接口并注解。它具有可插拔的注解特性,可使用Feign 注解和JAX-RS注解。Feign支持可插拔的編碼器和解碼器。Feign默認集成了Ribbon并和Eureka結合默認實現了負載均衡的效果
    簡而言之:

    • Feign 采用的是基于接口的注解
    • Feign 整合了ribbon

    1.添加Feign依賴

            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-openfeign</artifactId>
            </dependency>
    

    2.在啟動類上加入@EnableFeignClients注解開啟Feign的功能
    3.定義一個UserService接口,通過@ FeignClient(value=“服務名”,fallback = 指定熔斷降級處理類),來指定調用哪個服務。比如在代碼中調用了provider-service服務的“/user/findAll”接口

    @ FeignClient的fallback屬性:fallback指定熔斷降級處理類
    編寫一個類實現此接口在類上加@Component注解即可(下方Feign使用Hystrix實現降級有介紹)

    代碼如下:

    @FeignClient(value = "PROVIDER-SERVICE", fallback = UserServiceImpl.class)
    //value為目標服務的ID,fallback指定熔斷降級處理類 編寫一個類實現此接口在類上加@Component注解即可(下方**Feign使用Hystrix實現降級**有介紹)
    public interface UserService {
        @RequestMapping("/user/findAll")
        List<User> findAll();
    }
    

    4.在controller層,注入UserService來消費服務

    @RestController
    @RequestMapping("test")
    public class UserController {
        @Autowired
        private RestTemplate restTemplate;
    
        @Autowired
        private UserService userService;
    
        @RequestMapping("findAll")
        public String findAll() {
            return restTemplate.getForObject("http://PROVIDER-SERVICE/user/findAll", String.class);
        }
    
        @RequestMapping("test")
        public List test(){
            return userService.findAll();
        }
    }
    

    Feign使用Hystrix實現降級

    服務雪崩

    在這里插入圖片描述如圖-1,如果所有服務A/B/C網絡/應用等都正常,同時能夠快速的處理請求并返回,服務之間就可以正常的調度。

    在這里插入圖片描述
    如圖-2,如果A服務出現異常情況(網絡異常/內部數據庫異常等)無法在指定的時間內返回B服務結果,那么由于C服務會持續的請求B服務,最終導致B服務積壓了大量的請求而服務器奔潰不可用。

    在這里插入圖片描述
    如圖-3,B服務由于A服務的不可用導致自身請求積壓而崩潰,所以所有的請求蔓延到下游的C服務,最終也導致C服務不可用崩潰,如圖-4所示。

    在這里插入圖片描述
    綜上所述:服務雪崩就是由于上游(例如A)的服務異常不可用,最終蔓延到下游的所有服務,導致所有相關下游的微服務應用不可用而系統崩潰。

    Hystrix簡介

    Hystrix是由Netfix開源的一個延遲和容錯工具庫,用于解決遠程調用/服務或者第三方庫防止級聯失敗提示系統的可用性和容錯性。
    1.Maven依賴

    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
    </dependency>
    

    2.修改配置文件

    feign:
      hystrix:
        # 開啟feign熔斷器的支持
        enabled: true
      compression:
        # 請求壓縮
        request:
          enabled: true
          # 起步壓縮大小
          min-request-size: 1024
          # 請求壓縮的數據類型
          mime-types: text/xml,application/xml,josn
        # 響應壓縮
        response:
          enabled: true
    

    3.添加降級類
    Feign服務熔斷降級其實是通過調度超時就調用本地的方法,而不是一直等待服務返回。Feign調度服務是通過接口+注解方式的,我們需要實現該接口用于實現服務降級調用本地方法。

    @Component
    public class UserServiceImpl implements UserService {
        @Override
        public List findAll() {
            ArrayList<String> list = new ArrayList<>();
            list.add("服務器異常");
            return list;
        }
    }
    
    

    Feign接口類

    主要是通過@FeignClient的fallback屬性定義降級后調用那個類的方法,這里方法名稱等都是一致才可以。
    
    @FeignClient(value = "PROVIDER-SERVICE", fallback = UserServiceImpl.class)
    public interface UserService {
        @RequestMapping("/user/findAll")
        List<User> findAll();
    }
    

    負載均衡 Spring Cloud Ribbon

    Ribbon 簡介

    解決了集群服務中,多個服務高效率訪問的問題。

    什么是Ribbon?

    Ribbon是Netflix發布的負載均衡器,有助于控制HTTP客戶端行為。為Ribbon配置服務提供者地址列表
    后,Ribbon就可基于負載均衡算法,自動幫助服務消費者請求。
    Ribbon默認提供的負載均衡算法:輪詢,隨機其他…。當然,我們可用自己定義負載均衡算法
    在這里插入圖片描述

    實現負載均衡訪問用戶服務。
    如果想要做負載均衡,我們的服務至少2個以上。所有第一步目標
    步驟:

    1. 啟動多個user_service服務
      修改UserServiceApplication的application.yml配置文件
    server:
      #  從jvm中拿值,如果沒有使用默認配置8001(在VM options中配 -Dport=8001)
      port: ${port:8001}
    
    1. 編輯應用啟動配置
      在這里插入圖片描述

    2. 復制一份UserServiceApplication
      在這里插入圖片描述

    3. 啟動多個Application應用

    4. Eureka服務中心可查看,注冊成功.

    開啟消費者調用負載均衡

    Feign和Eureka都默認集成了Ribbon,所以無需引入依賴。
    注:這里使用的是Feign默認實現了負載均衡的效果

    • 直接在配置文件中配置即可
    # 修改服務地址輪詢策略,默認是輪詢,配置之后變隨機
    # 配置訪問(PROVIDER-SERVICE)服務的負債均衡策略
    # RandomRule隨機策略
    # RoundRobinRule輪詢策略
    PROVIDER-SERVICE: #對應的服務ID
      ribbon:
        NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule
    
    版權聲明:本文為weixin_45638744原創文章,遵循 CC 4.0 BY-SA 版權協議,轉載請附上原文出處鏈接和本聲明。
    本文鏈接:https://blog.csdn.net/weixin_45638744/article/details/108474605

    智能推薦

    SpringCloud學習筆記

    SpringCloud學習筆記   ESB企業服務總線:用來連接各個服務節點,為了集成各種不同的服務。 1.系統架構演變 目標:   了解項目架構的演變歷程。 小結: 集中式架構 垂直拆分 分布式架構 SOA面向服務架構 微服務架構 2.微服務架構說明 目標:   了解SOA與微服務架構的區別以及說出微服務架構的特點。 分析: &emsp...

    SpringCloud學習筆記-Eureka

    注冊中心-Eureka Spring Cloud 封裝了 Netflix 公司開發的 Eureka 模塊來實現服務注冊和發現。Eureka 采用了 C-S 的設計架構。Eureka Server 作為服務注冊功能的服務器,它是服務注冊中心。而系統中的其他微服務,使用 Eureka 的客戶端連接到 Eureka Server,并維持心跳連接。這樣系統的維護人員就可以通過 Eureka Server ...

    SpringCloud學習筆記------Feign

      feign有假裝的意思   為什么要叫假裝? Feign可以把Rest的請求進行隱藏,偽裝成類似SpringMVC的Controller一樣。你不用再自己拼接url,拼接參數等等操作,一切都交給Feign去做。   快速入門 先用起來,我們在使用的時候揭開它神秘的面紗吧 導入依賴 pom.xml 引入: Feign的客戶端 寫一個Controller dao層 啟...

    SpringCloud學習筆記

    介紹 Spring Cloud是一系列技術的有序整合。它利用Spring Boot的開發便利性巧妙地簡化了分布式系統基礎設施的開發。 Spring Boot擅長的是集成,把世界上最好的框架集成到自己項目中,Spring Cloud也是一樣,把非常流行的微服務的技術整合到一起。 Spring Cloud從架構層面上降低了對大型系統構建的要求和難度,使我們以非常低的成本(技術或者硬件)搭建一套高效、分...

    SpringCloud 學習筆記

    SpringCloud 學習筆記 文章目錄 SpringCloud 學習筆記 1 簡介 1.1 什么是 SpringCloud 1.2 SpringCloud 能干什么 2. 微服務 2.1 什么是微服務 2.2 微服務與微服務架構 2.3 微服務架構的四個核心問題 2.4 微服務優缺點 2.5 微服務技術棧有哪些? 2.6 為什么選擇 SpringCloud 作為微服務架構 1. 選型依據 2....

    猜你喜歡

    SpringCloud - Nacos學習筆記

    Nacos學習筆記 nacos簡介 Nacos使用 Nacos Server安裝 Nacos啟動 Nacos關閉 單機模式支持mysql 集群部署 配置管理 客戶端使用方式 動態刷新 命名空間與分組 命名空間 分組 自定義擴展的 Data Id 配置 服務注冊發現 nacos簡介 Nacos 支持幾乎所有主流類型的“服務”的發現、配置和管理: Spring Cloud Du...

    SpringCloud Gateway學習筆記

    SpringCloud Gateway是Spring cloud的一個全新項目,是基于Spring5.0、Spring Boot 2.0和project Reactor等技術開發的網關,它旨在為微服務架構提供一個簡單有效的統一的API路由管理方式。 SrpingCloud Gateway作為spring cloud生態系統的網關,目標是替代Zuul,為了提升網關的性能,SpringCloud Ga...

    springcloud 學習筆記

    1. Eureka 注冊中心 Spring cloud 封裝了Netflix開發的Eureka來實現服務的注冊和發現 1.引入依賴 2.書寫配置文件 3.書寫啟動類 Eureka 注冊中心需要在啟動類上添加@@EnableEurekaServer 在服務提供者和消費者的啟動類上添加@EnableEurekaClient 同時在配置文件中添加上相關配置 4. 服務提供者和消費者配置 添加相關的mav...

    HTML中常用操作關于:頁面跳轉,空格

    1.頁面跳轉 2.空格的代替符...

    freemarker + ItextRender 根據模板生成PDF文件

    1. 制作模板 2. 獲取模板,并將所獲取的數據加載生成html文件 2. 生成PDF文件 其中由兩個地方需要注意,都是關于獲取文件路徑的問題,由于項目部署的時候是打包成jar包形式,所以在開發過程中時直接安照傳統的獲取方法沒有一點文件,但是當打包后部署,總是出錯。于是參考網上文章,先將文件讀出來到項目的臨時目錄下,然后再按正常方式加載該臨時文件; 還有一個問題至今沒有解決,就是關于生成PDF文件...

    精品国产乱码久久久久久蜜桃不卡