作者 | 波哥
审校 | 孙淑娟
SpringCloud是目前微服务转型的首选,主要得益于其活跃的社区支持度以及全量的配套组件,本章笔者将会把SpringCloud Netfix的几个核心组件组合起来,和老铁们一起逐步完成全套的应用框架搭建,这样有需要的老铁们在项目中就可以直接使用啦。
在SpringCloud Netfix中,核心的组件包括:注册中心(Eureka)、负载均衡(Ribbon)、服务调用(Feign)、熔断及降级(Hystrix)、网关(Gateway)、配置中心(Config)、链路追踪(Sleuth)等几大组件。
我们都知道SpringCloud是基于SpringBoot整出来的微服务框架,换言之在开发SpringCloud微服务的时候,咱就少不了要使用SpringBoot,所以这里的整合SpringCloud也就遵循了SpringBoot的某种整合的规范,比如对于依赖的引用就遵守:spring-cloud-starter-xxx这种规范,这里的xxx指的就是咱们使用的组件,比如如果咱们需要整合Ribbon,那它的依赖名称就是spring-cloud-starter-netflix-ribbon。
首先笔者将应用的整体情况做如下介绍:
1.应用的整体架构图:
2.使用的SpringCloud的版本是Hoxton.SR9,老铁们可以根据自己需要选择版本。
3.微服务的代码层级关系
其中parent为所有模块的父依赖,主要管理公共依赖;common是各个模块都需要用到的一些通用类;springcloud-demo-eureka-service则是eureka注册中心以及配置中心;global-gateway是网关;order-demo和product-demo是具体的服务。
4.JDK版本笔者用的是JDK1.8。
5.需要提前下载zipkin服务,下载地址大家到网上搜,下载后执行:java -jar zipkin.jar启动即可,然后访问:http://localhost:9411/zipkin/看看能否正常访问,正常情况下访问显示如下:
6.登录到Github上,创建一个服务,比如笔者这里创建了springcloud-demo-config的服务,用于存放配置文件。
7.启动顺序:注册中心和配置中心->服务提供者->消费者->网关。
接下来就看每个模块的代码了:
1.parent
parent的主要作用是管理公共的依赖,核心就是一个pom.xml文件,需要注意的是,它的parent是spring-boot-starter-parent:
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.3.6.RELEASE</version>
</parent>
<groupId>my.springcloud.demo</groupId>
<artifactId>parent</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>pom</packaging>
<properties>
<java.version>8</java.version>
<spring-cloud.version>Hoxton.SR9</spring-cloud.version>
</properties>
<modules>
<module>product-demo</module>
<module>springcloud-demo-eureka-service</module>
<module>order-demo</module>
<module>springcloud-demo-eureka-service2</module>
<module>common</module>
<module>global-gateway</module>
</modules>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<dependency>
<groupId>my.springcloud.demo</groupId>
<artifactId>common</artifactId>
<version>0.0.1-SNAPSHOT</version>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<