SpringCloud应用idea实现可相互调用的多模块程序详解

 更新时间:2022年07月19日 09:39:41   作者:扎哇太枣糕  
IDEA 全称 IntelliJ IDEA,是java编程语言的集成开发环境。IntelliJ在业界被公认为最好的Java开发工具,尤其在智能代码助手、代码自动提示、重构、JavaEE支持、各类版本工具(git、svn等)、JUnit、CVS整合、代码分析、 创新的GUI设计等方面的功能可以说是超常的

版本选择

  学习spring cloud之前需要有一定的spring boot基础,按我现阶段的了解就是,spring boot属于是做业务开发的,所谓的微服务就是将一个大的项目分为是很多的使用spring boot进行开发的单体项目。当然如果没有后续的话,那么这一个项目也就成了一盘散沙,没有办法真正的实现它的作用,于是就需要使用spring cloud将所有的spring boot单体项目整合起来,形成一个完整的项目,从而发挥它最大的作用。

  既然在一个项目中涉及到了两种框架技术的使用,那么就需要考虑这两种框架会不会产生冲突。那么我们应该如何查看这两种框架的版本适用呢?我们可以参考spring cloud官网给出的答案,这个文档是实时更新的,不用担心过时的问题。https://spring.io/projects/spring-cloud,打开链接直接向下划即可找到

  官网在这里只是提供了一个相对模糊的版本对应,想要更加具体的版本对应可以参考以下网站https://start.spring.io/actuator/info,将网站返回的JSON字符串经过工具的转换即可发现其中的版本对应

  当然,上述两种方法都是在boot和cloud技术版本选择时的一种参考,真正确定下来还是要看cloud官网上面的参考doc文档,点进去的Supported Boot Version才是最终敲定的依据

技术选型

  前面讲到spring cloud是一个微服务的框架,既然是微服务就说明我们需要使用技术控制各个单体服务之间的通信,还有不同服务的调用等。于是就涉及到了这些不同功能的技术选型,我们都知道技术是在不停迭代更新的,有很多的技术停更淘汰,与此同时也有很多的技术更新迭代出来,于是我们应该知道不同的功能应该选用哪种可行的技术。

服务注册中心:

  • Eureka
  • Zookeeper
  • Consul
  • Nacos √

服务调用:

  • Ribbon
  • LoadBalancer
  • Feign
  • OpenFeign √

服务降级:

  • Hystrix
  • Resilience4j
  • Sentinel √

服务网关:

  • Zuul
  • Zuul2
  • Gateway √

服务配置:

  • Config
  • Nacos √

服务总线:

  • Bus
  • Nacos √

spring boot单体模块的搭建

创建父工程

project项目创建

修改项目名 -> 修改项目存储地址 -> 修改maven配置 -> finished

配置字符编码格式

配置注解生效激活

配置项目的Java的版本

父工程的pom文件

  父pom中的并不会引入相应的jar包,而是定义了版本号供子模块使用,只有子模块导入依赖坐标的时候(如果父pom中有,可以不指定版本号)才会引入相应的jar包

<?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">
    <modelVersion>4.0.0</modelVersion>
    <groupId>项目的组id</groupId>
    <artifactId>项目名称</artifactId>
    <version>项目版本</version>
    <packaging>pom</packaging>
    <!--统一管理设置jar包的版本-->
    <properties>
        ..........
    </properties>
    <!--依赖传递:父pom文件中的依赖版本会被子模块自动继承,除非子模块中自己声明版本,否则就使用父pom的版本,同理,父pom的依赖版本升级,子模块也会升级到相应的版本-->
    <dependencyManagement>
        <dependencies>
            <dependency>
                .......
            </dependency>
				......
            <dependency>
                .......
            </dependency>
        </dependencies>
    </dependencyManagement>
</project>

创建子模块

  在父工程上右键,新建一个model

创建之后需要配置子模块的配置文件,也就是子模块的resources文件夹下的application.yml文件,主要就是配置端口号和数据库相关

server:
  port: 8001

spring:
  application:
    name: cloud-payment-service
  datasource:
    type: com.alibaba.druid.pool.DruidDataSource
    driver-class-name: org.gjt.mm.mysql.Driver
    url: …… ……… ………
    username: …… ……
    password: …… …… ……
