项目的简单介绍: 项目采用maven聚合工程 用spring boot 搭建 spring cloud的微服务 模块式开发

项目的截图:

搭建开始: 能上图 我少打字

1.首先搭建maven的聚合工程

  1.1创建聚合工程的父模块

  

  

  

  

  1.2设置父模块的POM文件

  主要是配置 spring boot版本,spring cloud 版本,和一些通用的依赖 比如这里的 lombok依赖

<?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>com.cloud</groupId>
<artifactId>cloud</artifactId>
<version>1.0-SNAPSHOT</version>
<!--packing默认是jar类型,
<packaging>pom</packaging> 父类型都为pom类型
<packaging>jar</packaging> 内部调用或者是作服务使用
<packaging>war</packaging> 需要部署的项目-->
<packaging>pom</packaging> <parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.3.RELEASE</version>
<relativePath /> <!-- lookup parent from repository -->
</parent> <properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
<org.mapstruct.version>1.2.0.Final</org.mapstruct.version>
<lombok.version>1.18.4</lombok.version>
<spring-cloud.version>Finchley.RELEASE</spring-cloud.version>
</properties> <!--dependencyManagement 标签不会引入依赖 -->
<dependencyManagement>
<dependencies>
<!--控制cloud的版本-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement> <dependencies>
<!-- 启用注解读取配置文件支持 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency> <!-- lombok -->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<scope>provided</scope>
</dependency> </dependencies> <build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.8.0</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
<encoding>UTF-8</encoding>
<annotationProcessorPaths>
<path>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>${lombok.version}</version>
</path>
</annotationProcessorPaths>
</configuration>
</plugin> </plugins>
</build>
</project>

2.使用spring boot创建 微服务 的注册中心 eureka

  2.1创建 eureka

  

   

  

  

  

  

  2.2 因为是用 spring boot方式创建的模块 需要修改POM文件的一些配置

  

  

  

  

  2.3 在父模块的POM文件中引入子模块

  

  

  2.4 在application.yml中加入配置

  2.4.1 创建开发环境的 配置文件

      

    2.4.2 添加配置

      application.yml

spring:
application:
name: boot-eureka
profiles:
#指向开发环境的yml文件
active: dev

      application-dev.yml

server:
port: 8367
eureka:
instance:
hostname: localhost
server: #配置属性,但由于 Eureka 自我保护模式以及心跳周期长的原因,经常会遇到 Eureka Server 不剔除已关停的节点的问题
enable-self-preservation: false
eviction-interval-timer-in-ms: 5000
peer-eureka-nodes-update-interval-ms: 1000
wait-time-in-ms-when-sync-empty: 0
# 不向注册中心注册自己
client:
fetch-registry: false
register-with-eureka: false
eureka-server-total-connections: 200
serviceUrl:
defaultZone: http://127.0.0.1:${server.port}/eureka/

 2.4.3 修改启动类

 

  启动后访问 http://127.0.0.1:8367

  出现 下图  eureka配置 启动成功

  

  3.创建提供服务的项目

  创建流程和之前是一样 只是 对应的依赖不一样 依赖如下图

  

  创建完成后 修改POM文件 和eureka一样  配置文件一样 两个

  3.1 添加配置

  application.yml

spring:
application:
name: boot-service
profiles:
active: dev

  application-dev.yml

server:
port: 7432
eureka:
instance:
prefer-ip-address: true
lease-renewal-interval-in-seconds: 5
lease-expiration-duration-in-seconds: 20
client:
service-url:
defaultZone: http://127.0.0.1:8367/eureka/

  3.2 添加方法 这里我简单的写了个测试方法

  

  

  

  启动完成后 eureka会看到刚才启动的服务信息

  

  4.创建 内部暴露服务接口的service-client模块

  创建流程和上面一样 依赖如下图

  

  创建完成后 修改POM文件 没有  配置文件 这个模块 只是暴露服务 不需要启动

  

  

  如果 A服务接口需要调用B服务接口

  在 spring cloud 中 流程如下图

   

  则需要在 A服务的POM文件中 添加   service-client模块 如下图

  

  

  

  5.创建 外部暴露给前端的api层

  创建流程一样 依赖如下

  

  

   创建完成后 修改POM文件 和 boot-service一样  配置文件一样 两个

   POM文件中 把service-client模块 引入

  

  

  

  

  启动后eureka中会显示 如下图

  

  现在 用POSTMAN 测试 访问API层接口

  

  可以看到service 被调用

 

  GET请求 可以 这样玩  但是 如果是POST 请求 就需要把请求 对象VO 单独抽离成一个项目  给service ,service-client,api 层使用

 创建vo模块 流程一样 依赖都不需要

  maven 聚合工程 A模块 调用 B模块 需要A模块中引入B模块

  所以 service ,service-client,api 这3个模块都需要引入 vo模块

  

  vo模块中的vo对象

  

  boot-service模块中添加对应的传入对象测试方法

  

  

  service-client层

  

  api层

  

  POSTMAN 测试 前端 POST请求

  

  

  成功接受到对象

  谢谢阅读!!!

  

