dubbo admin監(jiān)控中心+zookeeper注冊(cè)中心的簡(jiǎn)單配置

dubbo+zookeeper注冊(cè)中心的簡(jiǎn)單配置

1.新增一個(gè)父項(xiàng)目,并在父項(xiàng)目中添加依賴
<dependencies>
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>dubbo</artifactId>
            <version>2.5.8</version>
        </dependency>
        <dependency>
            <groupId>org.apache.zookeeper</groupId>
            <artifactId>zookeeper</artifactId>
            <version>3.4.6</version>
        </dependency>
        <dependency>
            <groupId>com.101tec</groupId>
            <artifactId>zkclient</artifactId>
            <version>0.7</version>
        </dependency>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
        </dependency>
    </dependencies>
2.在父項(xiàng)目中添加一個(gè)子模塊dubbo_interface,并新增一個(gè)IHelloInterface的接口
package com.ym.dubbo;

public interface IHelloInterface {
    String sayHello(String name);
}
3.在當(dāng)前父項(xiàng)目中添加一個(gè)子模塊dubbo_provider
  1. 在當(dāng)前子模塊的pom文件中,添加dubbo_interface的依賴

     <dependencies>
            <dependency>
                <groupId>com.ym</groupId>
                <artifactId>dubbo_interface</artifactId>
                <version>1.0-SNAPSHOT</version>
            </dependency>
        </dependencies>
    
  2. 在當(dāng)前子模塊中添加dubbo_interface模塊的實(shí)現(xiàn)類

    package com.ym.dubbo;
    
    public class HelloName implements IHelloInterface {
    
        @Override
        public String sayHello(String name) {
            return "hello " + name;
        }
    }
    
  3. 在當(dāng)前子模塊的resources下新增spring-dubbo.xml的配置文件(注冊(cè)中心的IP地址一定要找準(zhǔn))

    <?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://code.alibabatech.com/schema/dubbo"
           xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://code.alibabatech.com/schema/dubbo http://code.alibabatech.com/schema/dubbo/dubbo.xsd">
    
        <!--使用bean,來創(chuàng)建一個(gè)helloName的示例對(duì)象-->
        <bean id="myDubbo" class="com.ym.dubbo.HelloName" />
    
        <!--定義一個(gè)dubbo的應(yīng)用程序名稱,將來會(huì)在dubbo的管理中心查看-->
        <dubbo:application name="DubboProvider" />
    
        <!--配置dubbo協(xié)議,dubbo,hession,RMI-->
        <dubbo:protocol name="dubbo" port="20880" />
    
        <!--將當(dāng)前應(yīng)用注冊(cè)到zookeeper注冊(cè)中心服務(wù)器上-->
        <dubbo:registry address="zookeeper://192.168.41.106:2181"></dubbo:registry>
    
        <!--將當(dāng)前服務(wù)的接口暴露出去,以提供消費(fèi)方來消費(fèi)-->
        <dubbo:service interface="com.ym.dubbo.IHelloInterface" ref="myDubbo" />
    
    </beans>
    
  4. 在當(dāng)前子模塊中新建一個(gè)測(cè)試類將當(dāng)前的spring-dubbo.xml文件加載起來

    import org.junit.Test;
    import org.springframework.context.support.ClassPathXmlApplicationContext;
    
    public class DubboTest {
    
        @Test
        public void testProvider(){
    
            //加載spring-dubbo的配置文件
            new ClassPathXmlApplicationContext("classpath:spring-dubbo.xml");
    
            //打印提示信息
            System.out.println("provider is ready");
    
            //死循環(huán)保證 長(zhǎng)連接
            while (true){}
        }
    }
    
