springboot+mybatis+dubbo+aop日志终结篇

时间:2022-06-20
本文章向大家介绍springboot+mybatis+dubbo+aop日志终结篇,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

之前的几篇文章把dubbo服务层都介绍完毕,本篇文章咱们主要写web层如何调用服务层的方法。文章底部附带源码。

启动服务

服务启动时,会向zk注册自己提供的服务,zk则会记录服务提供者的IP地址以及暴露的接口名称,通过zkCli.cmd 查看树形结构,具体命令如下:

1、ls / 

展示两个目录:dubbo、zookeeper,下面主要看一下dubbo目录

2、ls /dubbo

可以看到注册到dubbo目录下的接口了

3、ls /dubbo/com.example.dubbo.demo.api.DemoApi

服务提供者的具体信息就在providers目录里了

服务消费者-web层

该层依赖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

作者:Eric.Chen 出处:https://www.cnblogs.com/lc-chenlong 如果喜欢作者的文章,请关注“写代码的猿”订阅号以便第一时间获得最新内容。本文版权归作者所有,欢迎转载