前言
有人调侃我们说:
- 程序员不如送外卖。送外卖是搬运食物,自己是搬运代码,都不产出新的东西……
- 透支体力,又消耗健康,可替代性极强,30岁之后就要面临被优化的危险……
- 想跳槽,但是更高的平台难进,同级别的平台又是重复……
- 想利用业余时间学习提升,但是自己能力有限,很难形成知识体系…
这些其实都是初级程序员面临的困境,当你提高自身能力,登上更高的层级之后,无论薪资还是发展都会有很大的提升。
那么问题来了,怎么才能度过初级程序员的瓶颈,进阶成为高薪工程师呢?
本文是由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使用一系列的注解来简化开发过程。
[图片上传失败…(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 文件来实现项目的发布。
第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编排服务启动顺序,简化项目部署流程。