不仅简化了 Dubbo 基于 xml 配置的方式,也提高了日常开发效率,甚至提升了工作幸福感。
创新互联服务项目包括王益网站建设、王益网站制作、王益网页制作以及王益网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,王益网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到王益省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!
为了节省亲爱的读者您的时间,请根据以下2点提示来阅读本文,以提高您的阅读收获效率哦。
如果您只有简单的 Java 基础和 Maven 经验,而不熟悉 Dubbo,本文档将帮助您从零开始使用 Spring Boot 开发 Dubbo 服务,并使用 EDAS 服务注册中心实现服务注册与发现。
如果您熟悉 Dubbo,可以选择性地阅读相关章节。
Spring Boot 使用极简的一些配置,就能快速搭建一个基于 Spring 的应用,提高的日常的开发效率。因此,如果您使用 Spring Boot 来开发基于 Dubbo 的应用,简化了 Bubbo 基于 xml 配置的方式,提高了日常开发效率,提升了工作幸福感。
EDAS 服务注册中心实现了 Dubbo 所提供的 SPI 标准的 注册中心扩展 ,能够完整地支持 Dubbo 服务注册、 路由规则 、 配置规则功能 。
EDAS 服务注册中心能够完全代替 ZooKeeper 和 Redis,作为您 Dubbo 服务的注册中心。同时,与 ZooKeeper 和 Redis 相比,还具有以下优势:
为了便于本地开发,EDAS 提供了一个包含了 EDAS 服务注册中心基本功能的轻量级配置中心。基于轻量级配置中心开发的应用无需修改任何代码和配置就可以部署到云端的 EDAS 中。
请您参考 配置轻量级配置中心 进行下载、启动及配置。推荐使用***版本。
1. 创建一个 Spring Boot 工程,命名为 spring-boot-dubbo-provider
这里我们以 Spring Boot 2.0.6.RELEASE 为例,在 pom.xml 文件中加入如下内容。
org.springframework.boot spring-boot-dependencies 2.0.6.RELEASE pom import org.springframework.boot spring-boot-starter-web org.springframework.boot spring-boot-actuator com.alibaba.boot dubbo-spring-boot-starter 0.2.0 com.alibaba.edas edas-dubbo-extension 1.0.0-SNAPSHOT
如果您需要选择使用 Spring Boot 1.x 的版本,请使用 Spring Boot 1.5.x 版本,对应的 com.alibaba.boot:dubbo-spring-boot-starter 版本为 0.1.0。
说明:Spring Boot 1.x 版本的生命周期即将在 2019 年 8 月 结束,推荐使用新版本开发您的应用。
2.开发 Dubbo 服务提供者
2.1 Dubbo 中服务都是以接口的形式提供的。因此需要开发一个接口,例如这里的 IHelloService ,接口里有若干个可被调用的方法,例如这里的 SayHello 方法。
- package com.alibaba.edas.boot;
- public interface IHelloService {
- String sayHello(String str);
- }
2.2 在服务提供方,需要实现所有以接口形式暴露的服务接口。例如这里实现 IHelloService 接口的类为 HelloServiceImpl 。
- package com.alibaba.edas.boot;
- import com.alibaba.dubbo.config.annotation.Service;
- @Service
- public class HelloServiceImpl implements IHelloService {
- public String sayHello(String name) {
- return "Hello, " + name + " (from Dubbo with Spring Boot)";
- }
- }
- ```
- *说明:** 这里的 Service 注解式 Dubbo 提供的一个注解类,类的全名称为:**com.alibaba.dubbo.config.annotation.Service** 。
2.3 配置 Dubbo 服务。在 application.properties/application.yaml 配置文件中新增以下配置:
- ```properties
- # Base packages to scan Dubbo Components (e.g @Service , @Reference)
- dubbo.scan.basePackages=com.alibaba.edas.boot
- dubbo.application.name=dubbo-provider-demo
- dubbo.registry.address=edas://127.0.0.1:8080
- ```
- **说明:**
- * 以上三个配置没有默认值,必须要给出具体的配置。
- * dubbo.scan.basePackages 的值是开发的代码中含有 com.alibaba.dubbo.config.annotation.Service 和 com.alibaba.dubbo.config.annotation.Reference 注解所在的包。多个包之间用逗号隔开。
- * dubbo.registry.address 的值前缀必须是一个 **edas://** 开头,后面的ip地址和端口指的是轻量版配置中心
3. 开发并启动 Spring Boot 入口类
- ```java
- package com.alibaba.edas.boot;
- import org.springframework.boot.SpringApplication;
- import org.springframework.boot.autoconfigure.SpringBootApplication;
- @SpringBootApplication
- public class DubboProvider {
- public static void main(String[] args) {
- SpringApplication.run(DubboProvider.class, args);
- }
- }
4.登录轻量版配置中心控制台 http://127.0.0.1:8080,在左侧导航栏中单击服务列表 ,查看提供者列表。可以看到服务提供者里已经包含了 com.alibaba.edas.IHelloService,且可以查询该服务的服务分组和提供者 IP。
1. 创建一个 Spring Boot 工程,命名为 spring-boot-dubbo-consumer。
这里我们以 Spring Boot 2.0.6.RELEASE 为例,在 pom.xml 文件中加入如下内容。
org.springframework.boot spring-boot-dependencies 2.0.6.RELEASE pom import org.springframework.boot spring-boot-starter-web org.springframework.boot spring-boot-actuator com.alibaba.boot dubbo-spring-boot-starter 0.2.0 com.alibaba.edas edas-dubbo-extension 1.0.0-SNAPSHOT
如果您需要选择使用 Spring Boot 1.x 的版本,请使用 Spring Boot 1.5.x 版本,对应的 com.alibaba.boot:dubbo-spring-boot-starter 版本为 0.1.0。
说明:Spring Boot 1.x 版本的生命周期即将在 2019 年 8 月 结束,推荐使用新版本开发您的应用。
2.开发 Dubbo 消费者
2.1 在服务消费方,需要引入所有以接口形式暴露的服务接口。例如这里 IHelloService 接口。
- package com.alibaba.edas.boot;
- public interface IHelloService {
- String sayHello(String str);
- }
- ```
2.2 Dubbo 服务调用。例如需要在 Controller 中调用一次远程 Dubbo 服务,开发的代码如下所示:
- ```java
- package com.alibaba.edas.boot;
- import com.alibaba.dubbo.config.annotation.Reference;
- import org.springframework.web.bind.annotation.PathVariable;
- import org.springframework.web.bind.annotation.RequestMapping;
- import org.springframework.web.bind.annotation.RestController;
- @RestController
- public class DemoConsumerController {
- @Reference
- private IHelloService demoService;
- @RequestMapping("/sayHello/{name}") public String sayHello(@PathVariable String name) { return demoService.sayHello(name);
- }
- }
说明:这里的 Reference 注解是 com.alibaba.dubbo.config.annotation.Reference 。
2.3 配置 Dubbo 服务。在 application.properties/application.yaml 配置文件中新增以下配置:
- dubbo.application.name=dubbo-consumer-demo
- dubbo.registry.address=edas://127.0.0.1:8080
- ```
- **说明:**
- * 以上两个配置没有默认值,必须要给出具体的配置。
- * dubbo.registry.address 的值前缀必须是一个 **edas://** 开头,后面的ip地址和端口指的是轻量版配置中心
3.开发并启动 Spring Boot 入口类
- ```java
- package com.alibaba.edas.boot;
- import org.springframework.boot.SpringApplication;
- import org.springframework.boot.autoconfigure.SpringBootApplication;
- @SpringBootApplication
- public class DubboConsumer {
- public static void main(String[] args) {
- SpringApplication.run(DubboConsumer.class, args);
- }
- }
- 登录
4. 轻量版配置中心控制台 http://127.0.0.1:8080,在左侧导航栏中单击 服务列表 ,再在服务列表页面选择 调用者列表 ,可以看到包含了 com.alibaba.edas.IHelloService,且可以查看该服务的服务分组和调用者 IP。
curl http://localhost:17080/sayHello/EDAS
- Hello, EDAS (from Dubbo with Spring Boot)
curl http://localhost:8080/sayHello/EDAS
- Hello, EDAS (from Dubbo with Spring Boot)
网站栏目:高效开发Dubbo?用SpringBoot可得劲!
当前网址:http://www.mswzjz.cn/qtweb/news28/260278.html
攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能