创建eureka注册中心_微服务注册中心和网关

创建eureka注册中心_微服务注册中心和网关目录关于SpringCloud版本单机模式Eureka注册中心搭建引入Eureka-Server依赖创建启动类添加配置高可用Eureka注册中心搭建双节点注册中心修改配置文件修改hosts文件启动测试多节点注册中心修改配置文件启动测试常见问题参考文章SpringCloud是一系列框架的集合,它利用SpringBoot的开发便利性巧…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

目录

关于SpringCloud版本

单机模式Eureka注册中心搭建

引入Eureka-Server依赖

创建启动类

添加配置

高可用Eureka注册中心搭建

双节点注册中心

修改配置文件

修改hosts文件

启动测试

多节点注册中心

修改配置文件

启动测试

常见问题

参考文章


Spring Cloud是一系列框架的集合,它利用Spring Boot的开发便利性巧妙地简化了分布式系统基础设施的开发,构建了服务治理(服务注册与发现)、配置中心、消息总线、负载均衡、断路器、数据监控、分布式会话和集群状态管理等功能,为我们提供一整套企业级分布式云应用的完美解决方案。

Spring Cloud的服务治理等核心功能主要是通过Spring Cloud Netflix的相关产品来实现,包括:服务发现(Eureka)、断路器(Hystrix)、智能路由(Zuul)和客户端负载均衡(Ribbon)。

本文主要对如何使用Eureka搭建服务注册中心进行介绍,我们先从最简单的单机模式Eureka服务器搭建开始。

关于SpringCloud版本

由于Spring Cloud是诸多子项目集合的综合项目,原则上由其子项目维护自己的发布版本号,也就是我们常用的版本号,如:1.2.3.RELEASE、1.1.4.RELEASE等。因此Spring Cloud为了避免版本号与其子项目的版本号混淆,所以没有采用版本号的方式,而是采用命名的方式。这些版本名称采用了伦敦地铁站的名字,根据字母表的顺序来对应版本时间顺序。比如,最早的Release版本名称为Angel,第二个Release版本的名称为Brixton,以此类推……。而我们在本系列文章所使用的版本名称为:Finchley.SR2,也就是目前的最新版本,其中的SR是service releases的简写,而1则是该版本名称中的第1个版本。其对应的Springboot版本为2.0.6.RELEASE。

关于更多版本的介绍,请参考官网:http://spring.io/projects/spring-cloud

单机模式Eureka注册中心搭建

引入Eureka-Server依赖

新建一个 Maven 工程,并在其 pom.xml 文件中引入依赖,内容如下:

	<parent>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-parent</artifactId>
		<version>2.0.6.RELEASE</version>
	</parent>

	<properties>
		<spring-cloud.version>Finchley.SR2</spring-cloud.version>
	</properties>

	<dependencies>
		<!-- Eureka-Server 依赖 -->
		<dependency>
			<groupId>org.springframework.cloud</groupId>
			<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
		</dependency>
	</dependencies>

	<dependencyManagement>
		<dependencies>
			<!-- SpringCloud 版本控制依赖 -->
			<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>

创建启动类

import org.springframework.boot.WebApplicationType;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.builder.SpringApplicationBuilder;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;

@SpringBootApplication
@EnableEurekaServer
public class EurekaServerApplication {

	public static void main(String[] args) {
		new SpringApplicationBuilder(EurekaServerApplication.class).web(WebApplicationType.SERVLET).run(args);
	}
}

添加配置

默认情况下,每一个Eureka服务端同时也是Eureka客户端,你需要为它提供(至少一个)service-url 让它用来定位它的同类(其他Eureka服务端),如果你一个service-url 都不提供,服务虽然能够运行并且正常工作,但是它会在你的日志文件中插入很多由于它不能成功注册到同类而生成的噪音日志。 在集群模式下,两个Eureka(一个服务端和一个客户端)通过注册表合并和心跳监控能够让一个独立的Eureka服务端从故障中完美复活(只要还有监控或者弹性运行环境使它保持存活)。在单机模式,我们需要关闭Eureka的这些客户端行为,这样的话它就不会再不停地去尝试连接它的同类并不停地失败了。

在 Springboot的核心配置文件 application.yml 中加入如下配置来关闭Eureka的客户端行为:

server:
  port: 8761

