dubbo源碼愫讀(3)dubbo基本服務(wù)搭建

1、基本環(huán)境搭建

1.1、軟件及源碼

zookeeper安裝配置:http://www.itdecent.cn/p/de90172ea680

node.js及vue安裝配置:http://www.itdecent.cn/p/7834fc55e9e8

dubbo源碼:https://github.com/apache/incubator-dubbo

dubbo管理后臺源碼:https://github.com/apache/incubator-dubbo-ops

1.2、環(huán)境配置

1.2.1、zookeeper配置

解壓zookeeper壓縮包,會有如下目錄:

zk解壓后目錄.png

雙擊運(yùn)行bin目錄下的zkServer.cmd啟動腳本,啟動成功會顯示如下信息:

zk服務(wù)啟動輸出.png

若執(zhí)行腳本出現(xiàn)閃退,則啟動異常,請打開windows的cmd窗口,在此窗口中執(zhí)行zkServer.cmd命令,并查看異常原因。

若2181端口被占用,請先關(guān)閉占用此端口的應(yīng)用。

zookeeper服務(wù)端啟動完成后,啟動bin目錄下的zkCli.cmd客戶端腳本。啟動成功并輸入:【ls /】命令會有以下輸出:

zk客戶端輸出.png

1.2.2、dubbo源碼編譯

dubbo源碼目錄結(jié)構(gòu)如下:

dubbo源碼目錄結(jié)構(gòu).png

利用idea等IDE工具集成的maven進(jìn)行編譯打包,并本地install;

dubbo源碼編譯打包安裝.png

1.2.3、dubbo管理后臺

(1)管理后臺結(jié)構(gòu)介紹

dubbo后臺管理的目錄結(jié)構(gòu)如下:

dubbo管理后臺源碼結(jié)構(gòu).png

dubbo最新版使用了前后端分離:

dubbo-admin-backend:基于spring-boot的后端業(yè)務(wù)邏輯代碼;

dubbo-admin-frontend:基于vue的前臺頁面資源代碼;

(1)后端編譯配置啟動

后端代碼目錄如下:

后端代碼目錄結(jié)構(gòu).png

后端主要配置zookeeper,即配置注冊中心,application.properties中配置如下:

后端配置.png

運(yùn)行DubboAdminApplication的main函數(shù),啟動后端服務(wù):

后端啟動.png

啟動成功將有如下輸出:

后端輸出.png

(1)前端配置啟動

前端代碼目錄如下:

前端代碼目錄結(jié)構(gòu).png

config/index.js中有如下配置:

前端配置.png

前臺服務(wù)器啟動之后有如下輸出:

前端啟動輸出.png

打開瀏覽器,輸入:http://localhost:8081

dubbo管理后臺界面.png

2、服務(wù)提供者及調(diào)用者

項(xiàng)目目錄結(jié)構(gòu)如下:

demo目錄結(jié)構(gòu).png

maven中dubbo版本依賴:

<dependencies>
   <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>
   </dependency>

   <!--此版本為本地編譯版本,若demo無法運(yùn)行請?zhí)鎿Q為已發(fā)布版本-->
   <!--經(jīng)測試,最新版本無法識別注冊中心-->
   <!--<dependency>
      <groupId>org.apache.dubbo</groupId>
      <artifactId>dubbo</artifactId>
      <version>2.7.0-SNAPSHOT</version>
   </dependency>-->
   <dependency>
      <groupId>com.alibaba</groupId>
      <artifactId>dubbo</artifactId>
      <version>2.6.5</version>
   </dependency>
   <dependency>
      <groupId>org.apache.curator</groupId>
      <artifactId>curator-framework</artifactId>
      <version>4.0.1</version>
   </dependency>
</dependencies>

2.1、服務(wù)提供者

