15年大牛用140多个实战案例深入讲解Java微服务架构实战:SpringBoot +SpringCloud +Docker +RabbitMQ

发布于:2021-10-16 10:38:05

前言

本文是由15年开发大牛用140个实战案例,完美演示Java微服务架构实战:SpringBoot +SpringCloud +Docker +RabbitMQ;


用丰富的架构图示+手把手步骤学*,带领大家轻松掌握微架构设计与开发;



?


Java微服务架构是当下最为流行的软件架构设计方案,可以快速地进行代码编写与开发,维护起来也非常方便。利用微架构技术,可以轻松地实现高可用、分布式、高性能的项目结构开发,同时也更加安全。


本文适用于从事Java 开发且有架构与项目重构需求的读者,也适用于相关技术爱好者,希望本文能够帮助到大家的学*!


目录


?


主要内容

全文涉及到的技术包括:SpringBoot、Thymeleaf、Jetty、Redis整合、C3PO整合、Druid整合、MyBatis整合、ActiveMQ 整合、RabbitMQ整合、Kafka整合、Shiro整合、SpringDataJPA整合、Mail整合、Actuator监控、Restful、RestTemplate、Eureka、Ribbon、 Feign、Hystrix、Turbine、Zuul、SpringCloudConfig、SpringCloudBus、SpringCloudStream、SpringCloudSleuth、Zipkin,OAuth、RabbitMQ和 Docker。


第一部分,springboot篇;


第1章SpringBoot编程起步;


1.SpringBoot提倡的是一种简洁的开发模式,可保证用户不被大量的配置文件和依赖关系所困扰。


2.SpringBoot开发需要Maven或 Gradle构建工具支持。


3.SpringBoot使用一系列的注解来简化开发过程。



?


第2章SpringBoot程序开发;


1. SpringBoot的依赖管理除了可以作为项目的父pom引入之外,也可以采用依赖管理的形式进行配置。


2. SpringBoot程序测试专门提供了spring-boot-starter-test依赖库,在测试时需要使用@SpringBootTest注解。


3.在定义SpringBoot程序主类时使用@SpringBootApplication注解,可以自动扫描子包中的配置项,实现自动配置。


4.@Controller 注解采用的是普通控制器的形式定义,而@RestController注解可以直接以Restful方式运行。


5.SpringBoot 默认使用的是Tomcat容器,开发时也可以配置spring-boot-starter-jetty依赖库,使用Jetty容器。但是在实际部署时,建议使用Tomcat容器。


6.SpringBoot支持*.properties和*.yml 两类配置文件,在实际开发中建议通过application.yml实现环境配置。


7.SpringBoot项目可以通过spring-boot-maven-plugin实现打包处理,这样就可以方便地通过*.jar 文件来实现项目的发布。



?


第3章Thymeleaf模板渲染;


1.在SpringBoot中如果要引入Thymeleaf模板,需要配置spring-boot-starter-thymeleaf依赖包。


2.Thymeleaf可以有效地取代JSP页面,实现页面动态逻辑处理。


3.Thymeleaf分为动态页面( templates)和静态资源(static)两类资源。


4.Thymeleaf不仅仅可以实现控制器传递的属性输出,也可以实现资源文件的内容输出。


5.在 Thymeleaf中可以使用“@{路径}”的形式实现资源引入与跳转配置。


6.Thymeleaf中可以使用判断、循环逻辑进行处理,也可以利用各种内置操作在页面上实现List、Map、Set、字符串等数据处理,还可以使用日期格式化指令进行日期显示格式的处理。



?


第4章SpringBoot与Web应用;


1.SpringBoot项目可以将程序打包为war文件,并且部署到Tomcat容器上执行。


2.SpringBoot可以像web.xml 文件一样设置状态码的错误跳转页,也可以设置异常的错误跳转页。


3.SpringBoot 与 SpringMVC上传文件的处理形式相同,但是配置更加简化。


