SpringCloud(第 051 篇)EurekaServer集羣高可用註冊中心以及簡單的安全認證

SpringCloud(第 051 篇)EurekaServer集羣高可用註冊中心以及簡單的安全認證

1、大體介紹

一、前面章節分析了一下 Eureka 的源碼,咱們是否是在裏面注意到了 Peer 節點的複製,爲何要複製節點同步信息呢,其實就是爲了同一個集羣之間的EurekaServer一致性方案的一個實現;
二、因而咱們在本章節就真正的來經過代碼來實現一下EurekaServer之間的高可用註冊中心。
三、至於所謂的安全認證,就是在咱們的客戶端配置defaultZone屬性環節,要帶上用戶名密碼才能夠註冊到高可用註冊中心去;

2、實現步驟

2.1 添加 maven 引用包

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <artifactId>springms-discovery-eureka-ha</artifactId>
    <version>1.0-SNAPSHOT</version>
    <packaging>jar</packaging>

    <parent>
		<groupId>com.springms.cloud</groupId>
		<artifactId>springms-spring-cloud</artifactId>
        <version>1.0-SNAPSHOT</version>
    </parent>

    <dependencies>
        <!-- 服務端發現模塊 -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-eureka-server</artifactId>
        </dependency>

        <!-- 服務端登陸驗證模塊:進入 eureka 的網頁時候須要輸入登陸密碼的模塊 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-security</artifactId>
        </dependency>
    </dependencies>

</project>

2.2 添加應用默認配置文件(springms-discovery-eureka-ha\src\main\resources\application.yml)

spring:
  application:
    name: springms-discovery-eureka-ha
  profiles:
    # 主要激活哪一個配置文件,若是有不清楚的話,能夠回頭看看 Config 配置相關的知識,好比 springms-config-client、springms-config-server
    active: peer1

2.3 添加應用peer1節點默認配置文件(springms-discovery-eureka-ha\src\main\resources\application-peer1.yml)

# 配置 eureka 登陸密碼,輸入地址 http://localhost:8761 時候就須要輸入這個用戶名密碼登陸進去
security:
  basic:
    enabled: true
  user:
    name: admin
    password: admin

server:
  port: 8401
 
eureka:
  datacenter: SpringCloud   # 修改 http://localhost:8761 地址 Eureka 首頁上面 System Status 的 Data center 顯示信息
  environment: Test         # 修改 http://localhost:8761 地址 Eureka 首頁上面 System Status 的 Environment 顯示信息
  instance:
    hostname: peer1
    instance-id: ${spring.application.name}:${server.port}
  client:
#    register-with-eureka: false
#    fetch-registry: false
    service-url:
      defaultZone: http://admin:admin@peer2:8402/eureka,http://admin:admin@peer3:8403/eureka

2.4 添加應用peer2節點默認配置文件(springms-discovery-eureka-ha\src\main\resources\application-peer2.yml)

# 配置 eureka 登陸密碼,輸入地址 http://localhost:8761 時候就須要輸入這個用戶名密碼登陸進去
security:
  basic:
    enabled: true
  user:
    name: admin
    password: admin

server:
  port: 8402
 
eureka:
  datacenter: SpringCloud   # 修改 http://localhost:8761 地址 Eureka 首頁上面 System Status 的 Data center 顯示信息
  environment: Test         # 修改 http://localhost:8761 地址 Eureka 首頁上面 System Status 的 Environment 顯示信息
  instance:
    hostname: peer2
    instance-id: ${spring.application.name}:${server.port}
  client:
#    register-with-eureka: false
#    fetch-registry: false
    service-url:
      defaultZone: http://admin:admin@peer1:8401/eureka,http://admin:admin@peer3:8403/eureka

2.5 添加應用peer3節點默認配置文件(springms-discovery-eureka-ha\src\main\resources\application-peer3.yml)

# 配置 eureka 登陸密碼,輸入地址 http://localhost:8761 時候就須要輸入這個用戶名密碼登陸進去
security:
  basic:
    enabled: true
  user:
    name: admin
    password: admin

server:
  port: 8403
 
eureka:
  datacenter: SpringCloud   # 修改 http://localhost:8761 地址 Eureka 首頁上面 System Status 的 Data center 顯示信息
  environment: Test         # 修改 http://localhost:8761 地址 Eureka 首頁上面 System Status 的 Environment 顯示信息
  instance:
    hostname: peer3
    instance-id: ${spring.application.name}:${server.port}
  client:
#    register-with-eureka: false
#    fetch-registry: false
    service-url:
      defaultZone: http://admin:admin@peer1:8401/eureka,http://admin:admin@peer2:8402/eureka

2.6 添加 EurekaServer 微服務啓動類(springms-discovery-eureka-ha\src\main\java\com\springms\cloud\EurekaServerHaApplication.java)

package com.springms.cloud;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;

