欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

SpringCloud Hoxton版微服务-入门篇

程序员文章站 2022-03-10 18:36:14
删除聚合结果:pom UTF-8 1.8 ......

SpringCloud Hoxton.SR9初级版

文章目录

前言

Spring Cloud 是一系列框架的有序集合,它利用 Spring Boot的开发便利性简化了分布式系统的开发,比如服务发现、服务网关、服务路由、链路追踪等。
Spring Cloud并不重复造*,而是将市面上开发得比较好的模块集成进去,进行封装,从而减少了各模块的开发成本。
换句话说:Spring Cloud提供了构建分布式系统所需的“全家桶”。

一、架构选型

spring-cloud官方地址:https://spring.io/projects/spring-cloud#learn
SpringCloud Hoxton版微服务-入门篇
时至今日,技术选型官方推荐如下:
SpringCloud Hoxton版微服务-入门篇
可以看到官方更新的最新H版,并且推荐我们使用的Spring-Boot版本是2.3.5的稳定版。

二、父工程创建

1、创建maven工程:

SpringCloud Hoxton版微服务-入门篇
SpringCloud Hoxton版微服务-入门篇

2、全局设置编码:

SpringCloud Hoxton版微服务-入门篇

3、注释生效激活:

SpringCloud Hoxton版微服务-入门篇

4、java编译版本选择:

SpringCloud Hoxton版微服务-入门篇

5、删除src文件夹、清除pom.xml部分代码

SpringCloud Hoxton版微服务-入门篇
SpringCloud Hoxton版微服务-入门篇

5、删除src文件夹、清除pom.xml部分代码聚合结果:

SpringCloud Hoxton版微服务-入门篇

6、完善pom.xml依赖:

<packaging>pom</packaging>

  <!--统一管理jar包版本-->
  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <maven.compiler.source>1.8</maven.compiler.source>
    <maven.compiler.target>1.8</maven.compiler.target>
    <junit.version>4.12</junit.version>
    <log4j.version>1.2.17</log4j.version>
    <lombok.version>1.16.18</lombok.version>
    <mysql.version>8.0.17</mysql.version>
    <druid.version>1.1.16</druid.version>
    <mybatis.spring.boot.version>1.3.2</mybatis.spring.boot.version>
    <!--架构选型-->
    <springboot.version>2.3.5.RELEASE</springboot.version>
    <spring-cloud.version>Hoxton.SR9</spring-cloud.version>
  </properties>

  <!--子模块继承父工程-->
  <dependencyManagement>
    <dependencies>
      <!--spring-boot-->
      <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-dependencies</artifactId>
        <version>${springboot.version}</version>
        <type>pom</type>
        <scope>import</scope>
      </dependency>
      <!--spring-cloud-->
      <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-dependencies</artifactId>
        <version>${spring-cloud.version}</version>
        <type>pom</type>
        <scope>import</scope>
      </dependency>
      <!--mysql-->
      <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>${mysql.version}</version>
        <scope>runtime</scope>
      </dependency>
      <!-- druid-->
      <dependency>
        <groupId>com.alibaba</groupId>
        <artifactId>druid</artifactId>
        <version>${druid.version}</version>
      </dependency>
      <!--mybatis-->
      <dependency>
        <groupId>org.mybatis.spring.boot</groupId>
        <artifactId>mybatis-spring-boot-starter</artifactId>
        <version>${mybatis.spring.boot.version}</version>
      </dependency>
      <!--单元测试-->
      <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>${junit.version}</version>
      </dependency>
      <!--log4j-->
      <dependency>
        <groupId>log4j</groupId>
        <artifactId>log4j</artifactId>
        <version>${log4j.version}</version>
      </dependency>
      <!--lombok-->
      <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
        <version>${lombok.version}</version>
        <scope>provided</scope>
      </dependency>
    </dependencies>
  </dependencyManagement>

  <!--热部署插件 开启-->
  <build>
    <plugins>
      <plugin>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-maven-plugin</artifactId>
        <configuration>
          <fork>true</fork>
          <addResources>true</addResources>
        </configuration>
      </plugin>
    </plugins>
  </build>

二、子工程创建-支付模块

1、创建支付模块:

SpringCloud Hoxton版微服务-入门篇
SpringCloud Hoxton版微服务-入门篇

2、模块名称 dt-provider-payment:

SpringCloud Hoxton版微服务-入门篇

3、父工程的pom.xml依赖便会自动导入 dt-provider-payment子工程的支付模块:

SpringCloud Hoxton版微服务-入门篇

4、dt-provider-payment子工程的支付模块:

SpringCloud Hoxton版微服务-入门篇

5、dt-provider-payment子工程基础架构如下:

SpringCloud Hoxton版微服务-入门篇

6、dt-provider-payment导入pom.xml依赖:

<dependencies>
    <!--三必备包-->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-actuator</artifactId>
    </dependency>
    <dependency>
        <groupId>org.mybatis.spring.boot</groupId>
        <artifactId>mybatis-spring-boot-starter</artifactId>
    </dependency>
    <!--druid-->
    <dependency>
        <groupId>com.alibaba</groupId>
        <artifactId>druid</artifactId>
    </dependency>
    <!--mysql-->
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
    </dependency>
    <!--devtools-->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-devtools</artifactId>
        <scope>runtime</scope>
        <optional>true</optional>
    </dependency>
    <!--lombok-->
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
        <optional>true</optional>
    </dependency>
    <!--test-->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
