谈谈springboot 微服务上下线动态感知

简介: 【10月更文挑战第3天】微服务上下线动态感知是微服务架构中一个非常重要的功能,它允许服务注册中心能够实时地感知到服务的上线和下线,从而确保系统的可用性和负载均衡。

微服务上下线动态感知是微服务架构中一个非常重要的功能,它允许服务注册中心能够实时地感知到服务的上线和下线,从而确保系统的可用性和负载均衡。这个功能通常通过服务注册与发现机制来实现。

底层原理

  1. 服务注册:当一个新的微服务实例启动时,它会向服务注册中心(如Eureka、Consul、Nacos等)注册自己的信息,包括服务名称、IP地址、端口号等。
  2. 服务发现:其他需要调用该服务的微服务实例可以通过服务注册中心查询目标服务的地址信息。
  3. 心跳机制:已注册的服务实例会定期向服务注册中心发送心跳,以表明自己仍然存活。如果注册中心在一定时间内没有收到某个服务实例的心跳,就会认为该实例已经下线,并将其从注册列表中移除。
  4. 事件通知:当服务注册中心感知到服务的上下线变化时,它会通过事件通知机制及时通知订阅了该服务的其他微服务实例,以便它们能够更新自己的本地缓存或重试其他可用的服务实例。

示例代码

下面是一个使用Eureka作为服务注册中心的简单示例,演示如何在Java中实现微服务的上下线动态感知。

1. 引入依赖

首先,在你的Spring Boot项目中引入Eureka的依赖:

xml复制代码
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>

2. 配置Eureka客户端

application.yml中配置Eureka客户端:

yaml复制代码
spring:
application:
name: demo-service
eureka:
client:
service-url:
defaultZone: http://localhost:8761/eureka/
instance:
prefer-ip-address: true
lease-renewal-interval-in-seconds: 5 # 心跳间隔时间  
lease-expiration-duration-in-seconds: 15 # 服务失效时间

3. 启动类

在启动类上添加@EnableEurekaClient注解,以启用Eureka客户端:

java复制代码
import org.springframework.boot.SpringApplication;  
import org.springframework.boot.autoconfigure.SpringBootApplication;  
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;  
@SpringBootApplication
@EnableEurekaClient
public class DemoServiceApplication {  
public static void main(String[] args) {  
        SpringApplication.run(DemoServiceApplication.class, args);  
    }  
}

4. 控制器

创建一个简单的控制器,用于测试服务是否注册成功:

java复制代码
import org.springframework.web.bind.annotation.GetMapping;  
import org.springframework.web.bind.annotation.RestController;  
@RestController
public class DemoController {  
@GetMapping("/hello")
public String hello() {  
return "Hello from Demo Service!";  
    }  
}

5. Eureka服务器(可选)

如果你没有现成的Eureka服务器,可以简单地创建一个Spring Boot项目,并在其中配置Eureka服务器。在application.yml中配置:

yaml复制代码
server:
port: 8761
eureka:
client:
register-with-eureka: false
fetch-registry: false
spring:
application:
name: eureka-server

在启动类上添加@EnableEurekaServer注解:

java复制代码
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);  
    }  
}