2.1.1、dubbo-rpc-provider.xml配置

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:dubbo="http://dubbo.apache.org/schema/dubbo"
       xsi:schemaLocation="http://www.springframework.org/schema/beans        http://www.springframework.org/schema/beans/spring-beans-4.3.xsd        http://dubbo.apache.org/schema/dubbo        http://dubbo.apache.org/schema/dubbo/dubbo.xsd">

    <!-- 提供方應(yīng)用信息,用于計(jì)算依賴關(guān)系 -->
    <dubbo:application name="privider-api-test"  />

    <!-- 使用zookeeper注冊中心暴露服務(wù)地址 -->
    <dubbo:registry id="zookeeperRegistry" protocol="zookeeper" address="zookeeper://127.0.0.1:2181" />

    <!-- 用dubbo協(xié)議在20880端口暴露服務(wù) -->
    <dubbo:protocol name="dubbo" port="20880" />

    <!-- 聲明需要暴露的服務(wù)接口 -->
    <dubbo:service id="dubboTestApi" interface="dubbo.demo.api.DubboTestApi" ref="dubboTestApiImpl" />

    <!-- 和本地bean一樣實(shí)現(xiàn)服務(wù) -->
    <bean id="dubboTestApiImpl" class="dubbo.demo.api.DubboTestApiImpl" />
</beans>

使用zookeeper作為注冊中心,協(xié)議dubbo協(xié)議,暴露端口為20880;

2.1.2、服務(wù)啟動實(shí)現(xiàn)

public class ProviderMain {
    public static void main(String[] args) throws Exception {
        ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("config/rpc/dubbo-rpc-provider.xml");
        context.start();
        System.in.read(); // 按任意鍵退出
    }
}

2.1.3、啟動服務(wù)

運(yùn)行main函數(shù),啟動服務(wù),輸出如下:

服務(wù)提供者啟動.png

管理后臺服務(wù)提供者有如下信息:

后臺服務(wù)調(diào)用者信息.png

2.2、服務(wù)調(diào)用者

2.2.1、dubbo-rpc-consumer.xml配置

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:dubbo="http://dubbo.apache.org/schema/dubbo"
       xsi:schemaLocation="http://www.springframework.org/schema/beans        http://www.springframework.org/schema/beans/spring-beans-4.3.xsd        http://dubbo.apache.org/schema/dubbo        http://dubbo.apache.org/schema/dubbo/dubbo.xsd">

    <!-- 消費(fèi)方應(yīng)用名,用于計(jì)算依賴關(guān)系,不是匹配條件,不要與提供方一樣 -->
    <dubbo:application name="consumer-api-test"  />

    <!-- 使用zookeeper注冊中心暴露發(fā)現(xiàn)服務(wù)地址 -->
    <dubbo:registry address="zookeeper://127.0.0.1:2181" />

    <!-- 生成遠(yuǎn)程服務(wù)代理,可以和本地bean一樣使用demoService -->
    <dubbo:reference id="dubboTestApi" interface="dubbo.demo.api.DubboTestApi" />
</beans>

2.2.2、服務(wù)啟動實(shí)現(xiàn)

public class ConsumerMain {
    public static void main(String[] args) throws Exception {
        ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("config/rpc/dubbo-rpc-consumer.xml");
        context.start();
        DubboTestApi testApi = (DubboTestApi) context.getBean("dubboTestApi"); // 獲取遠(yuǎn)程服務(wù)代理
        String ret = testApi.echoTest("this is my test!");
        System.out.println(ret); // 顯示調(diào)用結(jié)果
        System.in.read();
    }
}

2.2.3、調(diào)用服務(wù)

服務(wù)輸出:

服務(wù)調(diào)用者啟動輸出.png

管理后臺服務(wù)消費(fèi)者有如下信息:

后臺服務(wù)消費(fèi)者信息.png

demo源碼:https://github.com/zhaozhou11/dubbo-demo.git

參考文檔:http://dubbo.apache.org/zh-cn/docs/user/quick-start.html

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容