</dependencies>

6、配置application.yml:

server:
  port: 9001
spring:
  application:
    name: cloud-payment-service
  datasource:
    type: com.alibaba.druid.pool.DruidDataSource
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://xxxxxxx:3306/dtcloud?useUnicode=true&characterEncoding=utf-8&useSSL=false
    username: root
    password: 123456
mybatis:
  mapperLocations:  classpath:mapper/*.xml
  type-aliases-package: com.dtydf.springcloud.pojo
  configuration:
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

6、创建启动器PaymentAppMain.class:

SpringCloud Hoxton版微服务-入门篇

7、创建PaymentController.class控制器:

@RestController
@RequestMapping("/api/pay")
public class PaymentController {

    @Autowired
    private PaymentService paymentService;

    @GetMapping(value = "/payment/get/{id}")
    public CommentResult<Payment> getPaymentById(@PathVariable("id") Long id){
        Payment payment = paymentService.getById(id);
        log.info("返回结果:"+payment);
        if(payment != null){
            return new CommentResult<>(200,"查询成功",payment);
        }else {
            return new CommentResult<>(201,"没有查询到对应的记录",null);
        }
    }
}

三、子工程创建-订单模块

1、订单服务名称 dt-consumer-order:

SpringCloud Hoxton版微服务-入门篇

2、配置application.yml:

server:
  port: 8001
spring:
  application:
    name: cloud-consumer-service

3、创建OrderAppMain启动器:

@SpringBootApplication(exclude={DataSourceAutoConfiguration.class})
public class OrderAppMain {

    public static void main(String[] args) {
        SpringApplication.run(OrderAppMain.class,args);
    }
}

4、创建OrderController.class控制器:

@RestController
@Slf4j
public class OrderController {

    private static final String PAYMENT_URL = "http://localhost:9001";

    @Autowired
    private RestTemplate restTemplate;

    @GetMapping(value = "/consumer/payment/save")
    public CommentResult<Payment> create(Payment payment){
        return restTemplate.postForObject(PAYMENT_URL + "/payment/save",payment,CommentResult.class);
    }

    @GetMapping(value = "/consumer/payment/get/{id}")
    public CommentResult<Payment> getPaymentById(@PathVariable("id") Long id){
        log.info("订单(消费者)调用支费服务(提供者)");
        return restTemplate.getForObject(PAYMENT_URL + "/payment/get/"+id,CommentResult.class);
    }

}

5、订单(消费者)调用支费服务(提供者):

5.1 RestTemplate简介

RestTemplate是Spring提供的用于访问Rest服务的客户端,RestTemplate提供了多种便捷访问远程Http服务的方法,能够大大提高客户端的编写效率

5.2 RestTemplate配置类

/**
 * @description: RestTemplate
 * @author: ydf
 * @date: 2020/12/2 22:45
 * @version: v1.0
 */
@Configuration
public class ApplicationContextConfig {

    @Bean
    @LoadBalanced //开启负载均衡的功能(轮询的方式)
    public RestTemplate restTemplate(){
        return new RestTemplate();
    }
}

四、子工程创建-公共模块

1、公共服务名称 dt-service-common:

2、导入pom.xml依赖:

<dependencies>
        <!--devtools-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <scope>runtime</scope>
            <optional>true</optional>
        </dependency>
        <!--lombok-->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <!--hutool Java基础工具类,对文件、流、加密解密、转码、正则、线程、XML等JDK方法进行封装-->
        <dependency>
            <groupId>cn.hutool</groupId>
            <artifactId>hutool-all</artifactId>
            <version>5.1.0</version>
        </dependency>
    </dependencies>

3、通用JSON返回实体:

/**
 * @description: 通用JSON返回实体
 * @author: ydf
 * @date: 2020/12/2 21:50
 * @version: v1.0
 */
@Data
@AllArgsConstructor
@NoArgsConstructor
public class CommentResult<T> {

    private Integer code;

    private String message;

    private T data;

    public CommentResult(Integer code,String message){
        this(code,message,null);
    }
}

4、通用Payment 实体:

@Data
@AllArgsConstructor
@NoArgsConstructor
public class Payment implements Serializable {

    private static final long serialVersionUID = -6582898024290800951L;

    private Long id;

    private String serial;
}

5、通用基础架构:

SpringCloud Hoxton版微服务-入门篇

6、打包上传到maven库,共享通用:

6.1 先clean再install

SpringCloud Hoxton版微服务-入门篇

6.2 打包成功后即可在订单和支付模块使用公共依赖库

<!--引入自己自定义的api通用包,可以使用Payment支付Entity-->
<dependency>
    <groupId>com.dtydf.springcloud</groupId>
    <artifactId>dt-service-common</artifactId>
    <version>1.0-SNAPSHOT</version>
    <scope>compile</scope>
</dependency>

SpringCloud Hoxton版微服务-入门篇

五、测试:

1、支付模块自测试

http://localhost:9001/payment/get/1

SpringCloud Hoxton版微服务-入门篇

2、订单调用支付模块测试

http://localhost:8001/consumer/payment/get/1

SpringCloud Hoxton版微服务-入门篇

六、最后

订单(消费者)调用支费服务(提供者),通过Spring提供的RestTemplate,访问Rest服务的客户端,实现了简单的微服务间的调用。

下一篇我们将使用RestTemplate做服务调用的负载均衡实现。

本文地址:https://blog.csdn.net/qq_41107231/article/details/110496929