前言

有人调侃我们说:

  • 程序员不如送外卖。送外卖是搬运食物,自己是搬运代码,都不产出新的东西……
  • 透支体力,又消耗健康,可替代性极强,30岁之后就要面临被优化的危险……
  • 想跳槽,但是更高的平台难进,同级别的平台又是重复……
  • 想利用业余时间学习提升,但是自己能力有限,很难形成知识体系…

这些其实都是初级程序员面临的困境,当你提高自身能力,登上更高的层级之后,无论薪资还是发展都会有很大的提升。

那么问题来了,怎么才能度过初级程序员的瓶颈,进阶成为高薪工程师呢?

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

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

java 微服务架构应用 java微服务架构实战 pdf_java 微服务架构应用

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

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

目录

java 微服务架构应用 java微服务架构实战 pdf_java_02

主要内容

全文涉及到的技术包括: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使用一系列的注解来简化开发过程。

[图片上传失败…(image-c32738-1670046718848)]

第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 文件来实现项目的发布。

java 微服务架构应用 java微服务架构实战 pdf_java 微服务架构应用_03

第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、字符串等数据处理,还可以使用日期格式化指令进行日期显示格式的处理。

java 微服务架构应用 java微服务架构实战 pdf_腾讯云_04

第4章SpringBoot与Web应用;

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

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

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

4.SpringBoot可以使用HandlerInterceptor拦截器对控制层的请求进行拦截。

5.SpringBoot可以直接导入 spring-boot-starter-aop编写AOP拦截器,实现业务层拦截。

java 微服务架构应用 java微服务架构实战 pdf_腾讯云_05

第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实现单点登录控制。

java 微服务架构应用 java微服务架构实战 pdf_java 微服务架构应用_06

第二部分SpringCloud篇;

第6章SpringCloud简介;

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

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

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

java 微服务架构应用 java微服务架构实战 pdf_java 微服务架构应用_07

第7章SpringCloud与Restful;

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

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

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

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

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

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

java 微服务架构应用 java微服务架构实战 pdf_微服务_08

第8章Eureka注册服务;

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

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

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

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

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

java 微服务架构应用 java微服务架构实战 pdf_架构_09

第9章SpringCloud服务组件;

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

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

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

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

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

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

java 微服务架构应用 java微服务架构实战 pdf_腾讯云_10

第10章SpringCloudConfig;

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

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

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

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

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

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

java 微服务架构应用 java微服务架构实战 pdf_微服务_11

第11章SpringCloudStream;

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

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

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

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

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

java 微服务架构应用 java微服务架构实战 pdf_java_12

第12章SpringCloudSleuth;

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

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

java 微服务架构应用 java微服务架构实战 pdf_微服务_13

第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获取用户资源即可,同时也可以针对用户的角色进行统一管理。

java 微服务架构应用 java微服务架构实战 pdf_腾讯云_14

第三部分微服务辅助篇

第14章RabbitMQ消息组件;

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

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

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

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

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

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

java 微服务架构应用 java微服务架构实战 pdf_java_15

第15章Docker虚拟化容器;

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

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

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

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

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

java 微服务架构应用 java微服务架构实战 pdf_架构_16