1.服务介绍
注册中心eureka-server,配置中心config-server,授权中心服务uaa-service,Turbine聚合监控服务monitoring-service,链路追踪服务zipkin-service,聚合监控服务admin-service,路由网关服务gateway-service,日志服务log-service.另外包含两个资源服务user-service和blog-service.还有一个common工程。
eureka-server:所有的服务都向注册中心eureka-server进行服务注册,使用服务注册中心有两个好处,首先方便查看每个服务的状况,其次时服务注册中心维护了一份服务注册的列表,每个服务的实例都能获得这个列表,可以用于Ribbon的负载均衡和Zuul的智能路由。
config-server:配置中心,服务的所有配置由config-server统一管理,config-server可以从远程Git拉取配置,也可以从本地仓库读取,如果将配置文件放在远程仓库,配置Spring Cloud Bus,可以不在人工重启服务的情况下,进行全局服务的配置刷新。
gateway-service:网关服务使用的是zuul组件,Zuul组件可以实现智能路由,负载均衡的功能。
zipkin-service:它是Spring Cloud Sluth的组件,可以擦好看每个请求在微服务系统中的链路关系。
turbine-service:聚合了user-service和bolg-service的Hystrix Dashboard,可以查看这两个服务的熔断状况。
admin-service:一个Spring boot Admin 工程,提供了非常强大的服务监控功能。
uaa-service:集成了Spring Cloud OAuth2,由这个服务统一授权,返回token,其他的应用服务,如user-service和bolg-service作为资源服务,他的API接口资源是受保护的,需要验证token,并且鉴权后才能访问,
user-service和blog-service:作为资源服务,对外暴露API接口资源。
log-service:作为日志服务,user-service和blog-service服务通过RabbitMQ向log-service发送业务操作日志的消息,日志服务统一持久化操作日志,如有大量的日志需要处理可以使用ELK组件进行处理。
2.搭建项目
首先搭建父工程,SpringBoot版本选择最新的2.1.7,Spring Cloud的版本为G版。
父工程pom:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.wx</groupId>
<artifactId>SpringCloudInAction</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>pom</packaging>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.7.RELEASE</version>
<relativePath/>
</parent>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
<spring-cloud.version>Greenwich.SR2</spring-cloud.version>
</properties>
<modules>
<module>eureka-server</module>
</modules>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<!--利用JSON通过http实现JMX远程管理的开源组件-->
<dependency>
<groupId>org.jolokia</groupId>
<artifactId>jolokia-core</artifactId>
</dependency>
</dependencies>
<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>
</dependencies>
</dependencyManagement>
</project>
eureka pom:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.wx</groupId>
<artifactId>SpringCloudInAction</artifactId>
<version>1.0-SNAPSHOT</version>
</parent>
<groupId>com.wx</groupId>
<artifactId>eureka-server</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>eureka-server</name>
<description>Demo project for Spring Boot</description>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<finalName>app</finalName>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
yml文件:
server:
port: 8000
eureka:
client:
register-with-eureka: false
fetch-registry: false
serviceUrl:
defaultZone: http://localhost:${server.port}/eureka/
加上注解开启eureka server得功能
搭建config-server工程
配置使用的是本地配置的模式
pom文件:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.wx</groupId>
<artifactId>SpringCloudInAction</artifactId>
<version>1.0-SNAPSHOT</version>
</parent>
<groupId>com.wx</groupId>
<artifactId>config-server</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>config-server</name>
<description>Demo project for Spring Boot</description>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-config-server</artifactId>
</dependency>
<!-- actuator-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.retry</groupId>
<artifactId>spring-retry</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-aop</artifactId>
</dependency>
</dependencies>
<build>
<finalName>app</finalName>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
yml文件:
# remote git
#spring:
# cloud:
# config:
# server:
# git:
# uri: https://git.coding.net/xiaoantimes/xiaoantimes-taichi
# searchPaths: backend/repo
# username: 124746406@qq.com
# password:
# label: master
# ---native
spring:
cloud:
config:
server:
native:
search-locations: classpath:/shared
profiles:
active: native
application:
name: config-server
# port
server:
port: 8001
#management:
# security:
# enabled: false
加上注解开启config server的功能
配置中心是不向eureka 注册服务的。