当前位置:   article > 正文

dubbo yml配置_SpringBoot2.0完美整合Dubbo

yml里配置dubbo.provide.version

2019已经到了,希望我跟大家一样有一个新的开始,18年有再多的烦恼和不堪,那只是过去,接下来走好脚下的路就行了。

640

现在微服务越来越普遍,基本现在的新项目基本都是采用微服务的方式,这里我们暂不讨论微服务的好处什么的,我们常见的微服务架构就是SpirngCloud,它整合了各种组件,让我们的开发确实变得非常的方便,除了SpringCloud之外,其实还有另外的一种架构风格,SpringBoot + Dubbo,那么我们今天就来说一下,SpringBoot如何集成Dubbo做微服务架构。

640

项目结构

我们想要开发一个完善的微服务架构,那么做好各模块之间的依赖关系是至为重要的,那么我们先来看下我们的项目结构。

ecd9c8dc3d27415caf1c2c2d704728d9.png

我们构建这个项目其实主要是模拟这样一个流程,在订单模块去调用会员模块的接口。这里我就不说如何去安装zookeeper和Dubbo了,这个东西一百度一大把,如果实在有问题的话,底部留言吧,我看到会回复的。(建议大家尽量在Linux环境下去安装)

640

构建项目

接下来我们首先构建我们的父项目(springboot2.0-dubbo-parent),看需要引入哪些maven坐标。以下就是我们SpringBoot2.0整合Dubbo所需要的一些maven坐标,这里我并没有将整个pom文件放上来,主要太长,看着不方便,我已经把这个上传到了github上,下文有地址,可以点进去看。

 <parent>    <groupId>org.springframework.bootgroupId>    <artifactId>spring-boot-starter-parentartifactId>    <version>2.0.1.RELEASEversion>  parent>    <properties>    <project.build.sourceEncoding>UTF-8project.build.sourceEncoding>    <maven.compiler.source>1.8maven.compiler.source>    <maven.compiler.target>1.8maven.compiler.target>    <java-version>1.8java-version>    <curator-framework>4.0.1curator-framework>    <zookeeper.version>3.4.13zookeeper.version>    <dubbo.starter.version>0.2.0dubbo.starter.version>  properties>  <dependencies>        <dependency>      <groupId>org.springframework.bootgroupId>      <artifactId>spring-boot-starter-webartifactId>    dependency>    <dependency>      <groupId>com.alibaba.bootgroupId>      <artifactId>dubbo-spring-boot-starterartifactId>      <version>${dubbo.starter.version}version>    dependency>    <dependency>      <groupId>junitgroupId>      <artifactId>junitartifactId>      <version>4.11version>      <scope>testscope>    dependency>  dependencies>

接下来就是构建我们接口管理模块(springboot2.0-dubbo-public-api-service),所有模块的接口定义必须放在该模块下,这个模块中没有什么特别的maven坐标需要引入。

再下来构建会员接口模块(springboot2.0-dubbo-public-api-member-service),该模块是接口管理模块的子模块,这个模块中也没有什么需要特别需要引入的maven坐标。

然后我们就是来创建会员模块的实现模块(springboot2.0-dubbo-public-api-member-service-impl)了,这个模块是父项目下的一个模块,并不是存在于接口管理模块下的,不清楚可以看看上面的项目结构图。这个模块中需要引入一个maven坐标,因为他要去实现会员模块定义的接口,那么就必须把会员模块引入进来。

<dependency>    <groupId>com.xiaotaogroupId>    <artifactId>springboot2.0-dubbo-public-api-member-serviceartifactId>    <version>1.0-SNAPSHOTversion>dependency>

最后我们再来构建订单模块的表现层(springboot2.0-dubbo-order-web),这个模块中也是引入一个maven就好,因为它要去调用会员模块的接口,所以我们将会员模块的maven引入进来。

<dependency>    <groupId>com.xiaotaogroupId>    <artifactId>springboot2.0-dubbo-public-api-member-serviceartifactId>    <version>1.0-SNAPSHOTversion>dependency>
640

