什么是微服务架构 是系统架构上的一种设计风格,将独立的系统拆分成多个小型服务,这些小型服务都在各自独立的进程中运行,服务之间基于HTTP的RESTful API进行通信协作. 每个小型服务都围绕各自的业务功能进行构建.每个服务都维护自身的数据存储.业务开发.自动化测试案例以及独立部署机制. 注:由于有了轻量级的通信协作基础,所以这些微服务可以使用不同的语言编写. 与单体系统的区别 随着业务增长与开发,单体系统会显得更加臃肿,且由于单体系统往往部署在一个进程中,修改一个小功能,为了部署上线会影响其…
Spring Boot项目工程 src/main/java:主程序入口HelloApplication,可以通过直接运行该类来启动Spring Boot应用. src/main/resources:配置目录,该目录用来存放应用的一些配置,比如应用名,服务端口,数据库链接等. 由于引入了web模块,由此产生static目录与template目录,static用来存放静态资源,如:图片.css.js.template用来存放Web页面的模板文件. 由于演示为RESTful API,所以这两个目录暂时…
目前对Springcloud对了解仅限于:“用[注册服务.配置服务]来统一管理其他微服务” 这个水平.有待提高 Springcloud微服务实战这本书是翟永超2017年5月写的,时间已经过去了两年,略旧,不过入门还是可以的. 主要内容包括:服务治理.容错保护.API网关.配置管理.消息总线等 这本书442页,一共11章,现在看来,每一个都要学. 第一章.基础知识 第二章.微服务构建:Springboot 第三章:服务治理:springcloud Eureka 第四章:客户端负载均衡:spring…
SpringCloud学习(SPRINGCLOUD微服务实战) springboot入门 1.配置文件 1.1可以自定义参数并在程序中使用 注解@component @value 例如 若配置文件为application-dat.yml ​book.name = springbook.author = abc @Component@PropertySource(value = "classpath:/application-dat.yml")public class Book{ @va…
Spring Cloud Eureka 服务治理 是微服务架构中最核心最基本的模块.用于实现各个微服务实例的自动化注册与发现. 服务注册: 在服务治理框架中,都会构建一个注册中心,每个服务单元向注册中心登记自己提供的服务,将主机和端口号.版本号.通信协议等一些附加信息告知注册中心,注册中心按服务名分类组织服务清单. 服务注册中心还需要以心跳的方式去监测清单中的服务是否可用,若不可用,需从服务清单中剔除,达到清楚障碍的目的. 服务发现: 服务的调用通过向服务名发起请求调用实现.调用方向服务注册中心…
Spring Cloud Eureka是Spring Cloud Netflix微服务中的一部分,它基于NetFlix Sureka做了二次封装,主要负责完成微服务架构中的服务治理功能. 一.服务治理 服务治理是微服务架构中最为核心和基础的模块.它主要用来实现各个微服务实例的自动化注册与发现. 为了解决微服务架构中的服务实例维护问题,产生了大量的服务治理框架和产品,这下框架和产品的实现都围绕着服务注册与服务发现机制来完成对微服务应用实例的自动化管理. 1.服务注册 在服务治理框架中,通常都会构建…
  回忆一下,在上一篇文章中,我们创建了两个springboot项目,并且在consumer项目中通过restTemplate进行HTTP通信,成功访问到了producer提供的接口,思考一下这样的实现方式有什么问题?   1.consumer必须知道producer的IP,才能调用对方的HTTP接口,并且在consumer代码中使用硬编码的方式来访问producer的HTTP接口,代码耦合度高,实现方式不优雅.也许有童鞋会说,我们可以在application.properties配置文件进行配…
  回忆一下,在前面的文章中,我们使用了spring cloud eureka/ribbon/feign/hystrix/zuul搭建了一个完整的微服务系统,不管是队内还是对外都已经比较完善了,那我们的系统是否还有值得继续优化的地方呢?答案肯定是有的,那就是分布式配置中心config.那什么是分布式配置中心,我们为什么又需要分布式配置中心呢? 什么是分布式配置中心?   所谓配置中心,就是将配置的数据放在某种存储介质中,该介质可以是文件/数据库/中间件等等,像业界常用的zookeeper/Apo…
## 前言   本系列教程旨在为大家演示如何一步一步构建一整套微服务系统,至于其中的数据库用什么,订单ID如何保持唯一,分布式相关问题等等不在我们讨论范围内,本教程为了方便大家后续下载代码运行测试,不依赖任何其他诸如缓存.数据库之类的资源,此类操作我们在项目中使用代码的方式来模拟.   我们的实战过程会教童鞋们一步一步进行演化,让童鞋们了解一个微服务的开发流程:   1.创建两个用于演示的springboot项目,用于后续将其演化为两个微服务.   2.使用Eureka注册中心进行服务治理.  …
这里简单说明一下在Windows系统下开发SpringCloud项目所需要的的基本环境,这里只说明开发过程中基础必须的软件,其他扩展功能(Docker,k8s,MinIO,XXL-JOB,EKL,Keepalived,Nginx,RabbitMQ,Kafka等)用到的软件会在具体使用时详细说明,本地开发的环境软件以Windows版本的安装配置为例,数据库等中间件以Linux(CentOS7)的安装配置为例,其他系统Mac/Linux可自行配置. 后端开发需要准备的环境及软件有:JDK 1.8+,…