SpringBoot 快速构建微服务体系 知识点总结
可以通过http://start.spring.io/构建一个SpringBoot的脚手架项目
一、微服务
1、SpringBoot是一个可使用Java构建微服务的微框架。
2、微服务就是要倡导大家尽量将功能进行拆分,将服务粒度做小,使之可以独立承担对外服务的职责,沿着这个思路开发和交付的软件服务实体就叫做“微服务”。

3、微服务的好处
(1)独立,独立,还是独立。每一个微服务都是一个小王国,跳出了“大一统”(Monolith)王国的统治,开始从各个层面打造自己的独立能力,从而保障自己的小王国可以持续稳固的运转。
(2)多语言生态。微服务独立之后,给了对应的团队和组织快速迭代和交付的能力,同时,也给团队和组织带来了更多的灵活性,实际上,对应交付不同的微服务的团队或者组织来说,现在可以基于不同的计算机语言生态构建这些微服务。
二、Spring框架本质
1、Spring IoC(Inversion of Control)其实有两种形式,一种就是DI(Dependency Injection依赖反转),另一种是DL(Dependency Lookup依赖查找)。DI是当前软件实体被动接受其依赖的组件被IoC容器注入,DL是当前软件实体主动去某个服务注册地查找其依赖的那些服务。
Spring IoC容器的依赖注入工作可以分为两个阶段:
(1)收集和注册:构建和收集bean定义的阶段,这样IoC容器中充斥着一个个独立的bean,它们之间没有任何关系。
(2)分析和组装:分析这些已经在IoC容器之中的bean,然后根据它们之间的依赖关系先后组装它们。如果IoC容器发现某个bean依赖另一个bean,它就会将这另一个bean注入给依赖它的那个bean,直到所有bean的依赖都注入完成,所有bean都”整装待发“,整个IoC容器的工作即算完成。
2、 JavaConfig
Spring框架推出并持续完善了基于Java代码和Annotation元信息的依赖关系绑定描述方式,即JavaConfig项目。
基于JavaConfig方式的依赖关系绑定描述基本上映射了最早的基于XML的配置方式:
任何一个标注了@Configuration的Java类定义都是一个JavaConfig配置类。
任何一个标注了@Bean的方法,其返回值将作为一个bean定义注册到Spring的IoC容器,方法名将默认成为该bean定义的id。
如果一个bean的定义依赖其他bean,则直接调用对应JavaConfig类中依赖bean的创建方法就可以了。
那些高曝光率的Annotation:
@ComponentScan、@PropertySource与@PropertySources、@Import与@ImportSource

三、SpringBoot的工作机制
1、@SpringBootApplication
对于SpringBoot应用来说,重要的只有三个Annotation,而“三体”结构实际上指的就是这个三个Annotation:@Configuration、@EnableAutoConfiguration、@ComponentScan
2、SpringApplication:SpringBoot程序启动的一站式解决方案
3、SpringBoot应用启动步骤简要示意图

四、了解纷杂的spring-boot-starter
1、SpringBoot微框架从两个主要层面影响Spring社区的开发者们:
(1)基于Spring框架的“约定优先于配置(COC)"理念以及最佳实践之路;
(2)提供了针对日常企业应用研发各种场景的spring-boot-starter自动配置依赖模块,如此多“开箱即用”的依赖模块,使得开发各种场景的Spring应用更加快速和高效。
2、spring-boot-starter-aop
Java平台上的AOP(Aspect Oriented Programming)方案基本上已经以SpringAOP结合AspectJ的方式稳固下来。
3、spring-boot-starter-actuator
spring-boot-starter-actuator自动配置模块用于支持SpringBoot应用的监控。


五、SpringBoot微服务实践探索

1、使用SpringBoot构建微服务
(1)创建基于Dubbo框架的SpringBoot微服务
Dubbo:一款基于TCP长连接通信(Netty)的高性能服务治理框架。
将Dubbo微服务以SpringBoot形式标准化了,如此一来,我们既可以享受SpringBoot框架和周边的一系列研发支持,也可以用统一的形式发布、部署和运维。
微服务的一个特点就是数量多。
(2)使用SpringBoot快速构建Web API
2、SpringBoot微服务的发布与部署

基于Docker的发布与部署方式:



3、SpringBoot微服务的注册与发现



4、SpringBoot微服务的监控与运维



从局部性触发式报警到系统性智能化报警

实际上,一种有效的报警体系应该是能够系统化地综合考虑所有监控层级的数据,然后汇总和分析,最终发出一个行之有效的报警,称为系统性智能化报警。
5、SpringBoot微服务的安全与防护
深度防御(Defence In Depth)
访问的认证和授权的过程(Authentication And Authorization)

6、SpringBoot微服务体系的脊梁:发布与部署平台


