springboot+dubbo+zookeeper實現一個遠程的買票服務(小案例)

首先在寫案例之前我們先要知道什麼是dubbo?
Apache Dubbo是一款高性能、輕量級的開源Java RPC框架,它提供了三大核心能力:面向接口的遠程方法調用,智能容錯和負載均衡,以及服務自動註冊和發現。(這是阿里巴巴的開源項目,之後到了apache下)
img服務提供者(Provider):暴露服務的服務提供方,服務提供者在啓動時,向註冊中心註冊自己提供的服務。

服務消費者(Consumer):調用遠程服務的服務消費方,服務消費者在啓動時,向註冊中心訂閱自己所需的服務,服務消費者,從提供者地址列表中,基於軟負載均衡算法,選一臺提供者進行調用,如果調用失敗,再選另一臺調用。

註冊中心(Registry):註冊中心返回服務提供者地址列表給消費者,如果有變更,註冊中心將基於長連接推送變更數據給消費者

監控中心(Monitor):服務消費者和提供者,在內存中累計調用次數和調用時間,定時每分鐘發送一次統計數據到監控中心

調用關係說明

l 服務容器負責啓動,加載,運行服務提供者。

l 服務提供者在啓動時,向註冊中心註冊自己提供的服務。

l 服務消費者在啓動時,向註冊中心訂閱自己所需的服務。

l 註冊中心返回服務提供者地址列表給消費者,如果有變更,註冊中心將基於長連接推送變更數據給消費者。

l 服務消費者,從提供者地址列表中,基於軟負載均衡算法,選一臺提供者進行調用,如果調用失敗,再選另一臺調用。

l 服務消費者和提供者,在內存中累計調用次數和調用時間,定時每分鐘發送一次統計數據到監控中心。
RPC框架:簡單來說就是6個字:遠程過程調用.
.關於dubbo的安裝和zookeeper的使用這裏不做詳解.
進入正題:
首先我們先啓動zookeeper的服務端和客戶端
在這裏插入圖片描述zk服務端
在這裏插入圖片描述zk客戶端
在這裏插入圖片描述執行 dubbo-admin\target 下的dubbo-admin-0.0.1-SNAPSHOT.jar

java -jar dubbo-admin-0.0.1-SNAPSHOT.jar

【注意:zookeeper的服務一定要打開!】
在這裏插入圖片描述然後我們可以進入dubbo後臺查看
網址:localhost:7001
在這裏插入圖片描述在這裏插入圖片描述在這裏,我們可以查看到服務提供者的狀態.

這個時候我們開始寫代碼:
首先就是寫服務提供者.
1、將服務提供者註冊到註冊中心,我們需要整合Dubbo和zookeeper,所以需要導包

我們從dubbo官網進入github,看下方的幫助文檔,找到dubbo-springboot,找到依賴包

<!-- Dubbo Spring Boot Starter -->
<dependency>
   <groupId>org.apache.dubbo</groupId>
   <artifactId>dubbo-spring-boot-starter</artifactId>
   <version>2.7.3</version>
</dependency>   

zookeeper的包我們去maven倉庫下載,zkclient;

<!-- https://mvnrepository.com/artifact/com.github.sgroschupf/zkclient -->
<dependency>
   <groupId>com.github.sgroschupf</groupId>
   <artifactId>zkclient</artifactId>
   <version>0.1</version>
</dependency>

【新版的坑】zookeeper及其依賴包,解決日誌衝突,還需要剔除日誌依賴;

<!-- 引入zookeeper -->
<dependency>
   <groupId>org.apache.curator</groupId>
   <artifactId>curator-framework</artifactId>
   <version>2.12.0</version>
</dependency>
<dependency>
   <groupId>org.apache.curator</groupId>
   <artifactId>curator-recipes</artifactId>
   <version>2.12.0</version>
</dependency>
<dependency>
   <groupId>org.apache.zookeeper</groupId>
   <artifactId>zookeeper</artifactId>
   <version>3.4.14</version>
   <!--排除這個slf4j-log4j12-->
   <exclusions>
       <exclusion>
           <groupId>org.slf4j</groupId>
           <artifactId>slf4j-log4j12</artifactId>
       </exclusion>
   </exclusions>
</dependency>

2、在springboot配置文件中配置dubbo相關屬性!