/**
 * 服務發現服務端EurekaServer微服務高可用。<br/>
 *
 * Eureka默認端口是8761
 * http://localhost:8761/eureka/apps 能夠查看註冊到該服務器上的一堆微服務實例的信息。
 *
 * @author hmilyylimh
 *
 * @version 0.0.1
 *
 * @date 2017/10/25
 *
 */
@SpringBootApplication
@EnableEurekaServer
public class EurekaServerHaApplication {

    public static void main(String[] args) {
        SpringApplication.run(EurekaServerHaApplication.class, args);
        System.out.println("【【【【【【 EurekaHa微服務 】】】】】】已啓動.");
    }
}

3、測試

測試以前,咱們得配置一下Run Configuration,如何快速啓動運行三個EurekaServer微服務;
在 Run/Debug Configuration(新建一個Spring Boot) -> Spring Boot -> EurekaServerHaApplication_8401_peer1(給界面頂部 Name 字段屬性命名) -> Configuration -> Spring Boot Settings -> Active Profiles: Peer1
在 Run/Debug Configuration(新建一個Spring Boot) -> Spring Boot -> EurekaServerHaApplication_8402_peer2(給界面頂部 Name 字段屬性命名) -> Configuration -> Spring Boot Settings -> Active Profiles: Peer2
在 Run/Debug Configuration(新建一個Spring Boot) -> Spring Boot -> EurekaServerHaApplication_8403_peer3(給界面頂部 Name 字段屬性命名) -> Configuration -> Spring Boot Settings -> Active Profiles: Peer3

/****************************************************************************************
 測試一:EurekaServer集羣高可用註冊中心以及簡單的安全認證(正常測試):

 一、註解:EnableEurekaClient
 二、按照上面依次運行啓動 EurekaServerHaApplication_8401_peer一、EurekaServerHaApplication_8402_peer二、EurekaServerHaApplication_8403_peer3 模塊服務,啓動3個端口;
 三、在瀏覽器輸入地址 http://localhost:8401 並輸入用戶名密碼 admin/admin 進入 8401 端口這臺服務正常啓動;
 四、在瀏覽器輸入地址 http://localhost:8402 並輸入用戶名密碼 admin/admin 進入 8402 端口這臺服務正常啓動;
 五、在瀏覽器輸入地址 http://localhost:8403 並輸入用戶名密碼 admin/admin 進入 8403 端口這臺服務正常啓動;
 六、注意一下,當前已經註冊的實例信息裏面,都有三臺微服務,說明小小的高可用集羣已經呈如今你們的眼前了;
 ****************************************************************************************/
 
/****************************************************************************************
 測試二:用戶微服務接口測試(採用 springms-provider-user 給 springms-discovery-eureka-ha 模塊作測試,測試EurekaClient客戶端註冊進EurekaServer高可用集羣中):

 一、註解:EnableEurekaClient
 二、修改 defaultZone 的接入地址值以下:
 ###################################################################################
 # 測試二:測試EurekaClient客戶端註冊進EurekaServer高可用集羣中
 defaultZone: http://admin:admin@peer1:8401/eureka,,http://admin:admin@peer2:8402/eureka,,http://admin:admin@peer3:8403/eureka
 ###################################################################################
 三、啓動 springms-discovery-eureka-ha 模塊服務,啓動3個端口;
 四、啓動 springms-provider-user 模塊服務,啓動1個端口;
 五、在瀏覽器輸入地址http://localhost:7900/simple/1 能夠看到信息成功的被打印出來,說明用戶微服務正常;

 六、在瀏覽器輸入地址 http://localhost:8401 並輸入用戶名密碼 admin/admin 進入Eureka微服務顯示在網頁中,說明用戶微服務確實註冊到了 eureka 服務中;
 七、在瀏覽器輸入地址 http://localhost:8401/eureka/apps/springms-provider-user 能夠看到自定義的 <metadata>信息以及用戶微服務的相關信息成功的被展現出來了;
 八、在瀏覽器輸入地址 http://localhost:8402/eureka/apps/springms-provider-user 能夠看到自定義的 <metadata>信息以及用戶微服務的相關信息成功的被展現出來了;
 九、在瀏覽器輸入地址 http://localhost:8403/eureka/apps/springms-provider-user 能夠看到自定義的 <metadata>信息以及用戶微服務的相關信息成功的被展現出來了;
 
 注意:這裏咱們要回到 springms-provider-user 項目代碼中稍微修改,也寫了一個對應的《測試二》測試步驟,便可實現咱們這個高可用的《測試二》樣例,;
 ****************************************************************************************/

4、下載地址

https://gitee.com/ylimhhmily/SpringCloudTutorial.gitjava

SpringCloudTutorial交流QQ羣: 235322432git

SpringCloudTutorial交流微信羣: 微信溝通羣二維碼圖片連接spring

歡迎關注,您的確定是對我最大的支持!!!apache

相關文章
相關標籤/搜索