java 探花交友项目实战篇1Dubbo 提供者消费者 dubbo高级特性 启动检查 多版本 超时与重试 负载均衡

Dubbo的前世今生

 

SOA架构

Dubbo介绍

Dubbo是阿里巴巴公司开源的一个高性能、轻量级的 Java RPC 框架。

致力于提供高性能和透明化的 RPC 远程服务调用方案,以及 SOA 服务治理方案。

官网:http://dubbo.apache.org

目前Dubbo在企业中有两种开发思路

 feign不适合高并发,所以我们替换成Dubbo

Dubbo的快速入门

Dubbo的基本架构

 

nacos:

安装DubboAdmin

修改配置:Dubbo-admin-server/src/main/resource下的appilication.properties文件

 这里我们修改成nacos以及nacos的端口8848

 在dubbo-admin目录下打开终端输入命令

mvn --projects dubbo-admin-server spring-boot:run

然后

 

搭建环境

(1)创建user-provider模块导入依赖

<dependencies>
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
    </dependency>
    <!--mybatis-->
    <dependency>
        <groupId>org.mybatis.spring.boot</groupId>
        <artifactId>mybatis-spring-boot-starter</artifactId>
    </dependency>

    <!--dubbo的起步依赖-->
    <dependency>
        <groupId>org.apache.dubbo</groupId>
        <artifactId>dubbo-spring-boot-starter</artifactId>
        <version>3.0.11</version>
    </dependency>

    <dependency>
        <groupId>org.apache.dubbo</groupId>
        <artifactId>dubbo-registry-nacos</artifactId>
        <version>3.0.11</version>
    </dependency>
</dependencies>

(4):配置

server:
  port: 18081
spring:
  datasource:
    url: jdbc:mysql://localhost:3306/dubbo-demo?useSSL=false
    username: root
    password: 123
    driver-class-name: com.mysql.jdbc.Driver
  application:
    name: user-provider
logging:
  level:
    cn.itcast: debug
  pattern:
    dateformat: HH:mm:ss:SSS
#配置dubbo提供者
#dubbo协议和访问端口
dubbo:
  protocol:
    name: dubbo
    port: 20881
    #注册中心地址
  registry:
    address: nacos://127.0.0.1:8848
    #dubbo注解的包扫描
  scan:
    base-packages: cn.itcast.user.service

 依赖:

<dependencies>
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>


    <!--dubbo的起步依赖-->
    <dependency>
        <groupId>org.apache.dubbo</groupId>
        <artifactId>dubbo-spring-boot-starter</artifactId>
        <version>3.1.4</version>
    </dependency>

    <dependency>
        <groupId>org.apache.dubbo</groupId>
        <artifactId>dubbo-registry-nacos</artifactId>
        <version>3.1.4</version>
    </dependency>
</dependencies>

然后我们访问消费者的方法,,返回成功就可以了

Dubbo的最佳实践

 抽取为独立模块,然后我们在各自的pom引入该模块的依赖就可以了:

<dependency>
    <groupId>cn.itcast</groupId>
    <artifactId>user-api</artifactId>
    <version>1.0-SNAPSHOT</version>
</dependency>

序列化

 所以我们的domain类,都实现Serializable就行了

Dubbo的高级特性 

启动检查

多版本

 

 

 我们通过版本号,保证升级的平稳过渡

超时与重试

dubbo 利用超时机制来解决这个问题(使用timeout属性配置超时时间,默认值1000,单位毫秒) 

若超时时间较短,当网络波动时请求就会失败,Dubbo通过重试机制避免此类问题的发生

一次没有成功,默认会再进行两次请求,可以通过consumer.retries设置(推荐改成0)

负载均衡

以上均可以在DubboReference里设置参数:

SpringCloud整合Dubbo

为什么需要Dubbo? 

 

Spring Cloud Alibaba提供了微服务开发的一站式解决方案,内部包含开发分布式应用微服务的必需组件,通过 Spring Cloud编程模型轻松整合Dubbo完成微服务调用 官方地址: https://github.com/alibaba/spring-cloud-alibaba

 

 

 模块分析:

1、创建dubbo-api模块,引入依赖

2、抽取公共接口

import cn.itcast.dubbo.domain.User;

public interface UserService {     User queryById(Long id); }

 父工程加入SpringCloud Alibaba依赖

<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-alibaba-dependencies</artifactId>
    <version>2.2.5.RELEASE</version>
    <type>pom</type>
    <scope>import</scope>
</dependency>

消费者和提供者引入nacos注册中心和Dubbo依赖

<!--nacos注册中心的依赖-->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>

<!--springcloud alibaba dubbo依赖   -->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-dubbo</artifactId>
</dependency>

 

 

 

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据提供的引用内容,Dubbo提供者启动不了可能有多种原因。以下是一些可能的解决方法: 1. 检查Zookeeper连接:Dubbo提供者需要连接到Zookeeper进行服务注册和发现。请确保Zookeeper已正确启动,并且提供者配置文件中的Zookeeper地址和端口与实际情况相匹配。 2. 检查Dubbo配置:请确保提供者Dubbo配置文件中的各项配置正确无误。特别是检查提供者的服务接口、版本号、协议等配置是否与消费者的配置相匹配。 3. 检查端口占用:如果提供者的端口被其他进程占用,可能会导致启动失败。请确保提供者的端口没有被其他进程占用。 4. 检查依赖是否完整:Dubbo提供者可能依赖于其他的jar包或者类库。请确保所有的依赖都已正确引入,并且版本兼容。 5. 检查日志输出:查看提供者的日志输出,可以帮助定位问题所在。根据日志中的错误信息,可以进一步排查问题。 以下是一个示例的Dubbo提供者启动失败的解决方法: ```java // 引入Dubbo依赖 <dependency> <groupId>com.alibaba.boot</groupId> <artifactId>dubbo-spring-boot-starter</artifactId> <version>2.7.3</version> </dependency> // 配置Dubbo提供者 @Configuration @EnableDubbo(scanBasePackages = "com.example.provider") public class DubboProviderConfig { @Bean public ProviderConfig providerConfig() { ProviderConfig providerConfig = new ProviderConfig(); providerConfig.setTimeout(5000); return providerConfig; } @Bean public ApplicationConfig applicationConfig() { ApplicationConfig applicationConfig = new ApplicationConfig(); applicationConfig.setName("dubbo-provider"); return applicationConfig; } @Bean public RegistryConfig registryConfig() { RegistryConfig registryConfig = new RegistryConfig(); registryConfig.setAddress("zookeeper://127.0.0.1:2181"); return registryConfig; } @Bean public ProtocolConfig protocolConfig() { ProtocolConfig protocolConfig = new ProtocolConfig(); protocolConfig.setName("dubbo"); protocolConfig.setPort(20880); return protocolConfig; } } // 提供者服务接口 public interface HelloService { String sayHello(String name); } // 提供者服务实现 @Service(version = "1.0.0") public class HelloServiceImpl implements HelloService { @Override public String sayHello(String name) { return "Hello, " + name; } } // 启动类 @SpringBootApplication public class DubboProviderApplication { public static void main(String[] args) { SpringApplication.run(DubboProviderApplication.class, args); } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值