it编程 > 编程语言 > Java

SpringCloud中的Eureka的集群配置

47人参与 2024-07-28 Java

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

目前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的集群配置,还是比较简单易懂的。

(0)
打赏 微信扫一扫 微信扫一扫

您想发表意见!!点此发布评论

推荐阅读

【SpringCloud篇】Eureka服务的基本配置和操作

07-28

【微服务】第37节:微服务的注册中心Eureka

07-28

【微服务开篇-RestTemplate服务调用、Eureka注册中心、Nacos注册中心】

07-28

Eureka上集成Spring Cloud 微服务网关 gateway

07-28

【微服务】SpringCloud-eureka光速入门

07-28

微服务数据流的协同:Eureka与Spring Cloud Data Flow集成指南

07-28

猜你喜欢

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论