(四)Eureka Server用户认证(双节点为例)

1.添加依赖

在microservice-discovery-eureka的pom.xml中添加依赖:

<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-security</artifactId>
        </dependency>

 

2.application.xml修改

1.在microservice-discovery-eureka的application.xml中添加账户名和密码:

security:
basic:
enabled: true # 开启基于HTTP basic的认证
user:
name: user
password: password # 配置登录账号和密码
2.修改 microservice-discovery-eureka的 application.yml中的eureka.client.serviceUrl.defaultZone为以下形式 http://user:password@EUREKA_HOST:EUREKA_PORT/eureka/
 
3. application.yml如下:
spring:
  application:
    name: microservice-discovery-eureka
# 用户认证配置
security:
  basic:
    enabled: true
  user:
    name: user
    password: password
---
spring:
  profiles: peer1
server:
  port: 8761
eureka:
  instance:
    # 指定profile=peer1时,主机名是peer1
    hostname: peer1
  client:
    service-url:
      # defaultZone: http://localhost:8762/eureka/
      defaultZone: http://user:password@localhost:8762/eureka/
---
spring:
  profiles: peer2
server:
  port: 8762
eureka:
  instance:
    # 指定profile=peer2时,主机名是peer2
    hostname: peer2
  client:
    service-url:
      # defaultZone: http://localhost:8761/eureka/
      defaultZone: http://user:password@localhost:8761/eureka/

 

3.测试

启动 microservice-discovery-eureka,访问http://localhost:8761需要身份验证,输入用户名和密码即可登录(user/password

4.微服务注册到需要认证的Eureka Server

 将microservice-provider-user的application.xml中的defaultZone修改为以下形式

http://user:password@EUREKA_HOST:EUREKA_PORT/eureka/
 
application.xml文件如下:
 
server:
  port: 8000
spring:
  application:
    name: microservice-provider-user
  jpa:
    generate-ddl: false
    show-sql: true
    hibernate:
      ddl-auto: none
  datasource:                           # 指定数据源
    platform: h2                        # 指定数据源类型
    schema: classpath:schema.sql        # 指定h2数据库的建表脚本
    data: classpath:data.sql            # 指定h2数据库的数据脚本
logging:                                # 配置日志级别,让hibernate打印出执行的SQL
  level:
    root: INFO
    org.hibernate: INFO
    org.hibernate.type.descriptor.sql.BasicBinder: TRACE
    org.hibernate.type.descriptor.sql.BasicExtractor: TRACE

eureka:
client:
serviceUrl:
defaultZone:http://user:password@localhost:8761/eureka/,http://user:password@localhost:8762/eureka/
  instance:
    prefer-ip-address: true

management:
  security:
    enabled: false

info:
  app:
    name: @project.artifactId@
    encoding: @project.build.sourceEncoding@
    java:
      source: @java.version@
      target: @java.version@

5.访问登录即可

 

### 回答1: Eureka Server是Netflix开源的服务发现组件,用于实现微服务架构中的服务注册与发现。它充当了服务注册中心的角色,负责管理所有微服务的注册信息,并提供查询、监控等功能。 Eureka Client是基于Eureka Server的客户端,用于将自己的服务注册到Eureka Server上,并从Eureka Server上获取其他服务的信息。它可以自动地将自己的服务注册到Eureka Server上,并定时向Eureka Server发送心跳,以保证自己的服务状态始终可用。同时,它还可以从Eureka Server上获取其他服务的信息,以便进行服务调用。 ### 回答2: Eureka是Netflix开发的一套基于REST的服务发现系统,允许服务在运行期间注册、协调和发现。Eureka由两个主要组件构成:Eureka serverEureka client。 Eureka serverEureka系统的核心组件,它是服务注册中心。Eureka server维护着所有可用服务的信息,包括服务的实例列表、IP地址和端口号等。Eureka server还会定期检查服务的可用性,以便列表中只包含可用的服务实例。服务实例将自己注册到Eureka server,并向其发送心跳以表明自己仍然可用。Eureka server还会在服务实例出现故障或无响应时将其从列表中删除,确保调用者只会访问到可用的服务。 Eureka client是服务提供方的组件,它将自己注册到Eureka server并发送心跳以表明自己仍然可用。Eureka client会定期从Eureka server获取服务列表,以便知道哪些服务实例是可用的。一旦服务实例出现故障或无响应,Eureka client会重新注册自己以确保服务列表的正确性。 Eureka serverEureka client的结合使得我们能够轻松地实现服务的注册、发现和协调,实现服务间的高效通信。Eureka还提供了丰富的扩展点和API,允许我们自定义各种功能和策略,以满足不同场景和需求的要求。 ### 回答3: Eureka是Netflix开源的一款服务发现框架,它支持在云端部署的服务,它能够帮助我们在环境中(如微服务架构)自动化的管理和维护服务的地址,从而使各个服务之间更加高效和协作。其中,Eureka ServerEureka Client分别是Eureka的服务端和客户端。 Eureka Server是一个可用的服务注册中心,在微服务架构中,它扮演了一个重要的角色。Eureka Server负责维护注册表,所有的微服务都可以在这个注册中心注册自己,记录它们所处的地址以及端口等(在Eureka Server中他们被称之为服务实例)。 对于一个服务,当这个服务确定好自己的服务ID、服务名和服务地址等信息后,首先需要将自己注册到Eureka Server中,这样其他微服务才能够通过查询到这个服务所在的地址,来访问到这个服务。 而Eureka Client则扮演着微服务的客户端,他是整个微服务系统中向注册中心Eureka Server注册的微服务,就像是公司ERP系统那样的一个客户端,负责跟Eureka Server通信、注册微服务实例,以及从Eureka Server中查询服务实例列表等等。 在微服务架构中,微服务的数量很多。当微服务的数量越来越多时,Eureka Server作为微服务的注册中心起到了非常重要的作用,它们可以更方便的找到其他服务以及管理和协调服务。而Eureka Client则为各个微服务之间提供了一个很好的通信平台,协同运行微服务。 总之,Eureka ServerEureka Client是构成Eureka体系的两个重要组成部分,它们能够共同协作,来建立一个高效的微服务体系,为现代化的应用架构提供了必要的支持。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值