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

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

1.1饼拍、軟件及源碼

zookeeper安裝配置:http://www.reibang.com/p/de90172ea680

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

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

dubbo管理后臺(tái)源碼:https://github.com/apache/incubator-dubbo-ops

1.2首装、環(huán)境配置

1.2.1厉膀、zookeeper配置

解壓zookeeper壓縮包颤殴,會(huì)有如下目錄:

zk解壓后目錄.png

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

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

若執(zhí)行腳本出現(xiàn)閃退,則啟動(dòng)異常涵但,請(qǐng)打開windows的cmd窗口哪亿,在此窗口中執(zhí)行zkServer.cmd命令,并查看異常原因贤笆。

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

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

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管理后臺(tái)

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

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

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

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

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

dubbo-admin-frontend:基于vue的前臺(tái)頁面資源代碼;

(1)后端編譯配置啟動(dòng)

后端代碼目錄如下:

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

后端主要配置zookeeper耳标,即配置注冊(cè)中心醇坝,application.properties中配置如下:

后端配置.png

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

后端啟動(dòng).png

啟動(dòng)成功將有如下輸出:

后端輸出.png

(1)前端配置啟動(dòng)

前端代碼目錄如下:

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

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

前端配置.png

前臺(tái)服務(wù)器啟動(dòng)之后有如下輸出:

前端啟動(dòng)輸出.png

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

dubbo管理后臺(tái)界面.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)行請(qǐng)?zhí)鎿Q為已發(fā)布版本-->
   <!--經(jīng)測(cè)試,最新版本無法識(shí)別注冊(cè)中心-->
   <!--<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注冊(cè)中心暴露服務(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作為注冊(cè)中心谚赎,協(xié)議dubbo協(xié)議淫僻,暴露端口為20880;

2.1.2壶唤、服務(wù)啟動(dòng)實(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雳灵、啟動(dòng)服務(wù)

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

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

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

后臺(tái)服務(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注冊(cè)中心暴露發(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ù)啟動(dòng)實(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)用者啟動(dòng)輸出.png

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

后臺(tá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)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末荡灾,一起剝皮案震驚了整個(gè)濱河市瓤狐,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌批幌,老刑警劉巖础锐,帶你破解...
    沈念sama閱讀 216,591評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異荧缘,居然都是意外死亡皆警,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門截粗,熙熙樓的掌柜王于貴愁眉苦臉地迎上來信姓,“玉大人,你說我怎么就攤上這事绸罗∫馔疲” “怎么了?”我有些...
    開封第一講書人閱讀 162,823評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵珊蟀,是天一觀的道長(zhǎng)菊值。 經(jīng)常有香客問我,道長(zhǎng),這世上最難降的妖魔是什么俊性? 我笑而不...
    開封第一講書人閱讀 58,204評(píng)論 1 292
  • 正文 為了忘掉前任略步,我火速辦了婚禮,結(jié)果婚禮上定页,老公的妹妹穿的比我還像新娘趟薄。我一直安慰自己,他們只是感情好典徊,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,228評(píng)論 6 388
  • 文/花漫 我一把揭開白布杭煎。 她就那樣靜靜地躺著,像睡著了一般卒落。 火紅的嫁衣襯著肌膚如雪羡铲。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,190評(píng)論 1 299
  • 那天儡毕,我揣著相機(jī)與錄音也切,去河邊找鬼。 笑死腰湾,一個(gè)胖子當(dāng)著我的面吹牛雷恃,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播费坊,決...
    沈念sama閱讀 40,078評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼倒槐,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了附井?” 一聲冷哼從身側(cè)響起讨越,我...
    開封第一講書人閱讀 38,923評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎永毅,沒想到半個(gè)月后把跨,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,334評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡沼死,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,550評(píng)論 2 333
  • 正文 我和宋清朗相戀三年着逐,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片漫雕。...
    茶點(diǎn)故事閱讀 39,727評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖峰鄙,靈堂內(nèi)的尸體忽然破棺而出浸间,到底是詐尸還是另有隱情,我是刑警寧澤吟榴,帶...
    沈念sama閱讀 35,428評(píng)論 5 343
  • 正文 年R本政府宣布魁蒜,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏兜看。R本人自食惡果不足惜锥咸,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,022評(píng)論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望细移。 院中可真熱鬧搏予,春花似錦、人聲如沸弧轧。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,672評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽精绎。三九已至速缨,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間代乃,已是汗流浹背旬牲。 一陣腳步聲響...
    開封第一講書人閱讀 32,826評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留搁吓,地道東北人原茅。 一個(gè)月前我還...
    沈念sama閱讀 47,734評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像擎浴,于是被迫代替她去往敵國(guó)和親员咽。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,619評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容