dubbo高级应用:
1,dubbo直连方式
默认的连接服务提供端的端口是20880,用直连的的方式可以指定提供端的url(接口地址--可以通过配置也可以通过java实现(类似泛化))和这个具体服务暴露的端口(一个合作企业一个端口)
用直连的方式可以绕过zk等注册中心(用直连的方式可以不用注册中心而用起dubbo)
2,一个系统既可以配成提供端也可以配成消费端,配合直连方式指定消费哪个服务提供的那个接口
3,用配置的方式最后的原理还是通过dubbo的客户端,通过ip+端口获取服义务和暴露服务
@Slf4j
public class RealReference {
//用于将bean关系注入到当前的context中
@Autowired
private ApplicationContext applicationContext;
@Test
public void realReference() {
String url = "dubbo://localhost:21880/com.demo.service.DemoService";//更改不同的Dubbo服务暴露的ip地址&端口
ReferenceBean<DemoService> referenceBean = new ReferenceBean<DemoService>();
referenceBean.setApplicationContext(applicationContext);
referenceBean.setInterface(com.demo.service.DemoService.class);
referenceBean.setUrl(url);
try {
referenceBean.afterPropertiesSet();
DemoService demoService = referenceBean.get();
System.out.print(demoService.deal("Tester"));
} catch (Exception e) {
e.printStackTrace();
}
}
基于Dubbo的动态远程调用
问题:为解决实际业务,由我方提供接口定义,具体的实现交给第三方处理。然后由第三方将开发好的服务注册到他们自己的Dubbo服务上,由我方调用。问题就在于多个第三方开发具体实现,对于我方而言如果按照配置方式切入调用是无法满足这种需求。所以找寻了dubbo的根据URL远程调用服务的机制。以下是Demo
关于Zookeeper的安装&配置此次不详细介绍了。
服务调用方
定义服务接口:
- package com.demo.service;
- /**
- * Desc:
- * Mail:v@terminus.io
- * author:Michael Zhao
- * Date:2015-03-04.
- */
- public interface DemoService {
- public String deal(String someting);
- }
定义Consumer配置文件:
- <?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: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:application name="dubbo_consumer" />
- </beans>
远程调用测试类:
- package com.demo.test;
- import com.alibaba.dubbo.config.spring.ReferenceBean;
- import com.demo.service.DemoService;
- import lombok.extern.slf4j.Slf4j;
- import org.junit.Test;
- import org.junit.runner.RunWith;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.context.ApplicationContext;
- import org.springframework.test.context.ContextConfiguration;
- import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
- /**
- * Desc:测试Dubbo实时映射bean
- * Mail:v@terminus.io
- * author:Michael Zhao
- * Date:2015-03-04.
- */
- @RunWith(SpringJUnit4ClassRunner.class)
- @ContextConfiguration(locations = {
- "classpath:/spring/root-context.xml"
- })
- @Slf4j
- public class RealReference {
- //用于将bean关系注入到当前的context中
- @Autowired
- private ApplicationContext applicationContext;
- @Test
- public void realReference() {
- String url = "dubbo://localhost:21880/com.demo.service.DemoService";//更改不同的Dubbo服务暴露的ip地址&端口
- ReferenceBean<DemoService> referenceBean = new ReferenceBean<DemoService>();
- referenceBean.setApplicationContext(applicationContext);
- referenceBean.setInterface(com.demo.service.DemoService.class);
- referenceBean.setUrl(url);
- try {
- referenceBean.afterPropertiesSet();
- DemoService demoService = referenceBean.get();
- System.out.print(demoService.deal("Tester"));
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
- }
服务提供方实现接口:
实现1:
- package com.dubboT.service;
- import com.demo.service.DemoService;
- import lombok.extern.slf4j.Slf4j;
- import org.springframework.stereotype.Service;
- /**
- * Desc:Dubbo动态加载服务测试
- * Mail:v@terminus.io
- * author:Michael Zhao
- * Date:2015-03-04.
- */
- @Service
- @Slf4j
- public class DemoServiceImpl implements DemoService {
- @Override
- public String deal(String s) {
- return "My Name is " + s;
- }
- }
实现2:
- package com.dubboT.service;
- import com.demo.service.DemoService;
- /**
- * Desc:
- * Mail:v@terminus.io
- * author:Michael Zhao
- * Date:2015-03-05.
- */
- public class DemoServiceNImpl implements DemoService {
- @Override
- public String deal(String s) {
- return "This is DemoServiceNImpl " + s;
- }
- }
分别在不同的端口暴露Service的实现
- <?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: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
- ">
- <bean id="demoService" class="com.rabbit.service.DemoServiceImpl" />
- <!-- 提供方应用信息,用于计算依赖关系 -->
- <dubbo:application name="dubboProvider" />
- <!-- 使用zookeeper注册中心暴露服务地址 -->
- <dubbo:registry address="zookeeper://127.0.0.1:2181" />
- <!-- 用dubbo协议在20880端口暴露服务 -->
- <dubbo:protocol name="dubbo" port="20880" />
- <!-- 声明需要暴露的服务接口 -->
- <dubbo:service interface="com.elasticsearch.service.DemoService" ref="demoService" />
- </beans>
DemoServiceNImpl在21800端口暴露
- <?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: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
- ">
- <bean id="demoService" class="com.rabbit.service.DemoServiceNImpl" />
- <!-- 提供方应用信息,用于计算依赖关系 -->
- <dubbo:application name="dubboProvider" />
- <!-- 使用zookeeper注册中心暴露服务地址 -->
- <dubbo:registry address="zookeeper://127.0.0.1:2181" />
- <dubbo:protocol name="dubbo" port="21880" />
- <!-- 声明需要暴露的服务接口 -->
- <dubbo:service interface="com.elasticsearch.service.DemoService" ref="demoService" />
- </beans>
分别提供服务
- import org.springframework.context.support.ClassPathXmlApplicationContext;
- /**
- * Desc:
- * Mail:v@terminus.io
- * author:Michael Zhao
- * Date:2015-03-04.
- */
- public class DubboProviderMain {
- public static void main(String[] args) throws Exception {
- ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext(new String[] {"spring/rabbit-dubbo-provider.xml"});
- context.start();
- System.in.read();
- }
- }
- import org.springframework.context.support.ClassPathXmlApplicationContext;
- /**
- * Desc:
- * Mail:v@terminus.io
- * author:Michael Zhao
- * Date:2015-03-04.
- */
- public class DubboProvider2Main {
- public static void main(String[] args) throws Exception {
- ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext(new String[] {"spring/dubbo-provider.xml"});
- context.start();
- System.in.read();
- }
- }
启动服务后,运行RealReference实现根据URL调用远程服务
- SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".
- SLF4J: Defaulting to no-operation (NOP) logger implementation
- SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details.
- log4j:WARN No appenders could be found for logger (com.alibaba.dubbo.common.logger.LoggerFactory).
- log4j:WARN Please initialize the log4j system properly.
- log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.
- My Name is Tester
- Process finished with exit code 0
相关推荐
### Dubbo高级视频教程知识点概览 #### 一、Dubbo概述与分布式系统基础 - **Dubbo简介**:Dubbo是一款高性能、轻量级的开源Java RPC框架,旨在为服务治理提供简单、全面的解决方案。 - **分布式系统概念**:分布式...
- 视频教程提供了从初级到高级的全面学习资料,覆盖了Dubbo的核心概念、架构原理、实际操作等多个方面,是学习Dubbo不可多得的好资源。 - 除了视频外,还可以参考官方文档、社区论坛、博客文章等多种形式的学习资源...
### Dubbo应用开发教程知识点详解 #### 一、Dubbo能解决的问题 1. **透明化的远程方法调用**:Dubbo支持透明化的远程方法调用(Remote Procedure Call, RPC),使得开发者可以像调用本地方法一样调用远程方法,...
【标题】:“Dubbo高级教程及源码.zip” 【描述】:“Dubbo是一个高性能、轻量级的开源Java RPC框架,它提供了丰富的监控、服务治理功能,是阿里巴巴集团的重要技术组件。这个压缩包包含了Dubbo的高级教程以及源码...
### Dubbo视频教程--高级篇--第24节--简易版支付系统介绍知识点 #### 1. Dubbo框架与分布式系统架构 Dubbo是一款高性能、轻量级的Java RPC框架,由阿里巴巴开源。它提供了高可用的服务治理能力,在分布式系统中尤为...
### Apache Dubbo 高级特性:服务版本与分组 #### 一、服务版本管理 在微服务架构中,服务的频繁迭代与升级是常态化的操作。为了保证服务升级过程中的稳定性,避免对现有服务调用者的负面影响,Apache Dubbo 引入...
3. **Dubbo-demo**: 示例项目通常会展示Dubbo的基本用法,例如如何创建服务提供者和服务消费者,如何配置服务接口和实现,如何进行服务注册和调用,以及如何利用Dubbo的其他高级特性,如集群策略、过滤器、监控等。...
《Dubbo技术详解与实战应用》 Dubbo是一款由阿里巴巴开源的高性能、轻量级的服务治理框架,它致力于提供一个简单、高效的分布式服务解决方案。在Java世界里,Dubbo已经成为了微服务架构的重要组成部分,其核心特性...
Dubbo是由阿里巴巴开源的一款分布式服务框架,旨在帮助开发者构建高性能、可扩展的服务化应用程序。它支持多种协议和服务注册发现机制,可以方便地与Spring等主流Java框架进行集成。通过Dubbo,开发者能够轻松实现...
6. `<dubbo:provider>` 和 `<dubbo:consumer>`:这两个元素是服务提供者和服务消费者的高级配置,可以用来设置一些全局的属性。 7. `<dubbo:method>` 和 `<dubbo:argument>`:细化服务方法和参数的配置,如异步调用...
【Dubbo快速掌握:构建远程调用应用】 Dubbo,由阿里开源的SOA服务治理框架,实际上更常被理解为一个高效的RPC(Remote Procedure Call)框架。它提供了丰富的功能,包括但不限于服务发现、负载均衡、容错机制、...
【Dubbo入门到精通架构高级课程】是一门深入解析Dubbo框架的全面教程,旨在帮助初学者和进阶者理解并掌握这个强大的Java分布式服务框架。该课程包含了视频讲解、课件资料以及配套的源码,确保学习者能理论与实践相...
【Dubbo快速掌握:基础应用详解】 Dubbo,由阿里巴巴开源,是一个强大的SOA服务治理...在实际开发中,还需要深入学习Dubbo的其他高级特性,如过滤器、拦截器、监控、调优等,以便更好地利用其功能来优化微服务架构。
《Dubbo源码分析系列》是一份深入探讨Java开源...通过对《Dubbo源码分析系列》的学习,开发者不仅可以掌握Dubbo的基本使用,还能深入理解其设计思想,从而更好地在实际项目中应用和优化Dubbo,提高系统的稳定性和效率。
Dubbo的设计目标是透明化的远程方法调用,就像本地调用一样简单,同时具备服务自动注册、服务分组、故障切换、服务监控等高级特性。 【Zookeeper在Dubbo中的作用】 Zookeeper是Apache的一个分布式协调服务项目,它...
本压缩包集合了深入理解Dubbo框架的重要资料,涵盖了从基础概念到高级应用的多个方面,旨在帮助读者全面掌握Dubbo的核心技术和应用实践。以下是各个文档的主要内容概述: 1. **Dubbo实现原理.doc**: 这份文档详细...
系统的学习Dubbo技术栈,掌握Dubbo、Zookeeper架构原理及应用。 lZookeeper 分布式CAP原则 2PC、3PC Paxos、ZAB ZK单机&集群 快速入门 源码解析 场景应用 分布式锁、队列 1Dubbo RPC核心 RPC实现 容错&治理 IO模型&...
《Dubbo入门与高级特性深度解析》 Dubbo,作为阿里巴巴开源的一款高性能、轻量级的Java服务治理框架,已经成为微服务架构中的重要组件。它提供了包括服务注册、服务发现、负载均衡、调用链跟踪等在内的核心功能,极...
1. **Dubbo**:Apache Dubbo 是一款高性能、轻量级的开源 Java RPC 框架,它提供了服务治理、监控等高级功能,旨在提高开发效率和提升系统的可扩展性。 2. **服务治理**:包括服务的注册、发现、调用、路由、负载...
### 二、Dubbo高级特性 #### 2.1 负载均衡 Dubbo 提供了多种负载均衡策略,如随机、轮询、最少活跃调用数等,可以根据不同的业务场景选择合适的策略来提高系统的可用性和响应速度。 #### 2.2 服务降级 在高并发或...