项目完善

到这里我们整个模块算是创建完了,我们剩下的就是去完善我们的项目。订单模块要调用会员模块的接口,那么我们首先应该在会员的接口模块创建一个接口。

public interface IMemberService {    // 会员接口    String getUser();}

会员接口的实现模块实现该接口

@Servicepublic class MemberServiceImpl implements IMemberService {    @Override    public String getUser() {        System.out.println("订单服务调用会员服务");        return "订单服务调用会员服务";    }}

注意:我们之前采用@Service是将我们的服务注册到容器中,但是我们现在使用的是Dubbo那么我们是将我们的服务注册到Dubbo中,所以大家这里导包的时候一定要注意。

78ac1becebc83dacb71301b4948706b5.png

这个模块是要启动起来的,所以我们还要写我们的启动类

@EnableDubbo@SpringBootApplicationpublic class AppMember {    public static void main(String[] args) {        SpringApplication.run(AppMember.class, args);    }}

注意:@EnableDubbo这个注解是开启Dubbo服务的,如果不加该注解,那么该服务是注册不到Dubbo中去的。

最后我们需要配置我们的dubbo,我们的dubbo将服务注册到哪里这些我们还没有进行配置,我们在springboot的resources下的application.yml中进行配置,具体配置如下

server:  port: 9002dubbo:  application:  ###########注册到注册中心的名称############    name: member  ###########采用协议和端口号################  protocol:  ###########采用dubbo协议####################    name: dubbo  ###########发布dubbo端口号为20880###########    port: 20881  registry:  ###########注册中心地址#####################    address: zookeeper://192.168.50.128:2181spring:  output:    ansi:      enabled: always

到这里我们订单这个模块就算搞定了,将会员实现这个模块启动起来,然后访问Dubbo地址(http://192.168.50.128:8080/dubbo-admin-2.6.0/),这里是我的地址,你要访问你的地址。

我们通过控制台可以看到Dubbo服务已经注册进去了。

c8a6a635822a8f769b0f43e6c7669802.png

我们再来看看Dubbo控制面板,可以看到这个服务的确已经注册进来了。

c38e971b79063a4a18d2cd03ee1f30d8.png

最后我们来说下,我们如果在订单模块去进行调用。首先我们在订单模块写一个接口去调用我们会员模块的接口。

@RestControllerpublic class OrderController {    @Reference    private IMemberService memberService;    @GetMapping("/orderToMember")    public String orderToMember() {        String user = memberService.getUser();        System.out.println(user);        return user;    }}

注意:@Reference 这个注解其实跟我们之前使用的@Autowired其实是一样的意思,但是我们之前将服务注册到了Dubbo中,所以我们需要从Dubbo中去取这个服务,所以就必须使用这个注解。

启动类

@SpringBootApplication@EnableDubbopublic class AppOrder {    public static void main(String[] args) {        SpringApplication.run(AppOrder.class, args);    }}

最后一步在配置下application.yml

server:  port: 8001dubbo:  application:  ##### 注册服务的名称    name: order  ##### 注册中心地址  registry:    address: zookeeper://192.168.50.128:2181  ##### 调用服务超时时间  consumer:    timeout: 5000spring:  output:    ansi:      enabled: always

到这里我们整个项目就写完了,那么最后我们启动订单模块,看看是否调用成功。

392003375bc1f6cb1f5e43f08cb073ef.png

最后通过测试我们可以发现,是没有问题的。我们再看看Dubbo的控制面板是否有消费者。

1551b1d49954d8945c9895f6814928b5.png

最后发现确实是有一个消费者的。

到这里我们SpringBoot2.0整合Dubbo就已经完成了。

项目地址:https://github.com/liangbintao/springboot2.0-dubbo

原创不易,给小涛点个底部的好看吧!

更多内容请关注“一个程序员的成长

c6c62342c60266562802c03bf1f1800c.png
本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号