spring整合dubbo&zookeeper

zookeeper安裝(單機(jī))

下載地址 https://mirrors.tuna.tsinghua.edu.cn/apache/zookeeper/病游,我這邊使用的是v3.4.13

配置文件

下載解壓后礁遵,復(fù)制一份conf/zoo_sample.cfg政勃,重命名為zoo.cfg,設(shè)置dataDir就可以了。

#日志存儲目錄
dataDir=/Users/xuyongjun/Downloads/zookeeper-3.4.13/data
#心跳包時間
tickTime=2000
#監(jiān)聽客戶端連接端口
clientPort=2181
啟動zookeeper

下面命令適用于unix和linux系統(tǒng),windows系統(tǒng)應(yīng)該使用.cmd文件。

/bin/zkServer.sh start
/bin/zkCli.sh -server

zookeeper配置完后诅迷,我們接著創(chuàng)建dubbo項目贡歧,我使用的是gradle來構(gòu)建的猎莲,如果你創(chuàng)建完項目后src下面沒有java目錄蜘欲,你可以build.gradle中添加下面的task執(zhí)行益眉。

task createdirs() {
    sourceSets*.java.srcDirs*.each { it.mkdirs() }
    sourceSets*.resources.srcDirs*.each { it.mkdirs() }
}

./gradlew createDirs
添加依賴庫
repositories {
//    mavenCentral()
    //國內(nèi)鏡像,下載要快點
    maven{ url'http://maven.aliyun.com/nexus/content/groups/public/'}
}

dependencies {
    testCompile group: 'junit', name: 'junit', version: '4.11'
    testCompile group: 'junit', name: 'junit', version: '4.12'
    compile group: 'com.alibaba', name: 'dubbo', version: '2.5.3'
    compile group: 'org.apache.zookeeper', name: 'zookeeper', version: '3.4.6', ext: 'pom'
    compile group: 'io.netty', name: 'netty-all', version: '4.0.35.Final'
    compile group: 'org.apache.curator', name: 'curator-recipes', version: '2.12.0'
// https://mvnrepository.com/artifact/com.101tec/zkclient
    compile group: 'com.101tec', name: 'zkclient', version: '0.2'
}

服務(wù)提供者


定義服務(wù)接口
package com.example.provider;

public interface DemoService {

    String sayHello(String name);
}
實現(xiàn)接口
package com.example.provider;

public class DemoServiceImpl implements DemoService {
    @Override
    public String sayHello(String name) {
        return "Hello " + name;
    }
}

使用spring配置聲明服務(wù)

之前按照官網(wǎng)的xml配置姥份,運行后一直報錯郭脂;最后發(fā)現(xiàn)是命名空間的問題,issues地址https://github.com/apache/incubator-dubbo/issues/1739

provider.xml:

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


    <!-- 提供方應(yīng)用信息澈歉,用于計算依賴關(guān)系 -->
    <dubbo:application name="hello-world-app"/>

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

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

    <!-- 聲明需要暴露的服務(wù)接口 -->
    <dubbo:service interface="com.example.provider.DemoService" ref="demoService"/>

    <!-- 和本地bean一樣實現(xiàn)服務(wù) -->
    <bean id="demoService" class="com.example.provider.DemoServiceImpl"/>
</beans>
加載spring配置
package com.example.provider;

import org.springframework.context.support.ClassPathXmlApplicationContext;

import java.io.IOException;

public class Provider {

    public static void main(String[] args) throws IOException {
        ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("classpath:provider.xml");
        context.start();
        System.in.read(); // 按任意鍵退出
    }
}

服務(wù)消費者


spring配置引用遠(yuǎn)程服務(wù)

consumer.xml:

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

    <!-- 消費方應(yīng)用名展鸡,用于計算依賴關(guān)系,不是匹配條件埃难,不要與提供方一樣 -->
    <dubbo:application name="consumer-of-helloworld-app"  />

    <dubbo:registry protocol="zookeeper" address="zookeeper://127.0.0.1:2181"/>

    <!-- 生成遠(yuǎn)程服務(wù)代理莹弊,可以和本地bean一樣使用demoService -->
    <dubbo:reference id="demoService" interface="com.example.provider.DemoService" />

</beans>
加載spring配置,調(diào)用遠(yuǎn)程服務(wù)
package com.example.provider;

import org.springframework.context.support.ClassPathXmlApplicationContext;

public class Consumer {

    public static void main(String[] args) {
        ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("classpath:consumer.xml");
        context.start();
        DemoService demoService = (DemoService)context.getBean("demoService"); // 獲取遠(yuǎn)程服務(wù)代理
        String hello = demoService.sayHello("world"); // 執(zhí)行遠(yuǎn)程方法
        System.out.println( hello ); // 顯示調(diào)用結(jié)果
        
    }
}

代碼已經(jīng)上傳到github上了涡尘,有問題可以拉下來參考忍弛;希望可以幫助到你。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末考抄,一起剝皮案震驚了整個濱河市细疚,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌川梅,老刑警劉巖疯兼,帶你破解...
    沈念sama閱讀 211,042評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異贫途,居然都是意外死亡吧彪,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,996評論 2 384
  • 文/潘曉璐 我一進(jìn)店門丢早,熙熙樓的掌柜王于貴愁眉苦臉地迎上來姨裸,“玉大人,你說我怎么就攤上這事怨酝】酰” “怎么了?”我有些...
    開封第一講書人閱讀 156,674評論 0 345
  • 文/不壞的土叔 我叫張陵凫碌,是天一觀的道長扑毡。 經(jīng)常有香客問我胃榕,道長盛险,這世上最難降的妖魔是什么瞄摊? 我笑而不...
    開封第一講書人閱讀 56,340評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮苦掘,結(jié)果婚禮上换帜,老公的妹妹穿的比我還像新娘。我一直安慰自己鹤啡,他們只是感情好惯驼,可當(dāng)我...
    茶點故事閱讀 65,404評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著递瑰,像睡著了一般祟牲。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上抖部,一...
    開封第一講書人閱讀 49,749評論 1 289
  • 那天说贝,我揣著相機(jī)與錄音,去河邊找鬼慎颗。 笑死乡恕,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的俯萎。 我是一名探鬼主播傲宜,決...
    沈念sama閱讀 38,902評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼夫啊!你這毒婦竟也來了函卒?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,662評論 0 266
  • 序言:老撾萬榮一對情侶失蹤涮母,失蹤者是張志新(化名)和其女友劉穎谆趾,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體叛本,經(jīng)...
    沈念sama閱讀 44,110評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡沪蓬,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了来候。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片跷叉。...
    茶點故事閱讀 38,577評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖营搅,靈堂內(nèi)的尸體忽然破棺而出云挟,到底是詐尸還是另有隱情,我是刑警寧澤转质,帶...
    沈念sama閱讀 34,258評論 4 328
  • 正文 年R本政府宣布园欣,位于F島的核電站,受9級特大地震影響休蟹,放射性物質(zhì)發(fā)生泄漏沸枯。R本人自食惡果不足惜日矫,卻給世界環(huán)境...
    茶點故事閱讀 39,848評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望绑榴。 院中可真熱鬧哪轿,春花似錦、人聲如沸翔怎。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,726評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽赤套。三九已至飘痛,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間容握,已是汗流浹背敦冬。 一陣腳步聲響...
    開封第一講書人閱讀 31,952評論 1 264
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留唯沮,地道東北人脖旱。 一個月前我還...
    沈念sama閱讀 46,271評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像介蛉,于是被迫代替她去往敵國和親萌庆。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,452評論 2 348

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