SpringCloud中的Eureka的集群配置

微服务框架中最为重要的就是注册中心,如果只是单注册中心,一旦出现问题,容易导致整个微服务环境不可用,所以建议注册中心集群。

目前SpringCloud框架中使用Eureka作为注册中心,本文简单介绍一下Eureka的集群配置,主要的思路就是相互注册,形成一组相互注册的注册中心,达到高可用的效果。

一般来说集群配置至少需要2台以上的服务器,这里是采用本机测试,道理是一样的。

集群配置

依赖配置

复制代码
<parent>
	<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-starter-parent</artifactId>
	<version>2.0.3.RELEASE</version>
	<relativePath/> <!-- lookup parent from repository -->
</parent>


<!-- 管理依赖 -->
<dependencyManagement>
	<dependencies>
		<dependency>
			<groupId>org.springframework.cloud</groupId>
		    <artifactId>spring-cloud-dependencies</artifactId>
			<version>Finchley.RELEASE</version>
			<type>pom</type>
			<scope>import</scope>
		</dependency>
	</dependencies>
</dependencyManagement>


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

<repositories>
	<repository>
	    <id>spring-milestones</id>
	    <name>Spring Milestones</name>
	    <url>https://repo.spring.io/milestone</url>
	    <snapshots>
	        <enabled>false</enabled>
	    </snapshots>
	</repository>
</repositories>

注册中心配置

第一个注册中心配置

复制代码
# 服务端口号
server:
  port: 8100
# 服务名称必须一样
spring:
  application:
 	name: app-eureka
eureka:
  instance:
    # 注册中心ip地址(本机地址)
    hostname: 127.0.0.1
  client:
    service-url:
    # 注册地址,注册到9100的注册中心,如果是三台以上,一样可以在这边添加
    # 主要是实现相互注册
      defaultZone: http://127.0.0.1:9100/eureka/  
    # 将自己注册给自己的注册中心
    register-with-eureka: true
    # 检索自己服务信息
    fetch-registry: false

第二个注册中心配置

复制代码
# 服务端口号
server:
  port: 9100
# 服务名称必须一样
spring:
  application:
    name: app-eureka

eureka:
  instance:
    # 注册中心ip地址(本机地址)
    hostname: 127.0.0.1
  client:
    service-url:
    # 注册地址,注册到8100的注册中心,如果是三台以上,一样可以在这边添加
    # 主要是实现相互注册
      defaultZone: http://127.0.0.1:8100/eureka/  
    # 将自己注册给自己的注册中心
    register-with-eureka: true
    # 检索自己服务信息
    fetch-registry: false

启动

复制代码
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;

@SpringBootApplication
@EnableEurekaServer //开启EurekaServer服务 开启注册中心
public class AppEureka {

	public static void main(String[] args) {
		SpringApplication.run(AppEureka.class, args);
	}
}

客户端配置

复制代码
# 订单服务的端口号
server:
  port: 8001
  
# 服务别名 -- 服务注册到注册中心名称
spring:
  application:
	name: app-order
    
eureka:
  client:
    service-url:
    # 当前订单服务注册到eureka服务地址,两个注册中心都注册
      defaultZone: http://localhost:8100/eureka,http://localhost:9100/eureka
    # 需要将服务注册到eureka
    register-with-eureka: true
    # 需要检索服务
    fetch-registry: true

客户端启动

复制代码
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate;

@SpringBootApplication
@EnableEurekaClient
public class AppOrder {
	
	public static void main(String[] args) {
		SpringApplication.run(AppOrder.class, args);	
	}
}

总结

以上即是Eureka的集群配置,还是比较简单易懂的。

相关推荐
程序员小郭836 分钟前
Spring Ai 04 解决 ChatClient 初始化冲突问题
java·后端·spring
SuniaWang10 分钟前
《Spring AI + 大模型全栈实战》学习手册系列 · 专题八:《RAG 系统安全与权限管理:企业级数据保护方案》
java·前端·人工智能·spring boot·后端·spring·架构
xiaohe0736 分钟前
Maven Spring框架依赖包
java·spring·maven
不吃香菜学java2 小时前
苍穹外卖-新增菜品代码开发
spring boot·spring·servlet·log4j·maven·mybatis
AAA_搬砖达人小郝2 小时前
Java生命周期(Spring Bean生命周期、JVM进程(应用)生命周期、Java对象生命周期、以及线程生命周期)
java·jvm·spring
NE_STOP2 小时前
SpringCloud进阶--Sentinel 流量防卫兵
spring
Memory_荒年3 小时前
SpringBoot 3.x 新特性:让代码自己“996”,你准时下班!
java·后端·spring
qq_334060213 小时前
spring_springmvc_mybatis权限控制+boostrap实现UI
java·spring·mybatis
小江的记录本4 小时前
【Spring Boot】Spring Boot 全体系知识结构化拆解(附 Spring Boot 高频面试八股文精简版)
java·spring boot·后端·spring·面试·tomcat·mybatis
eggwyw4 小时前
Spring 中使用Mybatis,超详细
spring·tomcat·mybatis