mybatis:
  mapper-locations: classpath:mapper/*.xml
  type-aliases-package: com.xiaochen.springcloud.entities

然后就是创建相应的mapper、service、serviceImpl、映射文件

RestTemplate

  Rest Template就是一种对HTTPClient的封装,是Spring提供的用于访问Rest服务的客户端模板工具集,其内部提供了多种便捷的用于访问远程http服务的方法,主要就是用于实现微服务项目中几个服务之间的相互调用。

使用步骤

使用配置类向容器中注入RestTemplate对象

/**
 * @ClassName: ApplicationContextConfig
 * @Description: 程序配置类
 * @author: chenhao
 * @date: 2022/7/17
 */
@Configuration
public class ApplicationContextConfig {
    @Bean
    public RestTemplate getRestTemplate() {
        return new RestTemplate();
    }
}

  在需要使用它的地方用@Resource注入对象,然后就是调用api实现相应的功能,全部api参考以下链接:链接

系统重构(子模块间重复代码的抽取)

  创建一个公共模块,将公共的代码和依赖全部抽取到这个公共模块中,然后别的模块如果想要使用公共模块的代码,就必须先对公共模块的maven进行clean和install,然后在pom文件中导入这个公共模块的依赖即可使用公共部分代码

到此这篇关于SpringCloud应用idea实现可相互调用的多模块程序详解的文章就介绍到这了,更多相关SpringCloud多模块程序内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • SpringMVC中的JSR303与拦截器的使用方法

    SpringMVC中的JSR303与拦截器的使用方法

    JSR303是Java中的一个标准,用于验证和校验JavaBean对象的属性的合法性,本文主要介绍了SpringMVC中的JSR303与拦截器的使用方法,感兴趣的可以了解一下
    2023-10-10
  • springboot整合Atomikos的示例详解

    springboot整合Atomikos的示例详解

    这篇文章主要为大家详细介绍了几种分布式事务的解决方案的两阶段提交Atomikos,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下
    2024-11-11
  • Java使用CompletableFuture进行非阻塞IO详解

    Java使用CompletableFuture进行非阻塞IO详解

    这篇文章主要介绍了Java使用CompletableFuture进行非阻塞IO详解,CompletableFuture是Java中的一个类,用于支持异步编程和处理异步任务的结果,它提供了一种方便的方式来处理异步操作,并允许我们以非阻塞的方式执行任务,需要的朋友可以参考下
    2023-09-09
  • ssm开发使用redis作为缓存的使用步骤

    ssm开发使用redis作为缓存的使用步骤

    在开发中经常遇到大量的重复的,高并发的查询,此时可以使用redis缓存。这篇文章主要介绍了ssm开发使用redis作为缓存的使用步骤,感兴趣的小伙伴们可以参考一下
    2018-11-11
  • Java 反射机制的实例详解

    Java 反射机制的实例详解

    这篇文章主要介绍了Java 反射机制的实例详解的相关资料,希望通过本文能帮助到大家,让大家理解掌握反射机制,需要的朋友可以参考下
    2017-10-10
  • Java数组转换为List的四种方式

    Java数组转换为List的四种方式

    这篇文章主要介绍了Java开发技巧数组转List的四种方式总结,每种方式结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-09-09
  • 远程调用@FeignClient注解属性使用详解

    远程调用@FeignClient注解属性使用详解

    这篇文章主要为大家介绍了远程调用@FeignClient注解属性使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • java中的常用集合类整理

    java中的常用集合类整理

    在本篇文章里小编给大家整理的是关于java中的常用集合类的相关知识点内容,有兴趣的朋友们学习下。
    2019-12-12
  • Java Map如何根据key取value以及不指定key取出所有的value

    Java Map如何根据key取value以及不指定key取出所有的value

    这篇文章主要介绍了Java Map如何根据key取value以及不指定key取出所有的value,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-09-09
  • 了解JAVA Future类

    了解JAVA Future类

    Future是并发编程中的一种设计模式,Future它代表一个异步计算的结果,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,下面小编和大家来一起学习一下吧
    2019-06-06

最新评论