微服务注册与发现——Eureka

文章目录

服务发现(注册)机制

nodejs的Eureka Client开源实现

服务发现组件具备功能:

服务注册表

服务注册与服务发现

服务检查

Eureka架构图

Eureka使用

引用

java 复制代码
<dependencies>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
    </dependency>
</dependencies>

配置

java 复制代码
server:
  port: 8761

eureka:
  client:
    registerWithEureka: false # 是否将自己注册到Eureka Server
    fetch-registry: false # 是否从Eureka Server获取注册信息
    service-url:
      defaultZone: http://localhost:8761/eureka/ # 设置与Eureka Server交互的地址,多个地址用,分隔

启动类标记

java 复制代码
@SpringBootApplication
@EnableEurekaServer // 声明这是一个Eureka Server
public class EurekaApplication {
    public static void main(String[] args) {
        SpringApplication.run(EurekaApplication.class, args);
    }
}

访问

http://localhost:8761/

微服务注册

微服务工程添加引用

注意添加版本号,否则会下载不下来

java 复制代码
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-eureka</artifactId>
    <version>1.4.7.RELEASE</version>
</dependency>

增加配置

java 复制代码
spring:
  application:
    name: microservice-provider-user # 用于指定注册到Eureka Server上的应用名称

eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8761/eureka/
    instance:
      prefer-ip-address: true # 表示将自己的IP注册到Eureka Server

启动类增加注解

java 复制代码
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
@EnableDiscoveryClient // 声明这是一个Eureka Client

启动服务注册

Eureka Server集群部署

防止因Eureka Server宕机导致微服务不可用

通过运行多个实例并相互注册的方式实现高可用部署,实例间彼此增量地同步信息,确保所有节点数据一致。

修改配置文件

java 复制代码
spring:
  application:
    name: microservice-discovery-eureka
---
spring:
  config:
    activate:
      on-profile: peer1 # 指定profile=peer1
server:
  port: 8761
eureka:
  instance:
    hostname: peer1 # 指定当profile=peer1时,主机名是peer1
  client:
    serviceUrl:
      defaultZone: http://peer2:8762/eureka/ # 将自己注册到peer2这个Eureka上面去
---
spring:
  config:
    activate:
      on-profile: peer2
server:
  port: 8762
eureka:
  instance:
    hostname: peer2
  client:
    serviceUrl:
      defaultZone: http://peer1:8761/eureka/

启动多个eureka实例

java -jar microservice-discovery-eureka-3.0.2.jar --spring.profiles.active=peer1

java -jar microservice-discovery-eureka-3.0.2.jar --spring.profiles.active=peer2


微服务注册到多个eureka实例

java 复制代码
eureka:
  client:
    serviceUrl:
      defaultZone: http://peer1:8761/eureka/,http://peer2:8762/eureka/
    instance:
      prefer-ip-address: true # 表示将自己的IP注册到Eureka Server

为Eureka Server添加用户认证

前面的示例均可以匿名访问,可以通过spring-security先登录之后在访问

引入spring-security

java 复制代码
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-security</artifactId>
</dependency>

配置

java 复制代码
server:
  port: 8761

eureka:
  client:
    registerWithEureka: false # 是否将自己注册到Eureka Server
    fetch-registry: false # 是否从Eureka Server获取注册信息
    service-url:
      defaultZone: http://user:password123@localhost:8761/eureka/
spring:
  security:
    user:
      name: user # 配置登录的账号
      password: password123 # 配置登录的密码

关闭security的csrf,否则client无法注册

未设置,client注册会报Cannot execute request on any known server

java 复制代码
/**
 * 高版本的丢弃了
 *
 * security:
 *   basic:
 *    enabled: true
 * 配置,应该使用以下方式开启
 * @param http
 * @throws Exception
 */
@Configuration
@EnableWebSecurity
public class WebSecurityConfig {
    @Bean
    public SecurityFilterChain filterChain(HttpSecurity http) throws Exception{
        http.sessionManagement().sessionCreationPolicy(SessionCreationPolicy.NEVER);
        http.csrf().disable();
        //注意:为了可以使用 http://${user}:${password}@${host}:${port}/eureka/ 这种方式登录,所以必须是httpBasic,
        // 如果是form方式,不能使用url格式登录
        http.authorizeRequests().anyRequest().authenticated().and().httpBasic();
        return http.build();
    }
}

client注册

仅需修改注册地址即可,注意和server保持一致

java 复制代码
eureka:
  client:
    service-url:
      defaultZone: http://user:password123@localhost:8761/eureka/ # 需要这种格式 http://user:password@EUREKA_HOST:EUREKA_PORT/eureka/

Eureka自我保护模式

https://blog.csdn.net/fengzelun/article/details/117718784

常见问题

1、Cannot execute request on any known server

https://juejin.cn/post/6995434651862958087

相关推荐
tiger从容淡定是人生11 小时前
AI替代软件战略(一):从 CCleaner 到 MCP 架构重构 —— TigerCleaner 的工程实践
人工智能·重构·架构·c#·mcp
一切皆是因缘际会11 小时前
下一代 AI 架构:基于记忆演化与单向投影的安全智能系统
大数据·人工智能·深度学习·算法·安全·架构
falldeep11 小时前
五分钟了解OpenClaw底层架构
人工智能·算法·机器学习·架构
Agent产品评测局11 小时前
流程型制造业生产节拍智能调整,落地方法与案例 | 2026工业AI Agent架构全景解析
人工智能·ai·chatgpt·架构
灰阳阳12 小时前
MySQL的基本架构
数据库·mysql·架构
程序员老邢12 小时前
【产品底稿 11】架构规整收官:从混乱到清晰,工程结构、表命名、模块分层一次性定型
后端·架构·springboot·产品底稿·架构规整·模块分层·数据库规范
空中海12 小时前
Docker入门到精通
java·docker·eureka
大江东去浪淘尽千古风流人物13 小时前
【MASt3R-SLAM】端到端密集SLAM系统:三进程架构与10大核心创新点深度解析
架构
aXin_ya13 小时前
微服务第九天 分布式缓存(Redis)
分布式·缓存·微服务
byoass13 小时前
企业云盘高可用架构:主备切换、负载均衡与健康检查实战
运维·网络·安全·架构·云计算·负载均衡