4.在父項(xiàng)目中添加一個(gè)子模塊dubbo_consumer
  1. 在子模塊的pom文件中添加dubbo_interface的依賴(我們也可以添加dubbo_provider的依賴,從而達(dá)到調(diào)用dubbo_interface模塊中的接口方法,但是一般情況下dubbo_provider不一定是我們寫的,所以最好添加dubbo_interface的模塊依賴:就像是門戶網(wǎng)站上面的天氣預(yù)報(bào)功能,門戶網(wǎng)站本身不會(huì)"架一個(gè)鍋"來收集天氣信息,但是天氣預(yù)報(bào)服務(wù)商會(huì)提供一個(gè)接口,供門戶網(wǎng)站使用)

     <dependencies>
            <dependency>
                <groupId>com.ym</groupId>
                <artifactId>dubbo_interface</artifactId>
                <version>1.0-SNAPSHOT</version>
            </dependency>
        </dependencies>
    
  2. 在當(dāng)前子模塊中的resources下新增spring-dubbo.xml的配置文件(注冊(cè)中心的IP地址一定要找準(zhǔn))

    <?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://code.alibabatech.com/schema/dubbo"
           xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://code.alibabatech.com/schema/dubbo http://code.alibabatech.com/schema/dubbo/dubbo.xsd">
    
        <!--配置當(dāng)前應(yīng)用的名稱,給監(jiān)控中心來使用-->
        <dubbo:application name="DubboConsumer" />
        
        <!--設(shè)置注冊(cè)中心,從該注冊(cè)中心去消費(fèi)服務(wù)-->
        <dubbo:registry address="zookeeper://192.168.41.106:2181" />
        
        <!--獲取提供方提供的接口數(shù)據(jù)-->
        <dubbo:reference interface="com.ym.dubbo.IHelloInterface" id="testDubbo" />
    
    </beans>
    
  3. 在當(dāng)前子模塊新增測(cè)試類加載spring-dubbo的配置信息,并測(cè)試數(shù)據(jù)是否獲取

    import com.ym.dubbo.IHelloInterface;
    import org.junit.Test;
    import org.springframework.context.ApplicationContext;
    import org.springframework.context.support.ClassPathXmlApplicationContext;
    
    public class DubboTest {
        IHelloInterface helloInterface;
    
        @Test
        public void testConsumer(){
    
            //   加載spring-dubbo的配置文件
            ApplicationContext ac=new ClassPathXmlApplicationContext("classpath:spring-dubbo.xml");
    
            //  通過id拿到spring-dubbo中定義的testDubbo節(jié)點(diǎn)對(duì)應(yīng)的對(duì)象
            helloInterface=ac.getBean("testDubbo",IHelloInterface.class);
    
            //  調(diào)用testdubbo對(duì)象中的方法,完成測(cè)試
            String s = helloInterface.sayHello("zhangsan");
    
            //打印結(jié)果
            System.out.println(s);
    
            //死循環(huán)保證 長(zhǎng)連接
            while (true){}
    
        }
    }
    
5.linux下搭建zookeeper的環(huán)境
  1. 通過Xftp將解壓后的zookeeper-3.4.14文件放到/opt/下

  2. 關(guān)閉防火墻

    systemctl stop firewalld

  3. 切換到zookeeper的bin目錄下,然后運(yùn)行命令啟動(dòng)zookeeper

    ./zkServer.sh start

  4. 命令行中出現(xiàn)以下內(nèi)容,說明啟動(dòng)成功


    啟動(dòng)zookeeper.png
6.運(yùn)行dubbo_cunsumer子模塊中的測(cè)試類驗(yàn)證
  • 如果控制臺(tái)打印正確的內(nèi)容,說明已經(jīng)運(yùn)行過程已經(jīng)通了
7.配置dubbo的環(huán)境(tomcat+dubbo)
  1. 新建一個(gè)dubbo的文件夾,解壓一個(gè)純凈的tomcat,然后修改tomcat-users.xml的配置文件(添加一下代碼)

    <role rolename="manager-gui"/>
     <role rolename="manager-script"/>
     <role rolename="manager-jmx"/>
     <role rolename="manager-status"/>
     <user username="yanm" password="yanm" roles="manager-gui, manager-script, manager-jmx, manager-status"/>
    
  2. 下載dubbo-admin-2.5.8.war并將dubbo-admin-2.5.8.war放到tomcat的webapps包下,啟動(dòng)tomcat(dubbo-admin-2.5.8.war有點(diǎn)問題:如果啟動(dòng)報(bào)錯(cuò),并且進(jìn)入不了頁面,就先啟動(dòng)tomcat,然后再把dubbo-admin-2.5.8.war放到webapps下,然后刷新頁面)

  3. 修改tomcat-webapps-(dubbo-admin-2.5.8)-(WEB-INF)-dubbo.properties文件,將里面的IP地址修改成linux中(zookeeper)的IP地址

  4. 啟動(dòng)tomcat服務(wù),用戶名和密碼都是root,可以在dubbo.properties修改,如果顯示如下頁面,則說明成功


    dubbo-admin登陸1.png
  • 登陸成功如下
dubbo-admin登陸成功1.png
  • 查看信息


    查看信息.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,578評(píng)論 6 544
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,701評(píng)論 3 429
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事?!?“怎么了?”我有些...
    開封第一講書人閱讀 178,691評(píng)論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,974評(píng)論 1 318
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,694評(píng)論 6 413
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 56,026評(píng)論 1 329
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 44,015評(píng)論 3 450
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 43,193評(píng)論 0 290
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,719評(píng)論 1 336
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,442評(píng)論 3 360
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,668評(píng)論 1 374
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,151評(píng)論 5 365
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,846評(píng)論 3 351
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,255評(píng)論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,592評(píng)論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 52,394評(píng)論 3 400
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,635評(píng)論 2 380