黄色网址大全免费-黄色网址你懂得-黄色网址你懂的-黄色网址有那些-免费超爽视频-免费大片黄国产在线观看

專注Java教育14年 全國咨詢/投訴熱線:400-8080-105
動力節點LOGO圖
始于2009,口口相傳的Java黃埔軍校
首頁 學習攻略 Java前沿技術-Dubbo的配置及使用

Java前沿技術-Dubbo的配置及使用

更新時間:2019-08-23 10:43:13 來源:動力節點 瀏覽2594次



現在學習的java編程的人越來越多了,Java是現今最流行的編程語言,在行業類工資也是相當高的,今天動力節點java學院小編為大家分享“Java前沿技術-Dubbo的配置及使用”,下面隨小編一起看看吧。


1、Dubbo是什么?


  Dubbo是一個分布式服務框架,致力于提供高性能和透明化的RPC遠程服務調用方案,以及SOA服務治理方案。簡單的說,dubbo就是個服務框架,如果沒有分布式的需求,其實是不需要用的,只有在分布式的時候,才有dubbo這樣的分布式服務框架的需求,并且本質上是個服務調用的東東,說白了Dubbo就是個遠程服務調用的分布式框架。


  其核心部分包含:


  (1)遠程通訊:提供對多種基于長連接的NIO框架抽象封裝,包括多種線程模型,序列化,以及“請求-響應”模式的信息交換方式。


  (2)集群容錯: 提供基于接口方法的透明遠程過程調用,包括多協議支持,以及軟負載均衡,失敗容錯,地址路由,動態配置等集群支持。


  (3)自動發現:基于注冊中心目錄服務,使服務消費方能動態的查找服務提供方,使地址透明,使服務提供方可以平滑增加或減少機器。



  2、Dubbo能做什么?


  (1)透明化的遠程方法調用,就像調用本地方法一樣調用遠程方法,只需簡單配置,沒有任何API侵入。


  (2)軟負載均衡及容錯機制,可在內網替代F5等硬件負載均衡器,降低成本,減少單點。


  (3) 服務自動注冊與發現,不再需要寫死服務提供方地址,注冊中心基于接口名查詢服務提供者的IP地址,并且能夠平滑添加或刪除服務提供者。



  3、dubbo的架構


  dubbo架構圖如下所示:


1.png




  節點角色說明:


  Provider: 暴露服務的服務提供方。


  Consumer: 調用遠程服務的服務消費方。


  Registry: 服務注冊與發現的注冊中心。


  Monitor: 統計服務的調用次調和調用時間的監控中心。


  Container: 服務運行容器。



  調用關系說明


  (1)服務容器負責啟動,加載,運行服務提供者。


  (2)服務提供者在啟動時,向注冊中心注冊自己提供的服務。


  (3)注冊中心返回服務提供者地址列表給消費者,如果有變更,注冊中心將基于長連接推送變更數據給消費者。


  (4)服務消費者,從提供者地址列表中,基于軟負載均衡算法,選一臺提供者進行調用,如果調用失敗,再選另一臺調用。


  (5)服務消費者和提供者,在內存中累計調用次數和調用時間,定時每分鐘發送一次統計數據到監控中心。


  (6)Dubbo 架構具有以下幾個特點,分別是連通性、健壯性、伸縮性、以及向未來架構的升級性。



  4、dubbo使用方法


  Dubbo采用全Spring配置方式,透明化接入應用,對應用沒有任何API侵入,只需用Spring加載Dubbo的配置即可,Dubbo基于Spring的Schema擴展進行加載。


  dubbo通常采用zookeeper作為注冊中心,這也是官方推薦的方式


  (1)使用dubbo前先啟動zookeeper。


  (2)定義服務接口。


服務提供者


package com.unj.dubbotest.provider;  

  

import java.util.List;  

  

public interface DemoService {  

  

    String sayHello(String name);  

  

    public List getUsers();  

  

}  



在服務提供方實現接口:(對服務消費方隱藏實現)


package com.unj.dubbotest.provider;  

  

import java.util.ArrayList;  

import java.util.LinkedList;  

import java.util.List;  

  

public class DemoServiceImpl implements DemoService{  

      

     public String sayHello(String name) {  

            return "Hello " + name;  

     }  