4.SpringBoot可以使用HandlerInterceptor拦*鞫钥刂撇愕那肭蠼欣菇亍


5.SpringBoot可以直接导入 spring-boot-starter-aop编写AOP拦*鳎迪忠滴癫憷菇亍



?


第5章SpringBoot服务整合;


1. SpringBoot可以方便地与常用ORM设计框架整合(MyBatis、JPA),同时也可以实现DataSource的自动引入。


2.SpringBoot整合消息组件时,只需要在application.yml配置文件中进行配置即可使用。


3. SpringBoot整合Redis数据库时,可以使用RedisTemplate模板进行数据库操作,也可以通过序列化操作,保存对象到数据库之中。


4.SpringBoot默认只支持单个Redis 数据库连接的配置,如果需要配置多个Redis数据库连接,则需要由开发者自行定义配置程序类来完成。


5.SpringBoot属于Web应用,可以使用Shiro实现认证与授权处理,同时也可以结合OAuth实现单点登录控制。



?


第二部分SpringCloud篇;


第6章SpringCloud简介;


1.RPC是实现远程过程调用的技术标准,可以使用各种语言实现。SpringCloud是基于Restful 架构实现的RPC技术。


2.SpringCloud在实现微服务的定义时,主要使用Netflix 公司的产品(如Eureka、Zuul、Feign、Ribbon等)实现架构整合。


3.SpringCloud可以结合SpringSecurity技术进行安全访问。



?


第7章SpringCloud与Restful;


1. SpringCloud是基于Restful实现的RPC 技术,并且需要SpringBoot技术支持。


2.在微服务的创建过程中为了保证服务访问的安全,需要配置DTO数据传输类,对请求和返回数据进行封装。


3.RestTemplate是消费端进行Restful服务端访问的程序类,通过地址即可访问。


4.微服务的信息可以通过Swagger框架进行接口描述定义。


5.为了保证微服务的安全,应该在项目中引入SpringSecurity,进行用户认证与授权信息配置。


6.微服务如果要承受高并发访问,则一定要采用无状态(STATELESS)Session配置。



?


第8章Eureka注册服务;


1.Eureka提供微服务的注册服务,所有的微服务都需要在Eureka中注册并进行服务发布。


2.Eureka提供发现管理,利用 DiscoveryClient类可以实现发现信息。


3.Eureka提供默认服务注册,开发者也可以根据实际情况配置心跳时间、清除时间等。


4.Eureka使用SpringSecurity实现安全机制,以保证注册中心的安全。


5.Eureka支持HA机制,以避免单节点导致的服务瘫痪问题。



?


第9章SpringCloud服务组件;


1.Ribbon是一个工作在消费端的负载均衡组件,SpringBoot消费端可以通过 Ribbon调用Eureka中注册的微服务。


2.SpringCloud微服务的负载均衡采用的是服务名称的管理,即同一个服务名称的微服务会自动注册到同一组微服务信息中,Ribbon中可以利用IRule接口子类配置负载均衡策略。


3.Feign是基于Ribbon组件的应用,可以利用Feign实现远程Restful 与接口间的映射转换。


4.Hystrix提供的是熔断机制,可以在某一个微服务出现问题后自动熔断,以防止雪崩效应出现。


5.HystrixDashboard提供微服务访问监控,利用Turbine可以实现一组微服务的监控。但对于认证的微服务,则需要进行安全访问排除。


6.Zuul提供有网关路由功能,利用Zuul可以实现一组微服务的划分。同时利用路由配置,可以使微服务的访问更加安全。



?


第10章SpringCloudConfig;


1.SpringCloudConfig是提供配置文件统一管理的微服务,可以利用软件版本控制仓库(Git、SVN)实现配置保存。


2.SpringCloudConfig 服务端可以在一个仓库中实现多个配置文件的抓取,也可以通过应用仓库自动选择实现多个仓库配置文件的抓取。


