更新時間: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架構圖如下所示:
節點角色說明:
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
以上內容就是動力節點java學院小編介紹的“Java前沿技術-Dubbo的配置及使用”的內容,希望對大家有幫助,更多精彩內容請關注動力節點java學院官網。
相關推薦
dubbo視頻教程免費下載路徑:http://www.dabaquan.cn/v99/
0基礎 0學費 15天面授
有基礎 直達就業
業余時間 高薪轉行
工作1~3年,加薪神器
工作3~5年,晉升架構
提交申請后,顧問老師會電話與您溝通安排學習