     public List getUsers() {  

         List list = new ArrayList();  

         User u1 = new User();  

         u1.setName("jack");  

         u1.setAge(20);  

         u1.setSex("男");  

           

         User u2 = new User();  

         u2.setName("tom");  

         u2.setAge(21);  

         u2.setSex("女");  

           

         User u3 = new User();  

         u3.setName("rose");  

         u3.setAge(19);  

         u3.setSex("女");  

           

         list.add(u1);  

         list.add(u2);  

         list.add(u3);  

         return list;  

     }  

}  


用Spring配置聲明暴露服務:


  

<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  

        ">  

  

      

     

      

      

     

   

      

    

      

  

  <---->

      

    

      

     

   

      

     

      

 


dubbo.properties文件(第一行是配置zookeeper的地址)


zookeeper.address=zookeeper://zkserver1.vko.cn:2181?backup=zkserver2.vko.cn:2181,zkserver3.vko.cn:2181

#zookeeper.address=N/A

goods.dubbo.url=

video.dubbo.url=

study.dubbo.url=

tiku.dubbo.url=

member.dubbo.url=

group.dubbo.url=

search.dubbo.url=

comment.dubbo.url=

cms.dubbo.url=


服務消費者:


通過Spring配置引用遠程服務:


  

<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  

        ">  

  

      

     

  

      

   

     

  

      

  

   <dubbo:reference id="demoService"  

        interface="com.unj.dubbotest.provider.DemoService" url="${study.dubbo.url}" version="1.0" timeout="20000" check="false"/>  

  

 


  然后分別啟動服務提供者和服務消費者就可以在消費中像調用本地方法一樣調用遠程接口服務 ,對于分布式服務來說,通常情況下服務提供者也是其它服務的消費者,反之服務消費者也會對外提供服務。


  這里會遇到一個dubbo循環調用的問題,在編程時應盡量避免。



  5、dubbo控制臺的安裝和使用


  dubbo的管理服務是需要單獨部署的


  dubbo管理控制臺開源部分主要包含: 提供者 路由規則 動態配置 訪問控制 權重調節 負載均衡 負責人,等管理功能。


  (1)下載dubbo,里面有個 dubbo-admin-xxxx.war 扔到tomcat 里,


  (2)配置dubbo.properties


  vim webapps/ROOT/WEB-INF/dubbo.properties


  dubbo.registry.address=zookeeper://10.0.65.3:2181


  dubbo.admin.root.password=root


  dubbo.admin.guest.password=guest


  (3)啟動tomcat localhost:8080/


  登錄密碼為root/root

1566527165787858.png


1566527208443481.png


1566527233415844.png


1566527249112291.png


以上內容就是動力節點java學院小編介紹的“Java前沿技術-Dubbo的配置及使用”的內容,希望對大家有幫助,更多精彩內容請關注動力節點java學院官網。


相關推薦


dubbo視頻教程免費下載路徑:http://www.ilovecolors.com.cn/v99/



提交申請后,顧問老師會電話與您溝通安排學習

免費課程推薦 >>
技術文檔推薦 >>
主站蜘蛛池模板: 国产一级做a爱免费观看 | 黄色一级片在线免费观看 | 日日操夜夜爽 | 男女一级爽爽快视频 | 国产在线成人精品 | 免费高清小黄站在线观看 | 国产一级特黄全黄毛片 | 午夜久久久久久亚洲国产精品 | 在线播放国产麻豆 | 欧美精品1区 | 2021国产精品成人免费视频 | 欧美 日韩 国产 在线 | 国产性xxx | 亚洲伦理网站 | 色网站在线观看 | 丁香六月婷婷综合 | 亚洲人成一区二区三区 | 成人免费观看www视频 | 中文国产成人精品久久无广告 | 国产黄色一级大片 | 免费看欧美日韩一区二区三区 | h视频在线免费看 | 老司机精品久久最新免费 | 狂野欧美激情性xxxx | 五月天久久婷婷 | 国产最新进精品视频 | 日韩不卡中文字幕 | 狠狠干干干 | 亚洲欧美日韩高清一区二区三区 | 97人人艹| 欧美第一页草草影院 | 成人1000部免费观看视频 | 波多野结衣中文字幕久久 | 五月天婷婷免费视频 | 色天天综合久久久久综合片 | 国产一级一片免费播放刺激 | 国产精品视频久 | 国产情精品嫩草影院88av | 日韩免费在线视频观看 | 天天澡天天摸天天爽免费 | 精品视频午夜一区二区 |