dubbo服務提供與消費

一、前言

  項目中用到了Dubbo,臨時抱大腿,學習了dubbo的簡單實用方法。現在就來總結一下dubbo如何提供服務,如何消費服務,并做了一個簡單的demo作為參考。

二、Dubbo是什么

  Dubbo是一個分布式服務框架,致力于提供高性能和透明化的RPC遠程服務調用方案,以及SOA服務治理方案。簡單的說,dubbo就是個服務框架,如果沒有分布式的需求,其實是不需要用的,只有在分布式的時候,才有dubbo這樣的分布式服務框架的需求,并且本質上是個服務調用的東東,說白了就是個遠程服務調用的分布式框架(告別Web Service模式中的WSdl,以服務者與消費者的方式在dubbo上注冊)
其核心部分包含:
  1. 遠程通訊: 提供對多種基于長連接的NIO框架抽象封裝,包括多種線程模型,序列化,以及“請求-響應”模式的信息交換方式。
  2. 集群容錯: 提供基于接口方法的透明遠程過程調用,包括多協議支持,以及軟負載均衡,失敗容錯,地址路由,動態配置等集群支持。
  3. 自動發現: 基于注冊中心目錄服務,使服務消費方能動態的查找服務提供方,使地址透明,使服務提供方可以平滑增加或減少機器。

  摘自:http://www.cnblogs.com/Javame/p/3632473.html

三、dubbo配置

  1.dubbo需要依賴的jar

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>com.hjz</groupId><artifactId>dubbo</artifactId><version>0.0.1-SNAPSHOT</version><packaging>pom</packaging><modules><module>hjz-dubbo-api</module><module>hjz-dubbo-consumer</module><module>hjz-dubbo-provider</module></modules><dependencies><dependency><groupId>com.alibaba</groupId><artifactId>dubbo</artifactId><version>2.8.4</version></dependency><dependency><groupId>javassist</groupId><artifactId>javassist</artifactId><version>3.12.1.GA</version></dependency><dependency><groupId>org.apache.zookeeper</groupId><artifactId>zookeeper</artifactId><version>3.4.6</version></dependency><dependency><groupId>com.github.sgroschupf</groupId><artifactId>zkclient</artifactId><version>0.1</version></dependency></dependencies>
</project>

  2.dubbo服務接口

package com.hjz.dubbo.api;public interface DubboServiceTest {public int calculate(int a, int b);
}

  3.dubbo服務生產者配置

  實現dubbo服務的接口

package com.hjz.service;import org.springframework.stereotype.Service;import com.hjz.dubbo.api.DubboServiceTest;@Service("dubboServiceTest")
public class DubboServiceProvider implements DubboServiceTest {@Overridepublic int calculate(int a, int b) {return a+b;}}

  dubbo服務提供者配置:classpath:dubbo-provider-example.xml

<?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:context="http://www.springframework.org/schema/context"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://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsdhttp://code.alibabatech.com/schema/dubbo http://code.alibabatech.com/schema/dubbo/dubbo.xsd"><description>dubbo公共配置</description><!-- 掃描需要注入到spring容器中的bean --><context:component-scan base-package="com.hjz.service" /><!-- 引入dubbo需要的配置文件 --><context:property-placeholder location="classpath:dubbo-example.properties" />    <!-- 同一個工程只配置一份即可 --><dubbo:application name="hjz-dubbo" owner="hjzgg"/><!-- 發布dubbo需要對外的協議(dubbo)和端口(20880),20880是dubbo默認提供的端口,若一臺機器發布多個dubbo服務,則此端口需要顯示配置,多個dubbo服務端口需要不一樣,否則會端口沖突 --><dubbo:protocol name="dubbo" port="${dubbo.protocol.port}" serialization="java"/><!-- 配置dubbo服務失敗后的重試次數和接口超時時間 --><dubbo:provider retries="0" timeout="${dubbo.provider.timeout}"/><!-- dubbo注冊到zookeeper,用于預發布或生產環境 --><!-- <dubbo:registry protocol="zookeeper" address="${zookeeper.addr}" /> --><!-- dubbo不注冊到任何registry,用于開發或測試環境--><dubbo:registry protocol="zookeeper" address="N/A" /><dubbo:service ref="dubboServiceTest" interface="com.hjz.dubbo.api.DubboServiceTest"/>
</beans>

  由于是提供者作為一個web項目,所以web.xml文件如下。

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_2_5.xsd"version="2.5" xmlns="http://xmlns.jcp.org/xml/ns/javaee"><display-name>hjz-dubbo-provider</display-name><context-param><param-name>contextConfigLocation</param-name><param-value>classpath:dubbo-provider-example.xml</param-value></context-param><context-param><param-name>log4jConfigLocation</param-name><param-value>classpath:log4j.properties</param-value></context-param><listener><listener-class>org.springframework.web.context.ContextLoaderListener</listener-class></listener><welcome-file-list></welcome-file-list>
</web-app>

  4.dubbo服務消費者配置

  dubbo服務消費者測試類

