SpringBoot与SpringCloud集成
SpringBoot与SpringCloud集成 :
简介
Spring Cloud是一系列框架的有序集合。它利用Spring Boot的开发便利性巧妙地简化了分布式系统基础设施的开发,如服务发现注册、配置中心、消息总线、负载均衡、断路器、数据监控,都可以用Spring Boot的开发风格做到一键启动和部署。Spring Cloud并没有重复制造*,它只是将目前各家公司开发的比较成熟、经得起实际考验的服务框架组合起来,通过Spring Boot风格进行再封装屏蔽掉了复杂的配置和实现原理,最终给开发者留出了一套简单易懂、易部署和易维护的分布式系统开发工具包。
关于微服务相关文档可以点击此处查看。
常用组件
- 服务发现——Netflix Eureka
- 客服端负载均衡——Netflix Ribbon
- 断路器——Netflix Hystrix
- 服务网关——Netflix Zuul
- 分布式配置——Spring Cloud Config
在后续的学习中,会给大家继续介绍。
步骤
创建项目
项目结构如下,eureka-server外,在创建项目时选中Eureka Server 其余都应该为Eureka Discovery
pom文件配置
1 |
|
在eureka-server中我们添加application.yml配置文件。
1 |
server: |
在EurekaServerApplication中我们添加@EnableEurekaServer 注解
1 |
package com.hph.eurek; |
启动项目
provider
下面我们来编写provider项目代码
pom文件配置如下
1 |
|
创建服务
项目结构如图所使
1 |
package com.hph.provider.service; |
配置视图控制器
1 |
package com.hph.provider.controller; |
编写配置文件
1 |
server: |
启动服务
再去查看一下服务端
服务成功注册。
我们可以更换服务端口把它打成jar包实现多服务的注册测试。
consumer
consumer端项目结构如下
1 |
package com.hph.consumer; |
1 |
package com.hph.consumer.controller; |
启动后我们发现在Eureka上注册了另外一个服务
测试
我们访问consumer8200端口的buy方法。我们可以说这个服务时负载均衡的。它使用了轮询的方式。
后续会继续学习关于SpringClould的相关知识。