测试

  1. 启动Eureka服务器(如果使用的是自己搭建的Eureka服务器)。
  2. 启动DemoServiceApplication
  3. 访问Eureka控制台(通常是http://localhost:8761),你应该能够看到demo-service已经注册成功。
  4. 访问http://localhost:<port>/hello<port>demo-service的端口),你应该能够看到返回的“Hello from Demo Service!”。

现在,当你启动或停止demo-service实例时,Eureka服务器会实时地感知到这一变化,并更新其注册列表。其他微服务可以通过Eureka服务器查询最新的服务地址信息,从而实现动态的服务发现和调用。

相关文章
|
8月前
|
Kubernetes Java 微服务
微服务上下线动态感知实现的技术解析
随着微服务架构的广泛应用,服务的动态管理和监控变得尤为重要。在微服务架构中,服务的上下线是一个常见的操作,如何实时感知这些变化,确保系统的稳定性和可靠性,成为了一个关键技术挑战。本文将深入探讨微服务上下线动态感知的实现方式,从技术基础、场景案例、解决思路和底层原理等多个维度进行阐述,并分别使用Java和Python进行演示介绍。
198 4
|
Java API Spring
Spring Boot第四弹,一文教你如何无感知切换日志框架?
Spring Boot第四弹,一文教你如何无感知切换日志框架?
|
2月前
|
JavaScript 前端开发 Java
制造业ERP源码,工厂ERP管理系统,前端框架:Vue,后端框架:SpringBoot
这是一套基于SpringBoot+Vue技术栈开发的ERP企业管理系统,采用Java语言与vscode工具。系统涵盖采购/销售、出入库、生产、品质管理等功能,整合客户与供应商数据,支持在线协同和业务全流程管控。同时提供主数据管理、权限控制、工作流审批、报表自定义及打印、在线报表开发和自定义表单功能,助力企业实现高效自动化管理,并通过UniAPP实现移动端支持,满足多场景应用需求。
230 1
|
3月前
|
前端开发 Java 关系型数据库
基于Java+Springboot+Vue开发的鲜花商城管理系统源码+运行
基于Java+Springboot+Vue开发的鲜花商城管理系统(前后端分离),这是一项为大学生课程设计作业而开发的项目。该系统旨在帮助大学生学习并掌握Java编程技能,同时锻炼他们的项目设计与开发能力。通过学习基于Java的鲜花商城管理系统项目,大学生可以在实践中学习和提升自己的能力,为以后的职业发展打下坚实基础。技术学习共同进步
266 7
|
2月前
|
供应链 JavaScript BI
ERP系统源码,基于SpringBoot+Vue+ElementUI+UniAPP开发
这是一款专为小微企业打造的 SaaS ERP 管理系统,基于 SpringBoot+Vue+ElementUI+UniAPP 技术栈开发,帮助企业轻松上云。系统覆盖进销存、采购、销售、生产、财务、品质、OA 办公及 CRM 等核心功能,业务流程清晰且操作简便。支持二次开发与商用,提供自定义界面、审批流配置及灵活报表设计,助力企业高效管理与数字化转型。
213 2
ERP系统源码,基于SpringBoot+Vue+ElementUI+UniAPP开发
|
6月前
|
JavaScript Java 测试技术
基于SpringBoot+Vue实现的留守儿童爱心网站设计与实现(计算机毕设项目实战+源码+文档)
博主是一位全网粉丝超过100万的CSDN特邀作者、博客专家,专注于Java、Python、PHP等技术领域。提供SpringBoot、Vue、HTML、Uniapp、PHP、Python、NodeJS、爬虫、数据可视化等技术服务,涵盖免费选题、功能设计、开题报告、论文辅导、答辩PPT等。系统采用SpringBoot后端框架和Vue前端框架,确保高效开发与良好用户体验。所有代码由博主亲自开发,并提供全程录音录屏讲解服务,保障学习效果。欢迎点赞、收藏、关注、评论,获取更多精品案例源码。
|
6月前
|
JavaScript Java 测试技术
基于SpringBoot+Vue实现的家政服务管理平台设计与实现(计算机毕设项目实战+源码+文档)
面向大学生毕业选题、开题、任务书、程序设计开发、论文辅导提供一站式服务。主要服务:程序设计开发、代码修改、成品部署、支持定制、论文辅导,助力毕设!
|
6月前
|
JavaScript 搜索推荐 Java
基于SpringBoot+Vue实现的家乡特色推荐系统设计与实现(源码+文档+部署)
面向大学生毕业选题、开题、任务书、程序设计开发、论文辅导提供一站式服务。主要服务:程序设计开发、代码修改、成品部署、支持定制、论文辅导,助力毕设!
|
6月前
|
JavaScript NoSQL Java
基于SpringBoot+Vue实现的大学生就业服务平台设计与实现(系统源码+文档+数据库+部署等)
面向大学生毕业选题、开题、任务书、程序设计开发、论文辅导提供一站式服务。主要服务:程序设计开发、代码修改、成品部署、支持定制、论文辅导,助力毕设!
|
6月前
|
JavaScript Java 测试技术
基于Java+SpringBoot+Vue实现的车辆充电桩系统设计与实现(系统源码+文档+部署讲解等)
面向大学生毕业选题、开题、任务书、程序设计开发、论文辅导提供一站式服务。主要服务:程序设计开发、代码修改、成品部署、支持定制、论文辅导,助力毕设!