对于前面的rest风格的分布式的缺点十分明显,url方面和服务器方面,所以springcloud引入的eureka实现服务的注册和发现,eureka相当于一个代理商(server),把provider和consumer的基本信息都存储到代理商(server)中,如果consumer需要请求user,只需要找到eureka,eureka会帮助consumer找到provider
而我当时照着视频创建eureka的model总是会出现这样那样的错误,最后经过研究别人的完整项目和自己的反复尝试,认为是版本之间的冲突问题
首先在上一篇中的microservice_parent父工程中创建一个eurekaserver的model
老规矩,点击spring Initializr,点击next
然后填写包名和model名称,点击next
然后点击springcloudDiscovery中的Eureka Server,点击next
检查包名,确认无误后,点击finish
然后配置pom
<?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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.zz</groupId>
<artifactId>microservice_parent</artifactId>
<version>0.0.1-SNAPSHOT</version>
</parent>
<groupId>com.zz</groupId>
<artifactId>eurekaserver</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>eurekaserver</name>
<description>Demo project for Spring Boot</description>
<packaging>jar</packaging>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
<exclusions>
<exclusion>
<groupId>org.junit.vintage</groupId>
<artifactId>junit-vintage-engine</artifactId>
</exclusion>
</exclusions>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
<repositories>
<repository>
<id>spring-milestones</id>
<name>Spring Milestones</name>
<url>https://repo.spring.io/milestone</url>
</repository>
</repositories>
</project>
然后在EurekaserverApplication类的上面添加@EnableEurekaServer注解,之后配置application.yml
server:
port: 8080
eureka:
client:
fetch-registry: false
register-with-eureka: false
service-url:
defaultZone: http://localhost:8080/eureka/
运行EurekaserverApplication,在网页中输入localhost:8080,会出现以下结果
此时eureka中的server已经注册完成
然后需要注册provider和consumer
首先是provider,只需三步
修改pom:在中添加
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
修改yml:在yml中添加服务注册地址,即eurekaserver的地址
eureka:
client:
service-url:
defaultZone: http://localhost:8080/eureka/ #服务注册中心的地址
在Application类上添加@EnableEurekaClient注解
consumer也是如此
最后在运行provider和consumer之前需要先运行起eurekaserver
最后的运行结果如下: