以前的几篇文章把dubbo服务层都介绍完毕,本篇文章我们主要写web层如何调用服务层的方法。文章底部附带源码。java
启动服务git
服务启动时,会向zk注册本身提供的服务,zk则会记录服务提供者的IP地址以及暴露的接口名称,经过zkCli.cmd 查看树形结构,具体命令以下:github
一、ls / web
展现两个目录:dubbo、zookeeper,下面主要看一下dubbo目录spring
二、ls /dubboapache
能够看到注册到dubbo目录下的接口了api
三、ls /dubbo/com.example.dubbo.demo.api.DemoApi浏览器
服务提供者的具体信息就在providers目录里了springboot
服务消费者-web层app
该层依赖api、model层,调用服务提供者对外提供的服务,所以须要配置服务消费者的dubbo信息,主要使用到的dubbo标签以下:
dubbo:application、dubbo:registry、dubbo:reference,具体配置信息以下:
<?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://code.alibabatech.com/schema/dubbo http://code.alibabatech.com/schema/dubbo/dubbo.xsd http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd"> <!-- 定义了提供方应用信息,用于计算依赖关系;在 dubbo-admin 或 dubbo-monitor 会显示这个名字 --> <dubbo:application name="${my.dubbo.application.name}" owner="ll" organization="ll" /> <!-- 使用 zookeeper 注册中心暴露服务,注意要先开启 zookeeper--> <dubbo:registry id="zookeeper-registry" protocol="${my.dubbo.registry.protocol}" address="${my.dubbo.registry.address}" /> <dubbo:monitor protocol="registry"/> <!-- 生成远程服务代理,能够和本地bean同样使用demoService --> <dubbo:reference id="demoApi" interface="com.example.dubbo.demo.api.DemoApi" check="false" /> </beans>
dubbo:registry的配置须要跟服务提供者的配置是一致的。
dubbo:reference配置引用服务的接口名称,详细的属性参考dubbo官方文档。
maven依赖
<dependency> <groupId>com.example.dubbo</groupId> <artifactId>dubbo-demo-api</artifactId> <version>0.0.1-SNAPSHOT</version> </dependency> <dependency> <groupId>com.example.dubbo</groupId> <artifactId>dubbo-demo-model</artifactId> <version>0.0.1-SNAPSHOT</version> </dependency>
服务调用
新建一个DemoService来调用服务提供者对外暴露的方法
package com.example.dubbo.demo.web.service; import com.example.dubbo.demo.api.DemoApi; import dubbo.demo.model.entity.Student; import java.util.List; import org.apache.dubbo.config.annotation.Reference; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; /** * 消费者服务层 * * @author chenlong * @date 2019-03-24 00:49 * @since 1.0.0 */ @Service public class DemoService { private static final Logger LOGGER = LoggerFactory.getLogger(DemoService.class); @Autowired private DemoApi demoApi; public String sayHello(String name) { return demoApi.sayHello(name); } public List<Student> getAll(){ return demoApi.getAll(); } public void add(Student student){ demoApi.add(student); } }
新建一个DemoController来进行测试
package com.example.dubbo.demo.web.controller; import com.example.dubbo.demo.web.service.DemoService; import dubbo.demo.model.entity.Student; import java.util.List; import java.util.Random; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.*; /** * demo 控制器 * * @author chenlong * @date 2019-03-24 00:51 * @since 1.0.0 */ @RestController @RequestMapping("/demo") public class DemoController { private static Logger logger = LoggerFactory.getLogger(DemoController.class); @Autowired private DemoService demoService; /** * 测试方法,浏览器访问 /demo/index 能够看到响应结果了 * * @return */ @RequestMapping(value = "/index", method = RequestMethod.GET) @ResponseBody public String index() { return demoService.sayHello("dubbo"); } @GetMapping("all") @ResponseBody public List<Student> getAll(){ return demoService.getAll(); } @GetMapping("add") @ResponseBody public Student add(){ Student student = new Student(); student.setNum("2019"+ new Random().nextInt()); student.setName("乔治"+new Random().nextInt(100)); student.setAge(new Random().nextInt(10)); student.setSex("m"); demoService.add(student); return student; } }
启动web层,web层会以长链接的方式监听zk,同时会把zk上的服务提供者的信息拿到本地,这样当zk挂掉后不影响消费者的调用,当新的服务注册到zk上时,消费者会同时拿到新的服务信息。
咱们在浏览器中输入地址,发现调用成功
代码地址:https://github.com/lcchenlong/springbootdubbo