SpringCloud第二篇:Ribbon(F版本)

上一篇文章,講了服務的註冊和發現。在微服務架構中,業務都會被拆分成一個獨立的服務,服務與服務的通訊是基於http restful的。Spring cloud有兩種服務調用方式,一種是ribbon+restTemplate,另一種是feign。在這一篇文章首先講解下基於ribbon+rest。
ribbon是一個負載均衡客戶端,可以很好的控制htt和tcp的一些行爲。
1.準備工作
繼上篇文章的項目,新建兩個服務,user9000,user9002,兩個服務都做負載均衡ribbon。
1.1 創建項目
和之前一樣,但是這裏選擇ribbon
在這裏插入圖片描述
1.2 “三板斧”
a.pom文件

<?xml version="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>com.jason</groupId>
        <artifactId>jason-cloud</artifactId>
        <version>1.0-SNAPSHOT</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.jason</groupId>
    <artifactId>consumer-user</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>consumer-user</name>
    <description>Spring Cloud Eureka 消費端 User</description>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jdbc</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>2.0.0</version>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.17</version>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

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

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
            <exclusions>
                <exclusion>
                    <groupId>org.junit.vintage</groupId>
                    <artifactId>junit-vintage-engine</artifactId>
                </exclusion>
            </exclusions>
        </dependency>

        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.6</version>
            <scope>provided</scope>
        </dependency>
    </dependencies>

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring-cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

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

</project>

b.配置

server.port=9000
#註冊到eureka服務端的微服務名稱
spring.application.name=consumer-user
#註冊到eureka服務端的地址
eureka.client.service-url.defaultZone=http://localhost:8761/eureka/
#eureka.client.service-url.defaultZone: http://www.eureka9000.com:9000/eureka/
#點擊具體的微服務,右下角是否顯示ip
eureka.instance.prefer-ip-address=true
#顯示微服務的名稱
eureka.instance.instance-id=consumer-user-9000

mybatis.configuration.map-underscore-to-camel-case=true
#配置數據庫
spring.datasource.url=jdbc:mysql://localhost:3306/jason-cloud?serverTimezone=GMT&useUnicode=true&characterEncoding=utf-8
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.username=root
spring.datasource.password=admin
logging.level.com.jason.consumeruser.dao=debug

另外一個一樣,修改端口和服務名稱

server.port=9002
#註冊到eureka服務端的微服務名稱
spring.application.name=consumer-user
#註冊到eureka服務端的地址
eureka.client.service-url.defaultZone=http://localhost:8761/eureka/
#eureka.client.service-url.defaultZone: http://www.eureka9000.com:9000/eureka/
#點擊具體的微服務,右下角是否顯示ip
eureka.instance.prefer-ip-address=true
#顯示微服務的名稱
eureka.instance.instance-id=consumer-user-9002

mybatis.configuration.map-underscore-to-camel-case=true
#配置數據庫
spring.datasource.url=jdbc:mysql://localhost:3306/jason-cloud?serverTimezone=GMT&useUnicode=true&characterEncoding=utf-8
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.username=root
spring.datasource.password=admin
logging.level.com.jason.consumeruser.dao=debug

c.貼註解
在這裏插入圖片描述
項目結構:
在這裏插入圖片描述
2.創建配置類,向程序的ioc注入一個bean: restTemplate;並通過@LoadBalanced註解表明這個restRemplate開啓負載均衡的功能。
在這裏插入圖片描述
2.1 寫接口,通過之前注入ioc容器的restTemplate來消費CONSUMER-USER服務的“/user/log-user-instance”接口,在這裏我們直接用的程序名替代了具體的url地址,在ribbon中它會根據服務名來選擇具體的服務實例,根據服務實例在請求的時候會用具體的url替換掉服務名,代碼如下:
在這裏插入圖片描述

@GetMapping("/log-user-instance")
    public String logUserInstance() {
        ServiceInstance serviceInstance = loadBalancerClient.choose("CONSUMER-USER");
        log.info("serviceId------------>:{},ip:{},port:{}",serviceInstance.getServiceId(),serviceInstance.getHost(),serviceInstance.getPort());
        return serviceInstance.getServiceId()+serviceInstance.getHost()+serviceInstance.getPort();
    }

3.啓動服務
在這裏插入圖片描述
3.1 訪問接口,/user/log-user-instance,ribbon負載均衡默認輪詢策略。下面發現多次訪問返回值的ip是9000,9002輪流來。
在這裏插入圖片描述
在這裏插入圖片描述
4.此時的結構
在這裏插入圖片描述
一個服務註冊中心,eureka server,端口爲8761
CONSUMER-USER 工程跑了兩個實例,端口分別爲9000,9002,分別向服務註冊中心註冊
當通過restTemplate調用 CONSUMER-USER 的/user/log-user-instance接口時,因爲用ribbon進行了負載均衡,會輪流的調用CONSUMER-USER:9000和9002 兩個端口的/user/log-user-instance接口;

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章