SpringCloud入门介绍

SpringCloud入门介绍

什么是SpringCloud

SpringCloud是基于Springboot 用来开发微服务系统的框架,它提供了微服务开发需要的配置管理,服务发现,断路器、智能路由、全局锁等组件,最重要的是,跟SpringBoot一起用德华,会让你开发微服务架构更加的方便,SpringCloud比Dubbo功能多很多,使用起来也简单方便。服务之间互相调用Http协议就可以

SpringBoot和SpringCloud版本对应关系
SpringCloud入门介绍_第1张图片
在实际开发过程中,我们需要更详细的版本对应 (https://start.spring.io/actuator/info):

SpringCloud入门介绍_第2张图片
spring-cloud-dependencies 版本列表可查看:
https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-dependencies

spring-boot-starter-parent 版本列表可查看:
https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-parent

开发服务注册中心

为什么这么做

我们一个微服务系统会有很多个服务需要管理,所以我们需要开发一个管理中心,其实也就是 “服务注册中心” ,服务注册中心在SpringCloud中使用自带的Eureka,如果你使用的是Dubbo,那么你需要使用第三方插件,“Zookeeper”

1.1创建工作空间
1.2创建一个项目

创建一个SpringBoot项目(Module)版本号2.1.13
模块名为 springboot-eureka

1.3配置pom.xml

引入父级依赖(自动导入)
导入web启动器(spring-boot-starter-web)
// 导入SpringCloud启动器(spring-cloud-dependencies)
引入eureka-server依赖(spring-cloud-starter-netflix-eureka-server)网飞出品

配置SpringCloud依赖管理




org.springframework.cloud
spring-cloud-dependencies
${spring-cloud.version}
pom
import



application.properties配置文件
// 设置服务注册中心端口号为8000
server.port=8000
//应用名,最终在服务注册中心的名字就是这个配置,建议和模块名一样
//服务之间调用就是通过服务注册中心的服务名调用
spring.application.name=server-eureka
 //将eureka安装到哪台服务上,填写的是ip,localhost就代表本机IP
eureka.instance.hostname=localhost
 //registerWithEureka表示是否注册自身到eureka服务器,如果改成true会报个错
// 解释:启动注册,服务注册中心还没启动,就会报错
// 改成false,因为服务注册中心不需要对外提供数据服务,没必要注册进来给别的服务调用
eureka.client.register-with-eureka=false
//fetchRegistry表示是否从eureka服务器获取注册信息。
eureka.client.fetch-registry=false
 //配置的是服务注册中心的http路径,其他服务通过该路径进行注册
 http://localhost:8000/eureka/
eureka.client.service-		url.defaultZone=http://${eureka.instance.hostname}:${server.port}/eureka/
主类/入口类添加注解

添加 @EnableEurekaServer 注解,说明是一个服务注册中心

启动

http://localhost:8000/

SpringCloud入门介绍_第3张图片

服务提供者

服务的 提供者 顾名思义就是一个项目,对外提供一些数据服务,对外暴露一个接口,说白就是我们的一个普通项目,区别在于, 需要把它发布到服务注册中心 ,供别的服务通过在服务注册中心的名字进行调用。

创建项目

创建一个SpringBoot项目
名字为 server-hello

配置pom依赖

引入eureka-client启动器(spring-cloud-starter-netflix-eureka-client)
这个项目需要注册到服务注册中心,相当于是client端
服务注册中心的项目引入是的server启动器





org.springframework.cloud
spring-cloud-dependencies
${spring-cloud.version}
pom
import



配置application.properties文件
端口
server.port=8001
 服务直接的调用是根据这个name值来相互调用的
spring.application.name=server-hello
#提交到这个注册中心
eureka.client.service-url.defaultZone=http://localhost:8000/eureka/
主类添加注解

添加 @EnableEurekaClient 或者 @EnableDiscoveryClient ,如果使用的SpringCloud是D版本或者更高,注解可以省略不写。

@EnableDiscoveryClient(可以将服务注册到Eureka中 也可以将服务注册到Zookeeoer中)

SpringCloud入门介绍_第4张图片

你可能感兴趣的:(SpringCloud入门介绍)