『高级篇』docker之开发课程服务(15)
2019-01-31 09:07:22
李明
  • 访问次数: 377
  • 注册日期: 2018-07-09
  • 最后登录: 2019-10-30

原创文章,欢迎转载。转载请注明:转载自 IT人故事会,谢谢!
原文链接地址: 『高级篇』docker之开发课程服务(15)


这次一起编写课程服务。之前的用户服务,用户EdgeSerivce,用户信息,都已经开发完毕了,开始开发课程服务,对外的是dubbo接口,需要访问后端的数据库。源码: github.com/limingios/ms


v2-960f9f8d6b0cb31f829a42e9b0e009e5_hd.j


开发课程服务模块

基于dubbo的服务,一般先定义api接口,前面的都是基于thrift的,我们先写一个thrift的文件,然后根据配置文件升成对应的api,dubbo我们相当于先手写一个api的模块。


v2-def8b113eb4b44bedaddf46812790aca_hd.j


稍微复杂

  • 总体思想

就不在复制代码了只通过截图来讲述功能,可以参考源码,本次跟用到了上次springboot集成dubbo的方式。
  1. course-dubbo-service-api 是负责提供接口的服务

  2. course-dubbo-service 是course-dubbo-service-api的实现

  3. course-dubbo-service 需要依赖原始的user-thrift-service-api的原生DTO类 和 user-thrift-service中的方法实现。

  4. course-dubbo-service调用user-thrift-service 是用过thrift的方式完成的调用。因为user-thrift-service本身就是通过thrift生成对应的java类。


v2-e68749e6f5084ac320c3f6a9ffa2c0bb_hd.j



v2-7a09d13979559923c85cf1829d656fd2_hd.j


  • user-thrift-service 和 user-thrift-service-api

  1. user-thrift-service-api 做了thrift的修改,增加了老师的DTO和ID来获取用户的信息,所以需要重新通过thrift命令生成对应的java类

  2. user-thrift-service 实现了新增的通过ID来获取用户的信息的接口,并增加了UserMapper

  3. user数据库中增加了一张关联表teacher表


v2-b63ad849dad1f020972c0062c8d5cc60_hd.p



v2-64d540ad517ce21a02880702873eae7b_hd.j



v2-7e973965a806312b579be3c703b9d747_hd.j



v2-6855106573452dabd7de2a4efba0859a_hd.j



v2-9eeedcc913238efdd4f329d80c35fb3c_hd.j



v2-2272e00bf0314a4f06023c3b6c60ae5d_hd.j


  • course-dubbo-service-api 和 course-dubbo-service

  1. course-dubbo-service pom中引入了springboot,mysql的驱动,thrift,springboot-dubbo,user-thrift-service.jar,user-thrift-service-api.jar

  2. course-dubbo-service 中注入thrift微服务的访问service,获取教师针对课程的教程信息访问user-thrift-service的微服务,通过thrift的方式。

  3. application.properties 配置dubbo的配置,数据库配置,user-thrift-service的地址和端口

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>1.5.3.RELEASE</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.idig8</groupId>
    <artifactId>course-dubbo-service</artifactId>
    <version>1.0-SNAPSHOT</version>
    <dependencies>
        <dependency>
            <groupId>io.dubbo.springboot</groupId>
            <artifactId>spring-boot-starter-dubbo</artifactId>
            <version>1.0.0</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
        </dependency>
        <dependency>
            <groupId>org.apache.thrift</groupId>
            <artifactId>libthrift</artifactId>
            <version>0.10.0</version>
        </dependency>
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>1.3.1</version>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.44</version>
        </dependency>
        <dependency>
            <groupId>com.idig8</groupId>
            <artifactId>course-dubbo-service-api</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>
        <dependency>
            <groupId>com.idig8</groupId>
            <artifactId>user-thrift-service</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>
        <dependency>
            <groupId>com.idig8</groupId>
            <artifactId>user-thrift-service-api</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>
    </dependencies>
</project>


v2-a2c5cc556a16a3f493b914aa94b1c472_hd.j



v2-f480c27a7681de6b227b5b45e935b9ec_hd.j



v2-b92d56b1bbfcab54d1eead725572890f_hd.j



v2-4f0cabd7da6d19858983563357035ef1_hd.j


PS:基本的课程开发思路就是这样,别人有的微服务调用,只实现自己所属的。



1240