eureka:
  instance:
    hostname: localhost
  client:
    registerWithEureka: false
    fetchRegistry: false
    serviceUrl:
      defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/

 其中fetch-registry和register-with-eureka两个配置用来关闭Eureka的客户端行为。

fetch-registry:表示是否从eureka server获取注册表信息,如果是单一节点,不需要同步其他eureka server节点,则可以设置为false;若是集群,则设置为true,默认为true。

register-with-eureka:表示是否将自己注册到eureka server,默认为true。

高可用Eureka注册中心搭建

由于Eureka服务端没有后台存储,但是所有的服务实例都需要不断地向Eureka服务端发送心跳来更新它们在注册表中的状态,所以,这一系列的功能只能在内存中完成的。同时,每一个Eureka客户端都有一个内存缓存存储了Eureka的注册表信息,对服务的请求可以直接从缓存的注册表中获取,并不需要每一次都到Eureka注册表中去获取。

你可以添加多个同类Eureka实例到你的系统中,只要它们彼此之间能够相互连接,它们就能够在彼此之间进行注册表同步,这能够让Eureka具有更高的弹性和可用性。事实上,这也是Eureka的默认行为,所以你唯一要做的就是配置一个有效的同类serviceUrl 来使它生效。

双节点注册中心

修改配置文件

修改上例中的application.yml文件,内容如下:

---
server:
  port: 8761
spring:
  profiles: peer1
  application:
    name: eureka-server
eureka:
  instance:
    hostname: peer1
  client:
    serviceUrl:
      defaultZone: http://peer2:8762/eureka/
  
---
server:
  port: 8762
spring:
  profiles: peer2
  application:
    name: eureka-server
eureka:
  instance:
    hostname: peer2
  client:
    serviceUrl:
      defaultZone: http://peer1:8761/eureka/

有了这个YAML文件,我们就能够在一台服务器上通过在启动时指定不同的Spring profile来模拟启动两个主机(peer1和peer2)了。事实上,如果你是在一个知晓自己主机名(默认主机是通过java.net.InetAddress 进行查找)的服务器上运行程序,eureka.instance.hostname 配置项并不是必须的。

修改hosts文件

在hosts文件中加入如下配置:

# Windows:C:\Windows\System32\drivers\etc\hosts
# Linux:/etc/hosts

127.0.0.1 peer1
127.0.0.1 peer2
127.0.0.1 peer3

启动测试

右键–>Run As –> Run Configurations…,分别以peer1和peeer2 配置信息启动EurekaServerApplication。

--spring.profiles.active=peer1
--spring.profiles.active=peer2

创建eureka注册中心_微服务注册中心和网关

 依次启动完成后,浏览器输入:http://peer1:8761/ 效果图如下:

创建eureka注册中心_微服务注册中心和网关

多节点注册中心

修改配置文件

在生产中我们可能需要三台或者大于三台的注册中心来保证服务的稳定性,配置的原理其实都一样,将注册中心分别指向其它的注册中心。这里只介绍三台集群的配置情况,其实和双节点的注册中心类似,修改上例中的application.yml文件,再添加一个 profiles 配置,内容如下:

---
server:
  port: 8761
spring:
  profiles: peer1
  application:
    name: eureka-server
eureka:
  instance:
    hostname: peer1
  client:
    serviceUrl:
      defaultZone: http://peer2:8762/eureka/,http://peer3:8763/eureka/
  
---
server:
  port: 8762
spring:
  profiles: peer2
  application:
    name: eureka-server
eureka:
  instance:
    hostname: peer2
  client:
    serviceUrl:
      defaultZone: http://peer1:8761/eureka/,http://peer3:8763/eureka/
          
---
server:
  port: 8763
spring:
  profiles: peer3
  application:
    name: eureka-server
eureka:
  instance:
    hostname: peer3
  client:
    serviceUrl:
      defaultZone: http://peer1:8761/eureka/,http://peer2:8762/eureka/

启动测试

分别加载三个profiles的配置启动EurekaServerApplication。

创建eureka注册中心_微服务注册中心和网关

常见问题

EMERGENCY! EUREKA MAY BE INCORRECTLY CLAIMING INSTANCES ARE UP WHEN THEY’RE NOT. RENEWALS ARE LESSER THAN THRESHOLD AND HENCE THE INSTANCES ARE NOT BEING EXPIRED JUST TO BE SAFE.