package com.hjz.dubbo.consumer;import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;import com.alibaba.dubbo.common.logger.Logger;
import com.alibaba.dubbo.common.logger.LoggerFactory;
import com.hjz.dubbo.api.DubboServiceTest;@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations={"classpath:dubbo-consumer-example.xml"})
public class DubboServiceConsumer {private static final Logger logger = LoggerFactory.getLogger(DubboServiceConsumer.class);@Autowiredprivate DubboServiceTest dubboServiceTest;@Testpublic void consumer(){int a = 4, b = 5;logger.info("消費dubbo服務....................");logger.info(String.format("a = %d, b = %d, a+b = %d", a, b, dubboServiceTest.calculate(a, b)));}
}

  dubbo服務消費者配置:dubbo-consumer-example.xml

<?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:context="http://www.springframework.org/schema/context"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://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsdhttp://code.alibabatech.com/schema/dubbo http://code.alibabatech.com/schema/dubbo/dubbo.xsd"><description>dubbo公共配置</description><context:property-placeholder location="classpath:dubbo-example.properties" /><!-- 同一個工程只配置一份即可 --><dubbo:application name="hjz-dubbo" owner="hjzgg"/><!-- 服務應用方調用的超時時間。默認不配置,則以服務提供方的超時時間為準。check為false表示延遲加載dubbo依賴的服務--><dubbo:consumer retries="0" timeout="${dubbo.consumer.timeout}" check="false"/><!-- dubbo注冊到zookeeper,用于預發布或生產環境 --><!-- <dubbo:registry protocol="zookeeper" address="${zookeeper.addr}" /> --><!-- 像引用spring的bean服務一樣引用dubbo提供的接口,用于預發布和生產環境--><!-- <dubbo:reference id="dubboServiceTest"  interface="com.hjz.dubbo.api.DubboServiceTest" /> --><!-- dubbo直連方式,只用于開發或測試階段 --><dubbo:reference id="dubboServiceTest"  interface="com.hjz.dubbo.api.DubboServiceTest" url="dubbo://127.0.0.1:20880" />
</beans>

四、dubbo測試

  首先啟動dubbo生產者,然后運行消費者的測試類,可以看到控制臺中有如下信息輸出:

2016-09-25 19:36:08,502 INFO [com.hjz.dubbo.consumer.DubboServiceConsumer] -  [DUBBO] 消費dubbo服務...................., dubbo version: 2.8.4, current host: 192.168.80.4
2016-09-25 19:36:08,761 INFO [com.hjz.dubbo.consumer.DubboServiceConsumer] -  [DUBBO] a = 4, b = 5, a+b = 9, dubbo version: 2.8.4, current host: 192.168.80.4

五、總結

  1.如果一個工程中有dubbo消費者,也有dubbo生產者,則<dubbo:application name="hjz-dubbo" owner="hjzgg"/>配置只有一個就可以了。

  2.測試環境一般采用dubbo直聯方式,生產環境一般將dubbo服務注冊到zookeeper。

  3.配置文件中?dubbo:reference id="dubboServiceTest" ?和 dubbo:service ref="dubboServiceTest", idref的對應的value要一致。

  4.配置文件中?dubbo:service ref="dubboServiceTest",ref對應的value是服務的名稱,例如@Service("dubboServiceTest")。

  5.如果拋出下面異常,