3.SpringCloudConfig客户端要通过bootstrap.yml配置SpringCloudConfig 服务端地址,这样在客户端启动时就可以自动实现配置文件加载。


4.在 SpringCloudConfig 中利用密钥与KeyStore实现重要信息加密。


5. SpringCloudConfig服务端作为一个微服务,可以在 Eureka中注册,以实现配置微服务的高可用。


6.利用SpringCloudBus可以实现配置文件的动态抓取,并且可以结合GitHub中的 Webhooks实现配置自动更新。



?


第11章SpringCloudStream;


1.SpringCloudStream可以实现消息驱动微服务的搭建。


2.SpringCloudStream最大的特征是用户采用对象的形式进行程序处理,而在消息传递中可以将对象自动转换为JSON结构,同时在消费端也可以实现JSON数据与对象之间的转换。


3.SpringCloudStream支持 RabbitMQ与Kafka两类消息组件,建议采用RabbitMQ整合。


4.SpringCloudStream默认通道使用的是Source与 Sink接口,如果开发者有需要,也可以自定义通道配置。


5.SpringCloudStream结合RabbitMQ时,可以利用消费端的分组配置实现消息持久化存储。



?


第12章SpringCloudSleuth;


1.SpringCloudSleuth是数据采集微服务,可以与Zipkin结合,实现微服务的调用结构观察。


2.SpringCloudSleuth可以与 RabbitMQ 与MySQL结合,实现数据采集。也可以与ELK结合,进行数据采集后的分析。



?


第13章OAuth认证管理;


1.OAuth除了可以在 Web端实现单点登录整合之外,也可以与SpringCloud结合使用。


2.OAuth在与SpringCloud整合时,可以使用ClientDetailsService 与UserDetailsService实现数据库信息的访问。


3.OAuth访问获得的token信息一定要保存在Redis 中,并且获取token认证信息的请求可以通过token获取用户完整资源。


4.SpringCloud在与OAuth整合时,一定要修改application.yml配置的security.oauth2.resource.filter-order选项,否则用户token将不会被检测。


5.SpringCloud整合OAuth时,需要在Zuul网关中生成token,而后在具体微服务访问时只需要通过token获取用户资源即可,同时也可以针对用户的角色进行统一管理。



?


第三部分微服务辅助篇


第14章RabbitMQ消息组件;


1.RabbitMQ是一款基于AMQP的消息组件,其处理性能要比JMS组件更高。


2.RabbitMQ需要 Erlang语言环境支持,并且提供完善的管理控制中心。


3.RabbitMQ可以创建临时消息或持久化消息,消息类型由用户创建的队列类型来决定。


4.RabbitMQ中支持虚拟主机,以实现不同用户与不同队列之间的隔离。


5.RabbitMQ中交换空间有topic(主题订阅)、direct(直连)和 fanout(广播)3种类型。


6.RabbitMQ集群需要配置镜像队列后才可以实现消息在多个主机里的保存,但HA机制可以依靠Spring框架补充完成。



?


第15章Docker虚拟化容器;


1. Docker是基于云服务的一种应用,可以在一台主机上实现若干服务的部署。


2.一个Docker镜像可以创建出若干个 Docker容器,每一个Docker容器独立存在。


3. Docker镜像可以通过文件保存或加载,也可以提交到DockerHub中进行统一管理。


4.微服务可以利用Maven插件实现Docker镜像的创建,同时也可以将Docker镜像直接提交到DockerHub 中。


5.当需要限定微服务启动顺序时,可以利用DockerCompose编排服务启动顺序,简化项目部署流程。



?



需要这份304页【Java微服务架构实战:SpringBoot +SpringCloud +Docker +RabbitMQ】技术文档的小伙伴,可以转发此文关注小编,扫码下方来获取!!



相关推荐

最新更新

猜你喜欢