maven 聚合工程 用spring boot 搭建 spring cloud 微服务 模块式开发项目的更多相关文章

  1. (子文章)Spring Boot搭建两个微服务模块

    目录 1. 创建工程和user-service模块 1.1 创建空工程 1.2 在空工程里新建Module 2. 配置文件 2.1 pom.xml 2.2 application.yml 3. 代码 ...

  2. Spring boot学习1 构建微服务:Spring boot 入门篇

    Spring boot学习1 构建微服务:Spring boot 入门篇 Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程.该框 ...

  3. Spring Boot 和 Docker 实现微服务部署

    Spring boot 开发轻巧的微服务提供了便利,Docker 的发展又极大的方便了微服务的部署.这篇文章介绍一下如果借助 maven 来快速的生成微服务的镜像以及快速启动服务. 其实将 Sprin ...

  4. 使用Ratpack与Spring Boot构建高性能JVM微服务

    在微服务天堂中Ratpack和Spring Boot是天造地设的一对.它们都是以开发者为中心的运行于JVM之上的web框架,侧重于生产率.效率以及轻量级部署.他们在服务程序的开发中带来了各自的好处.R ...

  5. 在Azure DevOps Server中运行基于Spring Boot和Consul的微服务项目单元测试

    1 概述 谈到微服务架构体系,绕不开服务发现这个功能.服务发现机制是简化微服务配置.实现容灾.水平扩缩容.提高运维效率的重要方式.在服务发现工具中,Consul在部署和使用方面与容器结合的天衣无缝,成 ...

  6. SPRING CLOUD微服务DEMO-上篇

    目录 1. 微服务架构 2. 远程调用方式 2.1 RPC/RMI 2.2 Http 2.3 如何选择 3. Http客户端工具 3.1 RestTemplate 4. Spring Boot 搭建项 ...

  7. Spring Boot和Spring cloud

    微服务框架SpringBoot简单验证 首先摘录部分IBM网站部分内容对框架做一个简单说明 http://www.ibm.com/developerworks/cn/java/j-lo-spring- ...

  8. 利用 Maven 构造 Spring Cloud 微服务架构 模块使用 spring Boot构建

    采用Maven 聚合工程搭建 Spring Cloud 使用工具: IntelliJ IDEA    版本: 2019.2.2 maven             版本: 3.6.0 JDK      ...

  9. 自我救赎 → 利用 IDEA 和 Spring Boot 搭建 SSM

    前言 开心一刻 儿子读高中放学回来了,一向不管他学习的我突然来了兴趣,想看看他的学习他的状况,抄起他的数学习题看了起来,当看到 1 x 2 x 3 x 4 x 5 x 6 x 7 x 8 x 9 x ...

随机推荐

  1. windows 子系统 linux wsl 开启ssh 服务

    原因 windows自带的终端操作丑陋,习惯xshell的操作 步骤 1.关闭windows自带的ssh服务,这个占用了22端口 2.wsl 安装ssh服务(使用的是ubuntu) sudo apt ...

  2. [swarthmore cs75] Lab 1 — OCaml Tree Programming

    课程回顾 Swarthmore学院16年开的编译系统课,总共10次大作业.本随笔记录了相关的课堂笔记以及第2大次作业. 比较两个lists的逻辑: let rec cmp l ll = match ( ...

  3. Android逆向破解表单登录程序

    Android逆向破解表单登录程序 Android开发 ADT: android studio(as) 程序界面如下,登录成功时弹出通知登录成功,登录失败时弹出通知登录失败. 布局代码 <?xm ...

  4. OPC转发阿里云alink工具

    这个最近还在做 2019-04-24 今天抽空吧基本mqtt上传,OPC遍历,导出物模型功能先做了 上报操作日志,上报错误信息,导入参数,导出参数还没做 有需要可以联系微信NBDX123

  5. Scala知识点汇总

    Scala数组小结 1.定长数组 定长数组:指长度不可变的数组Array.第一种方式:先声明一个数组,后初始化该数组: scala> val array = new Array[Double]( ...

  6. 端口转发 Port Forwarding (一)

    0x00First 最近发现一些好用的端口转发工具和技巧,计划认真梳理一下 SSH.NC.LCX.EW.FRP 0x01 SSH隧道端口转发 目前利用SSH隧道(SSH tunneling)进行端口转 ...

  7. Smokeping安装部署

    稳定性检测工具smokeping安装配置和使用方法 Smokeping介绍 是对IDC网络质量,稳定性等最好的检测工具,包括常规的 ping,dig,echoping,curl等,可以监视www服务器 ...

  8. Dubbo 源码分析 - 服务导出

    1.服务导出过程 本篇文章,我们来研究一下 Dubbo 导出服务的过程.Dubbo 服务导出过程始于 Spring 容器发布刷新事件,Dubbo 在接收到事件后,会立即执行服务导出逻辑.整个逻辑大致可 ...

  9. JVM之虚拟机类加载机制

    有兴趣可以先参考前面的几篇JVM总结: JVM自动内存管理机制-Java内存区域(上) JVM自动内存管理机制-Java内存区域(下)     JVM垃圾收集器与内存分配策略(一) 我们知道,在编写一 ...

  10. 【sql注入教程】mysql注入直接getshell

    Mysql注入直接getshell的条件相对来说比较苛刻点把 1:要知道网站绝对路径,可以通过报错,phpinfo界面,404界面等一些方式知道 2:gpc没有开启,开启了单引号被转义了,语句就不能正 ...