【spring cloud】(一)Eureka中的服务注册与发现

1 服务治理

服务治理是微服务架构中最为核心和基础的模块,主要来实现各个微服务实例的自动化注册与发现。为了解决微服务架构中的服务实例维护问题,引入了eureka来进行维护,同时也简化的这些服务之间的关系,更加简单方便。
在这里插入图片描述
服务治理:当我们在说微服务治理的时候究竟在说什么

2 服务间调用

在服务间的互相调用,最原始的方式是谁需要就添加谁的依赖,以前的场景是这样的:
服务A调用服务C和服务D,服务B调用服务C和服务D
在这里插入图片描述
现在的服务都比较简单,容易找到,所以我们将这些服务都注册到一个注册中心里面,然后如果我们需要调用这些服务都需要经过一个注册中心才可以找得到。
在这里插入图片描述
Eureka 分为 ServerClient

Server :注册中心
Client :注册进注册中新的服务

Client 通常分 为提供者(Provider)消费者(Consumer)

ServerClient 都是提供了高可用的配置:

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 代码示例

待上传

4.2 相关推荐

【spring cloud】(二)保证Eureka高可用的集群搭建

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Geek-Banana

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值