SpringBoot 快速构建微服务体系 知识点总结的更多相关文章
- Springboot揭秘-快速构建微服务体系-王福强-2016年5月第一次印刷
JavaConfig项目: spring IOC有一个非常核心的概念——Bean.由Spring容器来负责对Bean的实例化,装配和管理.XML是用来描述Bean最为流行的配置方式.Spring可以从 ...
- SpringBoot揭秘:快速构建微服务体系
chapter 2: 饮水思源:回顾与探索Spring框架本质 IoC其实有两种方式,一种是DI(dependency Injection),一种是DL(dependency Lookup 依赖查找, ...
- 《SpringBoot揭秘 快速构建微服务体系》读后感(一)
SpringIOC IOC有两种方式:一种是DI,另一种是DL,即Dependency Lookup(依赖查找).前者是当前软件实体被动接受其依赖的其他组件被IoC容器注入,而后者则是当前软件实体主动 ...
- 《SpringBoot揭秘 快速构建微服务体系》读后感(五)
应用日志和spring-boot-starter-logging 快速web应用开发与spring-boot-starter-web 1.项目结构层面的约定
- 《SpringBoot揭秘 快速构建微服务体系》读后感(三)
SpringApplication:SpringBoot程序启动的一站式解决方案 深入探索SpringApplication执行流程 因为书上的版本是1.2的,比较老,这里参考http://blog. ...
- 《SpringBoot揭秘 快速构建微服务体系》读后感(二)
最简单的springBoot应用 package com.louis.test; import org.springframework.boot.SpringApplication; import o ...
- 《SpringBoot揭秘 快速构建微服务体系》读后感(四)
再谈自动配置 基于条件的自动配置 调整自动配置的顺序
- [高清] SpringBoot揭秘快速构建微服务体系
------ 郑重声明 --------- 资源来自网络,纯粹共享交流, 如果喜欢,请您务必支持正版!! --------------------------------------------- 下 ...
- 通过GeneXus如何快速构建微服务架构
概览 “微服务”是一个非常广泛的话题,在过去几年里,市面上存在着各种不同的定义. 虽然对这种架构方式没有一个非常精确的定义,但仍然有一些概念具有代表性. 微服务有着许多围绕业务能力.自动化部署.终端智 ...
随机推荐
- 性能工具之JMeter+InfluxDB+Grafana打造压测可视化实时监控
一.安装配置InfluxDB InfluxDB是GO语言开发的一个开源分布式时序数据库,非常适合存储指标.事件.分析等数据.有人做过mysql和influxDB对比,存储1000万条数据mysql要7 ...
- Dp状态设计与方程总结
1.不完全状态记录<1>青蛙过河问题<2>利用区间dp 2.背包类问题<1> 0-1背包,经典问题<2>无限背包,经典问题<3>判定性背包问 ...
- Excel 技巧
<!-- Excel跳转到指定行指定列 --> =HYPERLINK("#"&ADDRESS(要跳转到的行数,要跳转到的列数),"跳转")
- 方法重载(overload)与方法重写(override)
一.方法重载: 在同一个类中,允许存在一个及以上的同名方法,只要他们的参数列表不同(参数的个数或者参数的类型不同)即可.注意方法重载与返回值类型.访问权限修饰符.和抛出的异常无关.重载是在本类中,与继 ...
- 73.Largest Rectangle in Histogram(最大矩形)
Level: Hard 题目描述: Given n non-negative integers representing the histogram's bar height where the ...
- Windows程序设计--(三)窗口与消息
3.1 窗口的创建 3.1.1 系统结构概述 所谓「Windows给程序发送消息」,是指Windows呼叫程序中的一个函数,该函数的参数描述了这个特定消息.这种位于Windows程序中的函数称为「窗口 ...
- Linux命令(干货)
@ vim 编辑快捷键 ctrl + n 是自动补齐 ctrl + p 是往上选择 ctrl + f 是下一屏幕 ctrl + b 是上一屏幕 w:是移动一个单词 b:是向前一个单词 d^:当前行中, ...
- Linux之scp命令的使用
Linux之scp命令的使用 1. scp简介 1.1 命令功能: scp是 secure copy的缩写, scp是linux系统下基于ssh登陆进行安全的远程文件拷贝命令.linux的scp命令可 ...
- Error- spark streaming 打包将全部依赖打进去Invalid signature file digest for Manifest main attributes
spark streaming 打包将全部依赖打进去,运行jar包报错:如下 Exception in thread "main" java.lang.SecurityExcept ...
- WriteDataToFile(filename,pJsonData,strlen(pJsonData)+1)
WriteDataToFile(filename,pJsonData,strlen(pJsonData)+1) 字节流的长度计算 发送的txt 文件是对的 zip exe出现字节计算错误 strlen ...