SpringCloud中关于Eureka的小知识---1

第一部分--------微服务的简单搭建

------ 代码连接https://gitee.com/liuxw9715/SpringCloud_Eureka

1. eureka基础

1.1 Eureka的基本架构,有三个部分组成:

Eureka Service --------提供服务注册与发现
Service Provider-------服务提供方、将自身服务注册到Eureka从而使得消费者找到
Service Consumer-----服务消费方,从Eureka获取服务,从而消费

1.2 Eureka 的原理

eureka的使用过程

2. 搭建Eureka Service

2.1创建工程

创建eureka服务

2.2导入坐标

<dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
        </dependency>
    </dependencies>

2.3配置application.yml文件

server:
  port: 8000 #端口号
#配置eureka service
eureka:
  instance:
    hostname: localhost
  client:
    register-with-eureka: false #是否将自己注册到注册中心
    fetch-registry: false #是否从eureka中获取注册信息
    #配置暴露给eureka client的请求地址
    service-url:
      defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/

2.4配置启动类

@SpringBootApplication
@EnableEurekaServer
public class EurekaApplication {
    public static void main(String[] args) {
        SpringApplication.run(EurekaApplication.class,args);
    }
}

2.5启动页面

启动页面

3. 将服务提供者注册到eureka Service中

3.1 引入eurekaClient的坐标

<!--引入EurekaClient-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>

3.2修改application.yml文件添加EurekaService的信息

#配置Eureka
eureka:
  client:
    service-url:
      defaultZone: http://127.0.0.1:8000/eureka/
    instance:
      profer-ip-address: true #使用IP地址注册

3.3修改启动类,添加服务发现的支持(可选)

主要添加@EnableDiscoveryClient注解

@SpringBootApplication
@EntityScan("org.liu.product.entity.po")
//激活EurekaClient
@EnableDiscoveryClient
public class ProductApplication {
    public static void main(String[] args) {
        SpringApplication.run(ProductApplication.class,args);
    }
}

4. 服务消费者通过注册中心获取服务列表并调用

Eureka中的元数据:服务的主机名,IP地址等信息,可以通过eurekaservice进行获取,用于服务之间调用。
微服务A从EurekaService中获取微服务B的数据信息如下;从注册中心获取的数据
使用RestTemplate进行各个服务之间的跳转

object= restTemplate.getForObject("http://" +instance.getHost() +":"+ instance.getPort() +"product/" + id, object.class);

可能图片看起来好理解一点
微服务之间的跳转
总结:到此简单的微服务搭建已经结束

第二部分-------Eureka Service的高可用

5.Eureka Service的高可用

解决方案直接看图,也就是说部署2个Eureka Service服务,且相互注册
Eureka Service的高可用
:只有一个eureka服务如何启动两个----没错就是直接复制,注意修改端口和注册端口的信息
①如何开启两个EurekaService服务
在这里插入图片描述
在这里插入图片描述
②两个application.yml文件的配置

8000端口

spring:
  application:
    name: eureka-service
server:
  port: 8000 #端口号
#配置eureka service
eureka:
  client:
    #配置暴露给eureka client的请求地址
    service-url:
      defaultZone: http://127.0.0.1:8001/eureka/

8001端口

spring:
  application:
    name: eureka-service
server:
  port: 8001 #端口号
#配置eureka service
eureka:
  client:
    #配置暴露给eureka client的请求地址
    service-url:
      defaultZone: http://127.0.0.1:8000/eureka/

③启动之后如下所示,代表成功
8000端口的一个
8000端口
8001端口的一个
8001端口
总结:服务到这里就可以使用了,即使eureka断开一个节点,另一个服务也可以正常的运行。

第三部分-------细节优化

6. 注册中心显示服务器的IP地址:

配置application.yml文件

#配置Eureka
eureka:
  client:
    service-url:
      defaultZone: http://127.0.0.1:8000/eureka/
      #defaultZone: http://127.0.0.1:8000/eureka/,http://127.0.0.1:8001/eureka/ #向多个eureka注册使用逗号隔开
  instance:
    prefer-ip-address: true #使用IP地址注册
    instance-ip: ${spring.cloud.client.ip-address}:${server.port} #向注册中心注册IP地址

7. eureka的服务剔除问题

配置yml文件
在这里插入图片描述

#配置Eureka
eureka:
  client:
    service-url:
      defaultZone: http://127.0.0.1:8000/eureka/
      #defaultZone: http://127.0.0.1:8000/eureka/,http://127.0.0.1:8001/eureka/ #向多个eureka注册使用逗号隔开
  instance:
    prefer-ip-address: true #使用IP地址注册
    instance-ip: ${spring.cloud.client.ip-address}:${server.port} #向注册中心注册IP地址
    lease-renewal-interval-in-seconds: 5 #向注册中心注册服务IP---发送心跳时间5s
    lease-expiration-duration-in-seconds: 10 #续约到期时间,立即到期

8.自我保护机制

当eureka界面出现红色的字体时,表示eureka出现自我保护机制

  • 自我保护机制的关闭
    yam文件中添加

在这里插入图片描述

  server:
    enable-self-preservation: false #关闭自我保护
    eviction-interval-timer-in-ms: 4000 #剔除服务间隔
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值