大战熟女丰满人妻av-荡女精品导航-岛国aaaa级午夜福利片-岛国av动作片在线观看-岛国av无码免费无禁网站-岛国大片激情做爰视频

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

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

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



現在學習的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://m.dabaquan.cn/v99/



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

免費課程推薦 >>
技術文檔推薦 >>
主站蜘蛛池模板: 色老头一区二区三区 | 综合激情在线 | 99热精品成人免费观看 | 午夜免费体验区 | 狠狠操狠狠操狠狠操 | 欧美性猛交xx乱大交 | 欧美色88| 99久久99热精品免费观看国产 | 欧美一级毛片特黄黄 | 涩涩视频在线观看 | 欧洲a老妇女黄大片 | 欧美另类网站 | 极品美女一级毛片免费 | 欧美一区二区在线观看免费网站 | 亚洲成aⅴ人片在线观 | er久99久热只有精品国产 | 欧美色网在线 | 久久97精品久久久久久清纯 | 免费看国产精品久久久久 | 久久天堂在线 | 老司机深夜福利影院 | 伊人久久青草青青综合 | 欧美激情精品久久久久久不卡 | 亚洲日本香蕉视频 | 亚洲天堂资源 | 99精彩免费观看 | 国产精品香蕉在线一区 | 人人狠狠综合久久亚洲 | 国产一区二区三区在线观看免费 | 亚洲精品久久99久久一 | 国产一区二区在线观看视频 | 久久精品国产国产精品四凭 | 美女又黄又免费的视频 | 欧美6699在线视频免费 | 亚洲黄色片视频 | 狠狠色丁香久久婷婷综合_中 | 国产成人免费a在线视频色戒 | 日韩精品国产自在久久现线拍 | 综合久久久久综合97色 | 国产亚洲精品中文带字幕21页 | 婷婷色综合网 |