demo代码地址:https://download.csdn.net/download/qq_33333654/12014918
环境IDEA + MAVEN +jdk1.8+win10
首先可以参考我之前写的博客进行本地单节点的eureka项目创建:
https://blog.csdn.net/qq_33333654/article/details/102622685
这个单节点项目将会作为clien项目。
接下来是需要创建clien需要调用的server注册中心项目。个人之前写的本地集群:
https://blog.csdn.net/qq_33333654/article/details/102636388
按照上面的步骤请创建本地集群项目和启动集群,保证eureka注册正常。
这里发个别人的图,还是蛮不错的:
图片地址:https://www.cnblogs.com/a-yuan/p/9530395.html 别人写的。
接下来修改单点项目为clien项目:
首先配置文件修改为:
eureka: client: service-url: defaultZone: http://peer1:8000/eureka/,http://peer2:8001/eureka/,http://peer3:8002/eureka/ instance: hostname: clientName spring: application: name: client
client需要注册到三个注册中心,保证集群正常。
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>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.2.0.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <groupId>com.wwb</groupId> <artifactId>client</artifactId> <version>0.0.1-SNAPSHOT</version> <name>client</name> <description>Demo project for Spring Boot</description> <properties> <java.version>1.8</java.version> <spring-cloud.version>Hoxton.M3</spring-cloud.version> </properties> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-eureka-client</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> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </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>
修改启动类:
@EnableDiscoveryClient
@SpringBootApplication
public class ClientApplication {
public static void main(String[] args) {
SpringApplication.run(ClientApplication.class, args);
}
}
可以观察下:注解添加了@EnableDiscoveryClient
注意不要使用
@EnableEurekaServer注解
启动项目,刷新注册中心:
你会发现三个注册中心都出现了CLIENT,这个就是我们的client,eureka默认是把名字全部大写了。
结束