溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

springboot+dubbo+zookeeper的示例分析

發(fā)布時(shí)間:2021-10-27 16:15:41 來(lái)源:億速云 閱讀:199 作者:小新 欄目:開(kāi)發(fā)技術(shù)

這篇文章主要介紹springboot+dubbo+zookeeper的示例分析,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

在dubbo-admin-0.0.1-SNAPSHOT.jar的路徑下啟動(dòng)dubbo,java -jar dubbo-admin-0.0.1-SNAPSHOT.jar

springboot+dubbo+zookeeper的示例分析

dubbo-admin-0.0.1-SNAPSHOT.jar的包需要提前打好

啟動(dòng)zookeeper的zkServer.cmd和zkCli.cmd

需要的依賴

 <!-- 導(dǎo)入依賴:zookeeper + dubbo -->
        <!-- https://mvnrepository.com/artifact/org.apache.dubbo/dubbo-spring-boot-starter -->
        <dependency>
            <groupId>org.apache.dubbo</groupId>
            <artifactId>dubbo-spring-boot-starter</artifactId>
            <version>2.7.3</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>
        <!--  上面兩個(gè)都是zookeeper服務(wù)端的一個(gè)依賴-->
        <dependency>
            <groupId>org.apache.zookeeper</groupId>
            <artifactId>zookeeper</artifactId>
            <version>3.4.14</version>
            <!--排除這個(gè)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>

服務(wù)端和消費(fèi)端都需要這些依賴

服務(wù)端

在服務(wù)端設(shè)置一個(gè)服務(wù)

springboot+dubbo+zookeeper的示例分析

@Component
@Service // 可以被掃描掃,在項(xiàng)目已啟動(dòng)就注冊(cè)到注冊(cè)中心  服務(wù)注冊(cè)與發(fā)現(xiàn)
public class TickServiceImp implements TicketService {
    @Override
    public String getTick() {
        return "《今天是個(gè)好日子》";
    }
}

這里的@Service是dubbo下的用來(lái)吧服務(wù)注冊(cè)到注冊(cè)中心
@Component用來(lái)把類注入到容器中

application.yml配置如下

server:
  port: 8001

#服務(wù)應(yīng)用名字
dubbo:
  application:
    name: provider-server
#注冊(cè)中心地址
  registry:
    address: zookeeper://127.0.0.1:2181
#那些服務(wù)要被注冊(cè)
  scan:
    base-packages: com.cfz.service

啟動(dòng)服務(wù)端,在zookeeper設(shè)置的端口http://localhost:7001下查看

springboot+dubbo+zookeeper的示例分析

消費(fèi)端

首先導(dǎo)入所需依賴(同上文)

設(shè)置服務(wù)

springboot+dubbo+zookeeper的示例分析

這里的接口要和服務(wù)端的相同

Userservice類中如下

@Service //放到容器中
public class Userservice {

    //想拿到provider-server提供的票,需要去注冊(cè)中心拿服務(wù)
    @Reference //引用,pom坐標(biāo),可以定義路徑相同的接口名
    TicketService ticketService;

    public void buyTicket() {
        System.out.println("在注冊(cè)中心拿到"+ticketService.getTick());
    }
}

application.yml配置如下

springboot+dubbo+zookeeper的示例分析

以上是“springboot+dubbo+zookeeper的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI