1 服务治理
服务治理是微服务架构中最为核心和基础的模块,主要来实现各个微服务实例的自动化注册与发现。为了解决微服务架构中的服务实例维护问题,引入了eureka来进行维护,同时也简化的这些服务之间的关系,更加简单方便。
服务治理:当我们在说微服务治理的时候究竟在说什么
2 服务间调用
在服务间的互相调用,最原始的方式是谁需要就添加谁的依赖,以前的场景是这样的:
服务A调用服务C和服务D,服务B调用服务C和服务D
现在的服务都比较简单,容易找到,所以我们将这些服务都注册到一个注册中心里面,然后如果我们需要调用这些服务都需要经过一个注册中心才可以找得到。
Eureka
分为 Server
和 Client
:
Server
:注册中心
Client
:注册进注册中新的服务
Client
通常分 为提供者(Provider)
和 消费者(Consumer)
Server
和 Client
都是提供了高可用的配置:
Server
:在集群部署时如果有分片出现故障时,就会转入自我保护模式,它在有故障的时候依旧可以继续提供服务的发现和注册,当故障分片恢复运行时,集群的其他分片会把他们的状态再次同步回来。
Client
:同样支持集群部署,部署在不同的服务器上进行同步配置,就可以实现高可用。
3 搭建注册中心
module名称:cloud-eureka-server-7001
目录结构
3.1 依赖引入
<dependencies>
<dependency>
<groupId>com.banana</groupId>
<artifactId>cloud-api-commons</artifactId>
<version>${project.version}</version>
</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-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
3.2 配置文件:application.yml
server:
port: 7001
eureka:
# instance:
# 集群要相互注册
# hostname: eureka-server-7001.com # eureka 服务端的实例名称
# 单机配置
hostname: localhost # eureka 服务端的实例名称
client:
register-with-eureka: false # 表示不向注册中心注册自己
fetch-registry: false # 表示自己端就是注册中心,维护服务实例,不需要去检索服务
service-url:
# 集群配置
# defaultZone: http://eureka-server-7001.com:7001/eureka/,http://eureka-server-7002.com:7002/eureka/
# 单机配置
defaultZone: http://${eureka.hostname}:${server.port}/eureka/
3.3 创建启动类
package com.banana.cloud;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;
@SpringBootApplication
@EnableEurekaServer
public class EurekaServerApplication {
public static void main(String[] args) {
SpringApplication.run(EurekaServerApplication.class, args);
}
}
3.4 运行结果
4 最后
单机搭建很简单,此处不在赘述
4.1 代码示例
待上传