com.caucho.hessian.client.HessianRuntimeException: com.caucho.hessian.io.HessianFieldException: com.shine.ermp.dto.UserAccountDTO.invalidDate:   
java.sql.Timestamp cannot be assigned from null  

   dubbo服務提供者的配置文件中加上下面紅色的代碼。

<dubbo:protocol  name="dubbo" port="20880" serialization="java"/>

六、測試demo

  https://github.com/hjzgg/dubbo_demo

  注:測試demo工程是個maven工程,eclipse可以通過?Check out as Maven Project from SCM 來導入即可,URL:https://github.com/hjzgg/dubbo_demo.git

轉載于:https://www.cnblogs.com/hujunzheng/p/5907035.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/531287.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/531287.shtml
英文地址,請注明出處:http://en.pswp.cn/news/531287.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

git親測命令

一、Git新建本地分支與遠程分支關聯問題 git checkout -b branch_name origin/branch_name 或者 git branch --set-upstream branch_name origin/branch_name 或者 git branch branch_name git branch --set-upstream-toorigin/branch_name branch_name 二、查看本地分支所關…

mysql 7下載安裝及問題解決

mysql 7安裝及問題解決 一、mysql下載 下載地址&#xff1a;https://www.mysql.com/downloads/Community (GPL) DownloadsMySQL Community Server (GPL)Windows (x86, 64-bit), ZIP ArchiveNo thanks, just start my download.二、mysql安裝 解壓到指定目錄在mysql bin目錄下打…

RestTemplate發送請求并攜帶header信息

1、使用restTemplate的postForObject方法 注&#xff1a;目前沒有發現發送攜帶header信息的getForObject方法。 HttpHeaders headers new HttpHeaders(); Enumeration<String> headerNames request.getHeaderNames(); while (headerNames.hasMoreElements()) {String k…

工作中常用到的命令

linux zip 和 unzip http://blog.csdn.net/shenyunsese/article/details/17556089 linux 查看日志 http://blog.chinaunix.net/uid-15463753-id-2943532.html linux 刪除 http://www.jb51.net/LINUXjishu/179430.html linux查看末尾日志&#xff08;tail -f&#xff09; http:/…

tomcat開發遠程調試端口以及利用eclipse進行遠程調試

一、tomcat開發遠程調試端口 方法1 WIN系統 在catalina.bat里&#xff1a;   SET CATALINA_OPTS-server -Xdebug -Xnoagent -Djava.compilerNONE -Xrunjdwp:transportdt_socket,servery,suspendn,address8899   Linux系統 在catalina.sh里&#xff1a;   CATALINA_OPTS&q…

webpack+react+redux+es6開發模式

一、預備知識 node, npm, react, redux, es6, webpack 二、學習資源 ECMAScript 6入門 React和Redux的連接react-redux Redux 入門教程 redux middleware 詳解 Redux研究 React 入門實例教程 webpack學習demo NPM 使用介紹 三、工程搭建 之前有寫過 webpackreactes6開發模式…

fiddler發送post請求

1.指定為 post 請求&#xff0c;輸入 url Content-Type: application/x-www-form-urlencoded;charsetutf-8 request body中的參數格式&#xff1a;userNameadminicxp&userPassword123qwe!# 這種方式可以用 request.getParameter的方式來獲得。 2.指定為 post 請求&#xff…

基于spring注解AOP的異常處理

一、前言 項目剛剛開發的時候&#xff0c;并沒有做好充足的準備。開發到一定程度的時候才會想到還有一些問題沒有解決。就比如今天我要說的一個問題&#xff1a;異常的處理。寫程序的時候一般都會通過try...catch...finally對異常進行處理&#xff0c;但是我們真的能在寫程序的…

Kettle之數據抽取、轉換、裝載

Kettle 官網 ETL利器Kettle實戰應用解析系列 利用kettle組件導入excel文件到數據庫 kettle中實現動態SQL查詢 java中調用kettle轉換文件 kettle 7.x版本下載&#xff1a;https://pan.baidu.com/s/1nvnzzCH  密碼&#xff1a;6f5c mac 下運行spoon.sh,  windows下為spoon.bat…