出现原因:默认情况下,为了防止由于网络问题而造成的已经正常启动的Eureka实例无法成功注册,Eureka会开启自我保护模式,这样即使Eureka实例续约失败也不会从可用列表中被剔除,可继续从注册表中返回并对外提供服务。

解决办法:关闭自我保护模式,将配置 eureka.server.enable-self-preservation 设置为 false 。关闭自我保护之后,提示信息将变为如下内容:

THE SELF PRESERVATION MODE IS TURNED OFF.THIS MAY NOT PROTECT INSTANCE EXPIRY IN CASE OF NETWORK/OTHER PROBLEMS.

参考文章

https://cloud.spring.io/spring-cloud-static/spring-cloud-netflix/2.0.2.RELEASE/single/spring-cloud-netflix.html

https://www.jianshu.com/p/d32ae141f680

http://spring.io/projects/spring-cloud

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

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/171875.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 通俗理解LDA主题模型

    通俗理解LDA主题模型0前言印象中,最开始听说“LDA”这个名词,是缘于rickjin在2013年3月写的一个LDA科普系列,叫LDA数学八卦,我当时一直想看来着,记得还打印过一次,但不知是因为这篇文档的前序铺垫太长(现在才意识到这些“铺垫”都是深刻理解LDA的基础,但如果没有人帮助初学者提纲挈领、把握主次、理清思路,则很容易陷入…

    2022年4月6日
    56
  • linux系统dpkg命令[通俗易懂]

    linux系统dpkg命令[通俗易懂]dpkg是Debianpackage的简写,为”Debian“操作系统专门开发的套件管理系统,用于软件的安装,更新和移除。阅读目录安装软件 列出与该包先关联的文件 显示包的版本 移除软件(保留配置) 移除软件(不保留配置) 查找包的详细信息 列出deb包的内容安装软件命令:dpkg-i<.debfilename>实例:dpkg-i~/Download/mozybackup_i386.debmozybackup_i386.deb是手动下…

    2022年5月11日
    46
  • .Net Core HttpClient处理响应压缩「建议收藏」

    .Net Core HttpClient处理响应压缩「建议收藏」前言在上篇文章[ASP.NETCore中的响应压缩]中我们谈到了在ASP.NETCore服务端处理关于响应压缩的请求,服务端的主要工作就是根据Content-Encoding头信息判断采用哪种方式压缩并返回。之前在群里有人问道过,现在的网络带宽这么高了还有必要在服务端针对请求进行压缩吗?确实,如今分布式和负载均衡技术这么成熟,很多需要处理高并发大数据的场景都可以通过增加服务器节点来进行。但是,在资源受限的情况下,或者是还没必要为了某一个点去增加新的服务器节点的时候,我们还是要采用一些程序本身的常规处理

    2022年7月15日
    14
  • POI jar包下载

    POI jar包下载POIjar包下载

    2022年5月15日
    115
  • 守护进程管理工具_进程保护工具

    守护进程管理工具_进程保护工具1.文本进程管理工具ntsysv是一个用户管理自动运行的守护进程的文本用户界面工具。2.命令行界面(CLI)工具可以使用chkconfig命令检查,设置系统的各种服务。此命令实际上是通过操作/etc/rc[0-6].d目录下的符号链接文件对系统的各种服务进行管理。chkconfig命令具有如下功能:1.添加指定的新服务2.清除指定的服务3.显示由chkconfig管理的服务4.改变服务的运行级别5…

    2025年6月4日
    2
  • Python入门习题(40)——CCF CSP认证考试真题:报数游戏「建议收藏」

    Python入门习题(40)——CCF CSP认证考试真题:报数游戏「建议收藏」CCFCSP认证考试真题(201712-2):游戏问题描述解题思路参考答案测试用例小结问题描述试题编号: 201712-2试题名称: 游戏时间限制: 1.0s内存限制: 256.0MB问题描述  有n个小朋友围成一圈玩游戏,小朋友从1至n编号,2号小朋友坐在1号小朋友的顺时针方向,3号小朋友坐在2号小朋友的顺时针方向,……,1号小朋友坐在n号小朋友的顺时针方向。  游戏开始,从1…

    2025年9月1日
    6

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号