server.port=8002
#服務應用名字
dubbo.application.name=provider-server
#註冊中心地址
dubbo.registry.address=zookeeper://127.0.0.1:2181
#哪些服務要被註冊
dubbo.scan.base-packages=com.qiu.service

編寫接口:

package com.qiu.service;

public interface TicketService {
    public String getTicket();
}

3、在service的實現類中配置服務註解,發佈服務!注意導包問題

package com.qiu.service;

import org.apache.dubbo.config.annotation.Service;
import org.springframework.context.annotation.Configuration;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;

//zookeeper 服務註冊與發現
@Service //可以被掃描到,在項目啓動就自動註冊到註冊中心
@Component  //使用了Dubbo後儘量不要使用Service註解
public class TicketServiceImpl implements TicketService{
    @Override
    public String getTicket() {
        return "qiuzhikang真帥";
    }
}

邏輯理解 :應用啓動起來,dubbo就會掃描指定的包下帶有@component註解的服務,將它發佈在指定的註冊中心中!
以上代碼是屬於服務提供者
在這裏插入圖片描述編寫完之後我們啓動這個項目.
接着編寫服務消費者:
1、導入依賴,和之前的依賴一樣;

<?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>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.3.0.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.qiu</groupId>
    <artifactId>consumer-server</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>consumer-server</name>
    <description>Demo project for Spring Boot</description>

    <properties>
        <java.version>1.8</java.version>
    </properties>

    <dependencies>
        <!--        導入依賴zookeeper和dubbo-->
        <dependency>
            <groupId>org.apache.dubbo</groupId>
            <artifactId>dubbo-spring-boot-starter</artifactId>
            <version>2.7.6</version>
        </dependency>
        <!--        zkClient-->
        <dependency>
            <groupId>com.github.sgroschupf</groupId>
            <artifactId>zkclient</artifactId>
            <version>0.1</version>
        </dependency>
        <!--        日誌會衝突-->
        <!-- 引入zookeeper -->
        <dependency>
            <groupId>org.apache.curator</groupId>
            <artifactId>curator-framework</artifactId>
            <version>2.12.0</version>
        </dependency>
        <dependency>
            <groupId>org.apache.curator</groupId>
            <artifactId>curator-recipes</artifactId>
            <version>2.12.0</version>
        </dependency>
        <dependency>
            <groupId>org.apache.zookeeper</groupId>
            <artifactId>zookeeper</artifactId>
            <version>3.4.14</version>
            <!--排除這個slf4j-log4j12-->
            <exclusions>
                <exclusion>
                    <groupId>org.slf4j</groupId>
                    <artifactId>slf4j-log4j12</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</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>
    </dependencies>

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

</project>

2、配置參數

server.port=8001
# 消費者去哪裏拿服務,需要暴露自己的名字
dubbo.application.name=consumer-server
#註冊中心的地址
dubbo.registry.address=zookeeper://127.0.0.1:2181

3. 本來正常步驟是需要將服務提供者的接口打包,然後用pom文件導入,我們這裏使用簡單的方式,直接將服務的接口拿過來,路徑必須保證正確,即和服務提供者相同;
在這裏插入圖片描述4. 完善消費者的服務類

package com.qiu.service;

import org.apache.dubbo.config.annotation.Reference;
import org.springframework.stereotype.Service;

@Service
public class UserService {
    // 想拿到provider提供的票,要去註冊中心拿到我們的服務
    @Reference //引用,正常開發時用pom座標.可以定義路徑相同的接口名
    TicketService ticketService;

    public void buyTicket(){
        String ticket = ticketService.getTicket();
        System.out.println("在註冊中心拿到了=>"+ticket);
    }

}

5. 測試類編寫;

package com.qiu;

        import com.qiu.service.UserService;
        import org.junit.jupiter.api.Test;
        import org.springframework.beans.factory.annotation.Autowired;
        import org.springframework.boot.test.context.SpringBootTest;

@SpringBootTest
class ConsumerServerApplicationTests {
    @Autowired
    UserService userService;
    @Test
    void contextLoads() {
        userService.buyTicket();
    }

}

啓動測試
在這裏插入圖片描述在這裏插入圖片描述在這裏插入圖片描述ok , 這就是SpingBoot + dubbo + zookeeper實現分佈式開發的應用,其實就是一個服務拆分的思想;
兩個module的結構圖如下:
在這裏插入圖片描述

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