SpringCloud(第 051 篇)EurekaServer集群高可用注冊(cè)中心以及簡(jiǎn)單的安全認(rèn)證
-
一、大致介紹1、前面章節(jié)分析了一下 Eureka 的源碼,我們是不是在里面注意到了 Peer 節(jié)點(diǎn)的復(fù)制,為什么要復(fù)制節(jié)點(diǎn)同步信息呢,其實(shí)就是為了同一個(gè)集群之間的EurekaServer一致性方案的一個(gè)實(shí)現(xiàn); 2、于是我們?cè)诒菊鹿?jié)就真正的來通過代碼來實(shí)現(xiàn)一下EurekaServer之間的高可用注冊(cè)中心。 3、至于所謂的安全認(rèn)證,就是在我們的客戶端配置defaultZone屬性環(huán)節(jié),要帶上用戶名密碼才可以注冊(cè)到高可用注冊(cè)中心去;二、實(shí)現(xiàn)步驟 2.1 添加 maven 引用包
2.2 添加應(yīng)用默認(rèn)配置文件(springms-discovery-eureka-hasrcmainresourcesapplication.yml)4.0.0 springms-discovery-eureka-ha 1.0-SNAPSHOT jar com.springms.cloud springms-spring-cloud 1.0-SNAPSHOT org.springframework.cloud spring-cloud-starter-eureka-server org.springframework.boot spring-boot-starter-security
spring: application: name: springms-discovery-eureka-ha profiles: # 主要激活哪個(gè)配置文件,如果有不清楚的話,可以回頭看看 Config 配置相關(guān)的知識(shí),比如 springms-config-client、springms-config-server active: peer12.3 添加應(yīng)用peer1節(jié)點(diǎn)默認(rèn)配置文件(springms-discovery-eureka-hasrcmainresourcesapplication-peer1.yml)
# 配置 eureka 登錄密碼,輸入地址 http://localhost:8761 時(shí)候就需要輸入這個(gè)用戶名密碼登錄進(jìn)去 security: basic: enabled: true user: name: admin password: admin server: port: 8401 eureka: datacenter: SpringCloud # 修改 http://localhost:8761 地址 Eureka 首頁(yè)上面 System Status 的 Data center 顯示信息 environment: Test # 修改 http://localhost:8761 地址 Eureka 首頁(yè)上面 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/eureka2.4 添加應(yīng)用peer2節(jié)點(diǎn)默認(rèn)配置文件(springms-discovery-eureka-hasrcmainresourcesapplication-peer2.yml)
# 配置 eureka 登錄密碼,輸入地址 http://localhost:8761 時(shí)候就需要輸入這個(gè)用戶名密碼登錄進(jìn)去 security: basic: enabled: true user: name: admin password: admin server: port: 8402 eureka: datacenter: SpringCloud # 修改 http://localhost:8761 地址 Eureka 首頁(yè)上面 System Status 的 Data center 顯示信息 environment: Test # 修改 http://localhost:8761 地址 Eureka 首頁(yè)上面 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/eureka2.5 添加應(yīng)用peer3節(jié)點(diǎn)默認(rèn)配置文件(springms-discovery-eureka-hasrcmainresourcesapplication-peer3.yml)
# 配置 eureka 登錄密碼,輸入地址 http://localhost:8761 時(shí)候就需要輸入這個(gè)用戶名密碼登錄進(jìn)去 security: basic: enabled: true user: name: admin password: admin server: port: 8403 eureka: datacenter: SpringCloud # 修改 http://localhost:8761 地址 Eureka 首頁(yè)上面 System Status 的 Data center 顯示信息 environment: Test # 修改 http://localhost:8761 地址 Eureka 首頁(yè)上面 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/eureka2.6 添加 EurekaServer 微服務(wù)啟動(dòng)類(springms-discovery-eureka-hasrcmainjavacomspringmscloudEurekaServerHaApplication.java)
package com.springms.cloud; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer; /** * 服務(wù)發(fā)現(xiàn)服務(wù)端EurekaServer微服務(wù)高可用。三、測(cè)試
* * Eureka默認(rèn)端口是8761 * http://localhost:8761/eureka/apps 可以查看注冊(cè)到該服務(wù)器上的一堆微服務(wù)實(shí)例的信息。 * * @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微服務(wù) 】】】】】】已啟動(dòng)."); } }
測(cè)試之前,我們得配置一下Run Configuration,如何快速啟動(dòng)運(yùn)行三個(gè)EurekaServer微服務(wù); 在 Run/Debug Configuration(新建一個(gè)Spring Boot) -> Spring Boot -> EurekaServerHaApplication_8401_peer1(給界面頂部 Name 字段屬性命名) -> Configuration -> Spring Boot Settings -> Active Profiles: Peer1 在 Run/Debug Configuration(新建一個(gè)Spring Boot) -> Spring Boot -> EurekaServerHaApplication_8402_peer2(給界面頂部 Name 字段屬性命名) -> Configuration -> Spring Boot Settings -> Active Profiles: Peer2 在 Run/Debug Configuration(新建一個(gè)Spring Boot) -> Spring Boot -> EurekaServerHaApplication_8403_peer3(給界面頂部 Name 字段屬性命名) -> Configuration -> Spring Boot Settings -> Active Profiles: Peer3 /**************************************************************************************** 測(cè)試一:EurekaServer集群高可用注冊(cè)中心以及簡(jiǎn)單的安全認(rèn)證(正常測(cè)試): 1、注解:EnableEurekaClient 2、按照上面依次運(yùn)行啟動(dòng) EurekaServerHaApplication_8401_peer1、EurekaServerHaApplication_8402_peer2、EurekaServerHaApplication_8403_peer3 模塊服務(wù),啟動(dòng)3個(gè)端口; 3、在瀏覽器輸入地址 http://localhost:8401 并輸入用戶名密碼 admin/admin 進(jìn)入 8401 端口這臺(tái)服務(wù)正常啟動(dòng); 4、在瀏覽器輸入地址 http://localhost:8402 并輸入用戶名密碼 admin/admin 進(jìn)入 8402 端口這臺(tái)服務(wù)正常啟動(dòng); 5、在瀏覽器輸入地址 http://localhost:8403 并輸入用戶名密碼 admin/admin 進(jìn)入 8403 端口這臺(tái)服務(wù)正常啟動(dòng); 6、注意一下,當(dāng)前已經(jīng)注冊(cè)的實(shí)例信息里面,都有三臺(tái)微服務(wù),說明小小的高可用集群已經(jīng)呈現(xiàn)在大家的眼前了; ****************************************************************************************/ /**************************************************************************************** 測(cè)試二:用戶微服務(wù)接口測(cè)試(采用 springms-provider-user 給 springms-discovery-eureka-ha 模塊做測(cè)試,測(cè)試EurekaClient客戶端注冊(cè)進(jìn)EurekaServer高可用集群中): 1、注解:EnableEurekaClient 2、修改 defaultZone 的接入地址值如下: ################################################################################### # 測(cè)試二:測(cè)試EurekaClient客戶端注冊(cè)進(jìn)EurekaServer高可用集群中 defaultZone: http://admin:admin@peer1:8401/eureka,,http://admin:admin@peer2:8402/eureka,,http://admin:admin@peer3:8403/eureka ################################################################################### 3、啟動(dòng) springms-discovery-eureka-ha 模塊服務(wù),啟動(dòng)3個(gè)端口; 4、啟動(dòng) springms-provider-user 模塊服務(wù),啟動(dòng)1個(gè)端口; 5、在瀏覽器輸入地址http://localhost:7900/simple/1 可以看到信息成功的被打印出來,說明用戶微服務(wù)正常; 6、在瀏覽器輸入地址 http://localhost:8401 并輸入用戶名密碼 admin/admin 進(jìn)入Eureka微服務(wù)顯示在網(wǎng)頁(yè)中,說明用戶微服務(wù)確實(shí)注冊(cè)到了 eureka 服務(wù)中; 7、在瀏覽器輸入地址 http://localhost:8401/eureka/apps/springms-provider-user 可以看到自定義的四、下載地址信息以及用戶微服務(wù)的相關(guān)信息成功的被展示出來了; 8、在瀏覽器輸入地址 http://localhost:8402/eureka/apps/springms-provider-user 可以看到自定義的 信息以及用戶微服務(wù)的相關(guān)信息成功的被展示出來了; 9、在瀏覽器輸入地址 http://localhost:8403/eureka/apps/springms-provider-user 可以看到自定義的 信息以及用戶微服務(wù)的相關(guān)信息成功的被展示出來了; 注意:這里我們要回到 springms-provider-user 項(xiàng)目代碼中稍微修改,也寫了一個(gè)對(duì)應(yīng)的《測(cè)試二》測(cè)試步驟,即可實(shí)現(xiàn)我們這個(gè)高可用的《測(cè)試二》樣例,; ****************************************************************************************/
https://gitee.com/ylimhhmily/SpringCloudTutorial.git
SpringCloudTutorial交流QQ群: 235322432
SpringCloudTutorial交流微信群: 微信溝通群二維碼圖片鏈接
歡迎關(guān)注,您的肯定是對(duì)我最大的支持!!!
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/67878.html
摘要:接收參數(shù)對(duì)象添加用戶微服務(wù)啟動(dòng)類用戶服務(wù)類添加服務(wù)注冊(cè),將用戶微服務(wù)注冊(cè)到中。 SpringCloud(第 004 篇)用戶服務(wù)類(添加服務(wù)注冊(cè),將用戶微服務(wù)注冊(cè)到 EurekaServer 中) - 一、大致介紹 通過添加注解 EnableEurekaClient,將用戶微服務(wù)注冊(cè)到 EurekaServer 中。 二、實(shí)現(xiàn)步驟 2.1 添加 maven 引用包 4.0....
摘要:第篇服務(wù)發(fā)現(xiàn)服務(wù)端微服務(wù)一大致介紹眾所周知,在現(xiàn)在互聯(lián)網(wǎng)開發(fā)中,訪問地址的和端口號(hào)是動(dòng)態(tài)的,一個(gè)服務(wù)停掉再重新啟用后和端口就可能發(fā)生了改變,所以用硬編碼是肯定不行了。再對(duì)外提供服務(wù)的時(shí)候便不再使用掛掉的服務(wù)提供者的和端口。 SpringCloud(第 003 篇)服務(wù)發(fā)現(xiàn)服務(wù)端EurekaServer微服務(wù) - 一、大致介紹 1、眾所周知,在現(xiàn)在互聯(lián)網(wǎng)開發(fā)中,訪問地址的IP和端口號(hào)是...
摘要:是一個(gè)相對(duì)比較新的微服務(wù)框架,年才推出的版本雖然時(shí)間最短但是相比等框架提供的全套的分布式系統(tǒng)解決方案。提供線程池不同的服務(wù)走不同的線程池,實(shí)現(xiàn)了不同服務(wù)調(diào)用的隔離,避免了服務(wù)器雪崩的問題。通過互相注冊(cè)的方式來進(jìn)行消息同步和保證高可用。 Spring Cloud 是一個(gè)相對(duì)比較新的微服務(wù)框架,...
摘要:集群系統(tǒng)中的單個(gè)計(jì)算機(jī)通常稱為節(jié)點(diǎn),通常通過局域網(wǎng)連接,但也有其它的可能連接方式。這樣就高興了,可以專心寫自己的,前端就專門交由小周負(fù)責(zé)了。于是,小周和就變成了協(xié)作開發(fā)。都是為了項(xiàng)目正常運(yùn)行以及迭代。 一、前言 只有光頭才能變強(qiáng) 認(rèn)識(shí)我的朋友可能都知道我這陣子去實(shí)習(xí)啦,去的公司說是用SpringCloud(但我覺得使用的力度并不大啊~~)... 所以,這篇主要來講講SpringClou...
閱讀 2728·2021-11-22 13:52
閱讀 1193·2021-10-14 09:43
閱讀 3648·2019-08-30 15:56
閱讀 2956·2019-08-30 13:22
閱讀 3283·2019-08-30 13:10
閱讀 1571·2019-08-26 13:45
閱讀 1106·2019-08-26 11:47
閱讀 2800·2019-08-23 18:13