`
y806839048
  • 浏览: 1121163 次
  • 性别: Icon_minigender_1
  • 来自: 上海
文章分类
社区版块
存档分类
最新评论

dubbo注意的问题,注入问题,接口中的bo应该实现序列化,否则服务注册失败

阅读更多

dubbo注意的问题,接口中的bo应该实现序列化,否则服务注册失败

 

 

用注解的服务注入1,用dubbo的@services,2,服务的引用用dubbo的@Refrence

 

 

 

 

1,在不使用dubbo注解的时候,service可以注入给消费端任何在spring容器管理的类

 

 

2,使用duboo注解的时候,除了配置spring的扫路径,还需配置dubbo的扫描路径

 

   dubbo在除了controller的控制层用注解还是注入不了用,在客户端配置文件dubbo.xml引入接口(一般这个就可以,配置化的只要在sping管理内都可以),还是不行用beanUntil.getBean()(此时需要配置化好,对于spring mvc spring这种父子容器context不共享的问题(夫不可拿子,或者先于5spring初始化,初始也需要用beanUntil.getBean()));

 

 

<!--dubbo相关配置  -->消费方,服务方都需要

<dubbo:annotation package="com.houbank" />

<!-- dubbo reference 注解 并非给 spring 管理,dubbo 通过扫描  将 其 反身赋值,故  dubbo扫描需要在  controller(初始化完成)之前,这也

   涉及到  该注解 在 controller中  是 获取 dispatcher context空器中的 对象,而非  父容器  context  容器,故  BeanUtils  也是无法直接获取值的。-->

<dubbo:annotation package="com.houbank.incoming.web.controller, com.houbank.incoming.web.util" />

<!-- dubbo 扫描和spring扫描开启 -->

<!--<context:component-scan base-package="com.houbank.incoming.web.controller" />  -->

<context:component-scan base-package="com.houbank" />

 

   服务注册:

@Service  ——》com.alibaba.dubbo.config.annotation

 

 

   消费方:

 

 

@Reference  ——》com.alibaba.dubbo.config.annotation

 

 

 

如果是简单的使用这种注入的方式只能注入到controller   ,需要注入给@Component或消费端任意spring容器管理的类,需要用配置文件的方式加强

 

 

消费端:

 <!-- 这里需要显式配置,否则 通过BeanUtil的方式无法获取到bean,解决velocity自定义模板注入问题 -->  

    <dubbo:reference id="cacheFacade" interface=" com.houbank.incoming.api.CacheFacade" check="false"/> 

    <dubbo:reference id="codeLibraryFacade" interface=" com.houbank.incoming.api.CodeLibraryFacade" check="false"/>

    <dubbo:reference id="weixinBaseInfoFacade" interface=" com.houbank.incoming.api.WeixinBaseInfoFacade" check="false"/>

    <dubbo:reference id="financialSalesRoleFacade" interface=" com.houbank.incoming.api.FinancialSalesRoleFacade" check="false"/>

    <dubbo:reference id="financialSalesEmploymentFacade" interface="com.houbank.incoming.api.FinancialSalesEmploymentFacade" check="false" />

    <dubbo:reference id="financialSalesTeamFacade" interface="com.houbank.incoming.api.FinancialSalesTeamFacade" check="false" />

    <dubbo:reference id="financialSalesCustomersFacade" interface="com.houbank.incoming.api.FinancialSalesCustomersFacade" check="false" />

    <dubbo:reference id="financialSalesStatisticsFacade" interface="com.houbank.incoming.api.FinancialSalesStatisticsFacade" check="false" />

    <dubbo:reference id="financialSalesFuncFacade" interface=" com.houbank.incoming.api.FinancialSalesFuncFacade" check="false"/>

    <dubbo:reference id="financialSalesUserFacade" interface=" com.houbank.incoming.api.FinancialSalesUserFacade" check="false"/>

 

  @Reference

    private FinancialSalesFuncFacade financialSalesFuncFacade;

 

 

  public FinancialSalesFuncFacade getFinancialSalesFuncFacade() {

        return financialSalesFuncFacade;

    }

 

    public void setFinancialSalesFuncFacade(FinancialSalesFuncFacade financialSalesFuncFacade) {

        this.financialSalesFuncFacade = financialSalesFuncFacade;

    }

 

 

 

 

 

 

 

 

 

 

dubbo在调试的时候有多个服务提供方,由指定的消费进去后,会随机一个服务方,后面服务方返回的也是到这个消费方,可以通过服务版本的方式控制乱跳

 

即:

消费方,服务方在第一次启动的时候就向注册中心获取服务,或者消费者列表(定时同步)

 

后续消费方根据自己内存的服务路由选择服务方,服务方根据request packget中带来的请求方的ip,端口返回给之前请求的消费端

 

 

分享到:
评论

相关推荐

    Dubbo调用java接口程序

    3. **配置服务提供者**:在`dubbo-provider.xml`中配置服务提供者,包括接口名、实现类、注册中心等信息。 ```xml &lt;dubbo:service interface=...

    dubbo 对外提供和使用接口方法

    通过上述内容,我们可以清晰地了解到在Dubbo中如何定义和提供服务接口,以及如何进行服务的消费。此外,还详细介绍了不同通信协议的选择及其配置方式,这对于构建高效稳定的微服务架构具有重要意义。在实际项目开发...

    dubbo接口测试调试工具

    前段时间排查某问题的时候,想要快速知道某些dubbo接口(三无)的响应结果,但不想启动项目(因为这些项目不是你负责的,不会部署而且超级笨重),也不想新建一个dubbo客户端项目(占地方),也不想开telnet客户端...

    maven打包dubbo服务接口(maven-assembly-plugin)

    Dubbo的服务提供者和服务消费者都需要在`dubbo.properties`或XML配置文件中指定相应的配置,如服务接口、实现类、注册中心等。例如: ```properties dubbo.application.name=MyDubboService dubbo.protocol.name=...

    dubbo服务接口

    在分布式系统架构中,服务接口的设计与实现是至关重要的环节。Dubbo,作为阿里巴巴开源的一款高性能、轻量级的服务治理框架,为开发者提供了强大的服务接口支持。本文将深入探讨Dubbo服务接口的概念、设计原则以及...

    dubbo提供 rest 服务接口

    确保服务类有对应的实现,并且使用 `@Service` 注解标记,以便 Dubbo 能够发现和注册该服务。 ### 6. 配置消费者 在服务消费者端,可以通过 Dubbo 的 `RestTemplate` 或自定义 `FeignClient` 来调用 REST 服务。...

    动态注册dubbo提供者接口

    在dubbo服务运行过程中,上传正确的java代码文件,自动编译生成class并注册到dubbo zk 中,可以正常dubbo invoke来调用。整个过程服务不用重启。我写了个框架并命名为D-Unit。

    dubbo服务注册到eureka.zip

    完成以上步骤后,Dubbo 服务就可以顺利地注册到 Eureka 中,实现服务的动态注册与发现。这种集成方式有助于在微服务架构中构建更灵活、可扩展的系统,同时也方便了服务的管理和监控。需要注意的是,在实际应用中,还...

    dubbo的简单实现

    当对象没有实现序列化接口时,可能会导致序列化失败。需要确保所有传输的对象都实现了序列化接口。 #### 总结 Dubbo作为一种成熟的分布式服务框架,不仅提供了服务间的高效通信,还解决了服务治理、负载均衡等一...

    自定实现dubbo服务导出

    在实现自定义Dubbo服务导出时,我们可能会定义一个`&lt;dubbo:service&gt;`标签,它包含服务接口、实现类、注册中心等信息。标签解析器将处理这些信息,并在Spring初始化时自动完成服务的注册。 接下来,让我们关注Spring...

    手写 dubbo

    4. **服务接口与实现**:在 Java 中,定义服务接口并提供其实现是服务发布的起点。手写 Dubbo 需要设计接口的定义、服务实现以及如何暴露服务。 5. **Spring 集成**:Dubbo 可以很好地集成到 Spring 框架中,方便...

    dubbo-api服务

    "dubbo-api服务"就是这样的一个组件,它是基于阿里巴巴开源的Dubbo框架构建的服务器端接口服务。Dubbo是一个高性能、轻量级的Java远程服务调用框架,它使得服务提供者和服务消费者之间能够高效地进行通信。 首先,...

    服务治理工具dubbo

    Dubbo是一款由阿里巴巴开源的高性能、轻量级的服务治理框架,它致力于提供一套完整的服务治理解决方案,包括服务注册、服务发现、服务调用、负载均衡、熔断机制等核心功能,是分布式微服务架构中的重要组件。...

    springboot+quartz集群:通过动态配置调度dubbo接口/http接口代码实现

    在项目中,我们可以通过Quartz来调度Dubbo接口,使得定时任务能够调用远程服务。HTTP Job则是通过HTTP请求来执行任务,这种方式更加灵活,可以调用任何暴露HTTP接口的服务。 要实现动态配置,我们需要一个用户界面...

    DUBBO 中文帮助文档

    Dubbo 基于 Java SPI(Service Provider Interface)提供了一套扩展机制,允许开发者自定义实现 Dubbo 的各个组件,如协议、序列化、注册中心等。 综上,Dubbo 中文 API 提供了丰富的配置选项,使得开发者能够灵活...

    Dubbo+zookeeper调用java接口

    本示例"Dubbo+zookeeper调用java接口"将展示如何在Dubbo环境中利用Zookeeper来实现服务的注册和调用。 首先,理解Dubbo的核心概念: 1. **服务提供者(Provider)**:暴露服务的服务提供方。 2. **服务消费者...

    分布式框架dubbo实现

    在`dubbo-provider`目录下,通常包含了服务接口定义(如`dubbo-api`项目中的`ServiceInterface.java`)、服务实现类(如`ServiceImpl.java`)以及相关的配置文件(如`dubbo.properties`)。配置文件中,我们需要设置...

    Dubbo无法访问远程Zookeeper已注册服务的问题解决方案

    Dubbo无法访问远程Zookeeper已注册服务的问题解决方案 在使用Dubbo框架时,可能会遇到无法访问远程Zookeeper已注册服务的问题。今天,我们将分享一篇关于Dubbo无法访问远程Zookeeper已注册服务的问题解决方案。 ...

    dubbo+zookeeper实现服务注册发现 dubbo+nacos实现服务注册发现

    在分布式系统中,服务注册与发现是至关重要的一个环节,它允许服务提供者将自己的服务注册到一个中心化的服务中心,而服务消费者则可以通过这个服务中心来发现并调用所需的服务。本篇将详细介绍如何使用Dubbo结合...

Global site tag (gtag.js) - Google Analytics