Home > Java > javaTutorial > Finchley version analysis based on Spring Boot 2.x

Finchley version analysis based on Spring Boot 2.x

php是最好的语言
Release: 2018-08-09 17:27:11
Original
2065 people have browsed it

Spring Boot 2.x has been released for a long time, and now Spring Cloud has also released the Finchley version based on Spring Boot 2.x. Now let’s do an overall framework upgrade for the project.

Before upgrade=> After upgrade

Spring Boot 1.5.x => Spring Boot 2.0.2

Spring Cloud Edgware SR4 => ; Spring Cloud Finchley.RELEASE

Eureka Server

Eureka Server dependency update

Before upgrade:

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

After upgrade:

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

Eureka Client

Because the configuration center needs to be registered as a service in the registration center, Eureka Client needs to be upgraded, and other dependencies have not changed.

Eureka Client dependency update

Before upgrade:

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

After upgrade:

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

Spring Cloud

The client instance IP in the registration center is incorrectly displayed

Because the Spring Cloud service client IP address configuration has changed.

Before upgrade:

${spring.cloud.client.ipAddress}
Copy after login

After upgrade:

${spring.cloud.client.ip-address}
Copy after login

Spring Security

Generally, the registration center and configuration center will use security encryption and will rely on spring-boot-starter-security component, there are two problems after upgrading.

1. The username and password cannot be logged in

Because the parameters of Spring Security have been changed.

Before upgrade:

security:
  user:
    name:
    password:
Copy after login

After upgrade:

spring:
  security:
     user:
       name: 
       password:
Copy after login

2. There is no registered instance in the registration center

As shown in the figure, Without a registered instance, the two registration centers cannot register with each other.

Finchley version analysis based on Spring Boot 2.x

Because Spring Security enables all CSRF attack defenses by default, /eureka’s defense needs to be disabled.

Add ignore configuration in the Application entry class:

@EnableWebSecurity
static class WebSecurityConfig extends WebSecurityConfigurerAdapter {

    @Override
    protected void configure(HttpSecurity http) throws Exception {
        http.csrf().ignoringAntMatchers("/eureka/**");
        super.configure(http);
    }
}
Copy after login

3. The configuration center cannot encrypt or decrypt

After upgrading, I found that the access configuration center cannot be read. configuration, the configuration information cannot be encrypted or decrypted, and the link to access the configuration center jumps directly to the login page.

Finchley version analysis based on Spring Boot 2.x

Now I want to change back to the previous basic auth authentication method. I found the source code and found that it automatically configured to jump to the login page. Now rewrite it.

Automatic configuration source code:
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();
}
Copy after login

After rewriting:

@EnableWebSecurity
static class WebSecurityConfig extends WebSecurityConfigurerAdapter {

    @Override
    protected void configure(HttpSecurity http) throws Exception {
        http.csrf().ignoringAntMatchers("/**").and().authorizeRequests().anyRequest()
                .authenticated().and().httpBasic();
    }

}
Copy after login

actually kills formLogin() and returns to the previous basic auth authentication method, as shown in the figure below.

Finchley version analysis based on Spring Boot 2.x

Now we can use the following commands to encrypt and decrypt.

After restoring basic auth, the previous service that required encrypted connection to the configuration center will run normally again.

Maven

After upgrading to Spring Boot 2.x, I found that the Maven startup plug-in of Spring Boot is not easy to use, mainly because the Profile cannot be switched freely.

Before upgrade:

spring-boot:run -Drun.profiles=profile1
Copy after login

After upgrade:

spring-boot:run -Dspring-boot.run.profiles=profile1
Copy after login

Summary

The above are the solutions summarized after going through all the pitfalls and actually solving the problem The process is far more complicated. The version changes are a bit big. This time, the basic dependencies of Spring Cloud, as well as the registration center (Eureka Server) and configuration center (Config Server) have been successfully upgraded.

Related recommendations:

Related introduction to the startup process of Spring Boot

Detailed explanation of unit testing of Spring Boot

The above is the detailed content of Finchley version analysis based on Spring Boot 2.x. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Issues
Install JAVA
From 1970-01-01 08:00:00
0
0
0
Unable to install java
From 1970-01-01 08:00:00
0
0
0
Can java be used as the backend of the web?
From 1970-01-01 08:00:00
0
0
0
Is this in Java language?
From 1970-01-01 08:00:00
0
0
0
Help: JAVA encrypted data PHP decryption
From 1970-01-01 08:00:00
0
0
0
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template