大战熟女丰满人妻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://www.dabaquan.cn/v99/



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

免費課程推薦 >>
技術文檔推薦 >>
主站蜘蛛池模板: 夜夜艹日日艹 | 久久久久久久99精品免费观看 | 99视频精品 | 老妇综合久久香蕉蜜桃 | 精品福利视频第一 | 欧美18videosex护士 | 第一国内永久免费福利视频 | 天天做天天爱天天爽综合网 | 免费一级毛片不卡在线播放 | 2020久久精品永久免费 | 欧美成人亚洲高清在线观看 | 国产日产亚洲精品 | 最新中文字幕日本 | 日本一级大毛片a一 | 精品一区二区三区色花堂 | 久草在线在线视频 | 国产一区二区免费在线 | 精品视频自拍 | 欧美一区亚洲 | 99成人在线| 国产亚洲精品久久yy5099 | 欧洲成人免费视频 | 日韩精品一区二区三区视频 | 亚欧成人毛片一区二区三区四区 | 日韩香蕉视频 | 日日夜夜精品 | 日本高清不卡免费 | 四虎网址在线观看 | 欧美成人日韩 | 亚洲精品二区中文字幕 | 国产区免费 | 91精品国产人成网站 | 亚洲毛片免费观看 | 顶级欧美色妇xxxxbbbb | 天天躁狠狠躁 | 人人骚 | 久久99视频免费 | 在线播放69热精品视频 | 国产精品久久精品牛牛影视 | 在线激情网址 | 久草精品视频在线观看 |