日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

Spring Cloud 升级最新 Finchley 版本,踩了所有的坑

發布時間:2023/12/3 javascript 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Spring Cloud 升级最新 Finchley 版本,踩了所有的坑 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

轉載自? ?Spring Cloud 升級最新 Finchley 版本,踩了所有的坑

Spring Boot 2.x 已經發布了很久,現在 Spring Cloud 也發布了 基于 Spring Boot 2.x 的 Finchley 版本,現在一起為項目做一次整體框架升級。

升級前 => 升級后

Spring Boot 1.5.x => Spring Boot 2.0.2

Spring Cloud Edgware SR4 => Spring Cloud Finchley.RELEASE

Eureka Server

Eureka Server 依賴更新

升級前:

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-eureka-server</artifactId> </dependency>

升級后:

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-server</artifactId> </dependency>

Eureka Client

因為配置中心需要作為服務注冊到注冊中心,所以需要升級 Eureka Client,其他依賴沒有變動。

Eureka Client 依賴更新

升級前:

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-eureka</artifactId> </dependency>

升級后:

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId> </dependency>

Spring Cloud

注冊中心里面的客戶端實例IP顯示不正確

因為 Spring Cloud 獲取服務客戶端 IP 地址配置變更了。

升級前:

${spring.cloud.client.ipAddress}

升級后:

${spring.cloud.client.ip-address}

Spring Security

一般注冊中心、配置中心都會使用安全加密,就會依賴?spring-boot-starter-security?組件,升級后有幾下兩個問題。

1、用戶名和密碼無法登錄

因為 Spring Security 的參數進行了變更。

升級前:

security:user:name:password:

升級后:

spring:security:user:name:?password:

2、注冊中心沒有注冊實例

如圖所示,沒有注冊實例,兩個注冊中心無法互相注冊。

?

因為 Spring Security 默認開啟了所有 CSRF 攻擊防御,需要禁用 /eureka 的防御。

?

在 Application 入口類增加忽略配置:

@EnableWebSecurity static?class?WebSecurityConfig?extends?WebSecurityConfigurerAdapter?{@Overrideprotected?void?configure(HttpSecurity?http)?throws?Exception?{http.csrf().ignoringAntMatchers("/eureka/**");super.configure(http);} }

3、配置中心無法加解密

升級后發現訪問配置中心無法讀取到配置,也無法加解密配置信息,訪問配置中心鏈接直接跳轉到了登錄頁面。

?

?

現在想變回之前的 basic auth 認證方式,找源碼發現是自動配置跳到了登錄頁面,現在重寫一下。

自動配置源碼:
org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter#configure(org.springframework.security.config.annotation.web.builders.HttpSecurity)

protected?void?configure(HttpSecurity?http)?throws?Exception?{logger.debug("Using?default?configure(HttpSecurity).?If?subclassed?this?will?potentially?override?subclass?configure(HttpSecurity).");http.authorizeRequests().anyRequest().authenticated().and().formLogin().and().httpBasic(); }

重寫之后:

@EnableWebSecurity static?class?WebSecurityConfig?extends?WebSecurityConfigurerAdapter?{@Overrideprotected?void?configure(HttpSecurity?http)?throws?Exception?{http.csrf().ignoringAntMatchers("/**").and().authorizeRequests().anyRequest().authenticated().and().httpBasic();}}

其實就是把?formLogin()?干掉了,又回到之前的 basic auth 認證方式,如下圖所示。

?

?

現在我們又可以使用以下命令加解密了。

如解密:
curl http://xx.xx.xx.xx:7100/decrypt -d secret -u user:password

恢復 basic auth 之后,之前的服務需要加密連接配置中心的又正常運行了。

Maven

升級到 Spring Boot 2.x 之后發現 Spring Boot 的 Maven 啟動插件不好用了,主要是 Profile 不能自由切換。

升級前:

spring-boot:run?-Drun.profiles=profile1

升級后:

spring-boot:run?-Dspring-boot.run.profiles=profile1

具體的請參考:
https://docs.spring.io/spring-boot/docs/current/maven-plugin/run-mojo.html

總結

以上都是踩完所有的坑總結出來的解決方案,實際解決問題的過程遠要復雜的多。版本變化有點大,本次已成功升級了 Spring Cloud 基礎依賴,及注冊中心(Eureka Server)、配置中心(Config Server)。

其他像 Gateway 代替了 Zuul, 及其他組件再慢慢升級,Spring Cloud 的快速發展令升級變得非常蛋疼,本文記錄了升級過程中踩過的所有的坑。。。

坑死了,已經保證編譯、運行正常,其他還有什么坑不知道,剛升級完 Finchley 這個正式版本,Spring Cloud 剛剛又發布了 Finchley.SR1,感覺 Spring Cloud 變成了學不動系列了。。。

總結

以上是生活随笔為你收集整理的Spring Cloud 升级最新 Finchley 版本,踩了所有的坑的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。