webpack+react+redux+es6開發模式---續

一、前言 之前介紹了webpackreactreduxes6開發模式 &#xff0c;這個項目對于一個獨立的功能節點來說是沒有問題的。假如伴隨著源源不斷的需求&#xff0c;前段項目會涌現出更多的功能節點&#xff0c;需要獨立部署運行。為了更好地管理這些獨立的功能節點&#xff0c;我們需要…

JdbcTemplate使用小結

org.springframework.jdbc.core.JdbcTemplate.query(String sql, Object[] args, RowMapper<StaffUnionVO> rowMapper) throws DataAccessException 1.自定義rowMapper public class StaffUnionVO implements RowMapper<StaffUnionVO>, Serializable {private stat…

RabbitMQ安裝和使用(和Spring集成)

一、安裝Rabbit MQ   Rabbit MQ 是建立在強大的Erlang OTP平臺上&#xff0c;因此安裝Rabbit MQ的前提是安裝Erlang。通過下面兩個連接下載安裝3.2.3 版本&#xff1a; 下載并安裝 Eralng OTP For Windows (vR16B03)運行安裝 Rabbit MQ Server Windows Installer (v3.2.3)具體…

單點登錄實現(spring session+redis完成session共享)

一、前言 項目中用到的SSO&#xff0c;使用開源框架cas做的。簡單的了解了一下cas&#xff0c;并學習了一下 單點登錄的原理&#xff0c;有興趣的同學也可以學習一下&#xff0c;寫個demo玩一玩。 二、工程結構 我模擬了 sso的客戶端和sso的服務端&#xff0c; sso-core中主要是…

maven deploy上傳私服出錯

error 內容如下 Failed to execute goal org.apache.maven.plugins:maven-deploy-plugin:2.5: deploy (default-deploy) on project XXX pom文件增加如下配置 <build><plugins><plugin><groupId>org.apache.maven.plugins</groupId><artifa…

加密策略

一、前言 這兩天研究了一下項目中的密碼加密&#xff0c;可以說得上是學到了很多。下面來大致說一下。 二、常用加密 1.單向加密算法 單向加密算法主要用來驗證數據傳輸的過程中&#xff0c;是否被篡改過。 BASE64 嚴格地說&#xff0c;屬于編碼格式&#xff0c;而非加密算法 …

Spring Data JPA: 實現自定義Repository

一、前言 由于項目中的 實體&#xff08;entity&#xff09;默認都是繼承一個父類&#xff08;包含一些公共的屬性&#xff0c;比如創建時間&#xff0c;修改時間&#xff0c;是否刪除&#xff0c;主鍵id&#xff09;。為了實現邏輯刪除&#xff0c;一般會自己實現RepositoryFa…

java json和對象互相裝換

java json和對象互相裝換 1.com.alibaba.fastjson.JSON 2.com.fasterxml.jackson.databind.ObjectMapper 轉載于:https://www.cnblogs.com/hujunzheng/p/6593491.html

js沖刺一下

js中__proto__和prototype的區別和關系 1.對象有屬性__proto__,指向該對象的構造函數的原型對象。  2.方法除了有屬性__proto__,還有屬性prototype&#xff0c;prototype指向該方法的原型對象。 深入淺出妙用 Javascript 中 apply、call、bind ***兩道面試題*** 關于js中偽數…

springmvc 源碼分析

DispatcherServlet的初始化流程 HandlerMapping - RequestMappingHandlerMapping初始化 DefaultAnnotationHandlerMapping 和RequestMappingHandlerMapping RequestToViewNameTranslator請求到視圖名稱的轉換 (如果沒有responsebody&#xff0c;并且沒有返回一個view&#xff0…

EntityManager的使用

1、最基礎的查詢 CriteriaBuilder cb entityManager.getCriteriaBuilder(); CriteriaQuery<User> cq cb.createQuery(User.class); Root<User> root cq.from(User.class); //from User cq.select(root); //select * from User javax.persistence.criteria.Predi…