- I have always been interested in microservices, so today I will update the remote invocation of SpringCloud integration Eureka
Demand analysis
In the front-end separation architecture, the service layer is split into many microservices. How is the information of microservices managed? A service registry is provided in SpringCloud to manage microservice information.
Why use a registry?
1. There are so many microservices that we need to know the IP address and port of the server to make a remote call. The registry helps us manage the IP address and port of these services.
2. Microservices will report their status in real time, and the registry will manage the status of these microservices in a unified manner, kicking the problematic services out of the service list, and the client will obtain the available services for invocation.
Had been introduced
Spring Cloud Eureka is the secondary encapsulation of Netflix Eureka, which realizes the function of service governance. Spring Cloud Eureka provides the server and client, and the server is the Eureka service registry. The client registers and discovers microservices to Eureka services. Both the server and client are written in the Java language. The following diagram shows the relationship between Eureka Server and Eureka Client:
2. Deploy the Eureka Client program on the microservice, remotely access the Eureka Server and register with the Eureka Server.
3. When a microservice needs to call another microservice, it will get the service call address from Eureka Server and make a remote call.
Eureka Server set up
Single-machine Environment Construction
- Add dependencies (in Eureka Server Microservice Engineering)
<dependencies> <! ‐ ‐ import dependence on Eureka service ‐ ‐ > < the dependency > < groupId > org. Springframework. Cloud < / groupId > The < artifactId > spring ‐ cloud ‐ starter ‐ netflix ‐ eureka ‐ server < / artifactId > < / dependency > < / dependencies >Copy the code
- Start class (added in Eureka Server Microservice Project)
@springBootApplication public class GovernCenterApplication {public static void main(String[] args) { SpringApplication.run(GovernCenterApplication.class, args); }}Copy the code
- @enableeurekaserver You need to use @enableeurekaserver on the startup class to identify the service as the Eureka service
- The configuration content of application.yml is as follows:
eureka:
client:
registerWithEureka: false Whether to register yourself with the Eureka service
fetchRegistry: false Service discover whether to get registration information from Eureka
serviceUrl: Eureka client and Eureka server exchange address, high availability status to configure each other's address, single-machine status to configure their own (ifNo configuration, the machine port 8761 by default) defaultZone: http://localhost:50101/eureka/ server:enable‐ self ‐ preservation:false Whether to enable the self-protection modeEviction ‐ interval ‐ timer ‐in‐ ms: 60000Service registry cleanup interval (in milliseconds, default is 60*1000)
Copy the code
- Take a look at the screenshots (notice the format)
FetchRegistry: Set to true when you need to find the target service to invoke from Eureka
ServiceUrl. DefaultZone Configuratio n Eureka service Address Report High availability Status Configure the IP address of the peer party and configure your own single-node service status
Enable-self-preservation: indicates the self-protection setting, which is described below.
Eviction -interval-timer-in-ms: Purge the interval of a failed node, and remove the node from the service list if no report is received from the node during this period.
- Start the Eureka Server. Start the Eureka Server and view port 50101.
Description:
The above red message: THE SELF PRESERVATION MODE IS TURNED OFF.THIS MAY NOT PROTECT INSTANCE EXPIRY IN CASE OF NETWORK/OTHER PROBLEMS. The self-protection mode is turned off. The protected instance may not fail in the event of network or other problems.
The Eureka Server supports self-protection mode. If a microservice no longer reports the status to the Eureka Server, the Eureka Server deletes the microservice from the service list. If a network exception occurs (the microservice is normal), the Eureka Server enters self-protection mode. Microservices are no longer removed from the service column table.
It is recommended to disable the self-protection mode during the development phase.
- GigHub source code (welcome to leave a message, exchange)
- Github.com/flagest/onl…