升级微服务架构1:搭建Eureka Server服务中心

  Spring Cloud中使用Eureka来做服务注册和发现,来统一管理微服务实例。

  1.使用IDEA创建一个空的Maven项目做父模块

  (也可以不用父项目,所有模块都用平行结构)

  

  删除父模块src文件夹

  

  可使用Spring Initializr来创建模块或者创建Maven项目手动添加依赖

  2.使用Spring Initializr创建Eureka Server

  选择SDK 1.8

  

  Artifact填写对应模块的名称

  

  依次选择Cloud Discovery->Eureka Server,Spring Boot默认选择的是2.0.4

  

  可以参考Spring Cloud官方对应的Spring Cloud版本对应组件的版本,可以看到Finchley.SR1对应的是Spring Boot 2.0.4.RELEASE版

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

  

  创建好后会还原Maven项目的依赖,需要一段时间。

  2.1配置Eureka Server注解
  还原成功后会生成一个模块名称+Application的启动类,在类名上加上@EnableEurekaServer注解用来申明这是个Eureka服务器

  

  2.2配置Eureka Server配置文件

  配置文件可参考号官方文档,找到对应的Spring Cloud版本,点击Reference。

  

  http://cloud.spring.io/spring-cloud-static/Finchley.SR1/single/spring-cloud.html#spring-cloud-eureka-server

  搜索找到Standalone Mode单机模式

  

  

  将项目中的application.properties后缀名改为yml,把application.yml的配置文件内容复制到项目中。

  port为服务的端口,可以自定义,我这里把端口改为了8881
  idea使用Debug启动成功后,在浏览器输入:http://localhost:8881/ 有一下内容则说明该服务启动成功。

  

  

  3.使用Maven项目创建Eureka Server

  创建一个空的Maven项目,在父模块创建的会自动选中父模块

  

  将项目中的pom文件parent节点全部删除,到Spring Cloud官网复制Maven项目的依赖相关内容到pom文件的project节点下

  

  官网的依赖文件是Eureka客户的依赖,把dependencies节点下的依赖都删除

  添加Eureka Server的依赖:  

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

  再添加Spring Cloud版本属性

<properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
    <java.version>1.8</java.version>
    <spring-cloud.version>Finchley.SR1</spring-cloud.version>
</properties>

  在resources文件夹中添加application.yml文件,并设置为资源根目录,配置文件内容和第一一样,改下端口为:8882

  

  新建启动类(项目名+Application.java),写一个main方法启动Spring Boot程序,并加上Eureka Server的注解

  

  配置Spring Boot启动配置项

  

  选择对应的启动类

  

  启动该模块,成功后再浏览器输入:http://localhost:8882/,使用Maven创建的Eureka Server项目也成功启动了

  

  4.创建Eureka Server集群

  集群的作用是一个服务复制多份实例,当某一个实例挂掉后不至于影响整个系统,Eureka Server集群中的每个实例都是相互复制来保障所注册的服务一致。

实际生产环境中只要有一个Eureka Server通过不同的实例对应配置不同的端口来实现,为方便演示,我这里创建集群就采用刚刚创建的两个不同的Eureka Server来做。

  在官方文档中搜索:Peer Awareness
  http://cloud.spring.io/spring-cloud-static/Finchley.SR1/single/spring-cloud.html#spring-cloud-eureka-server-peer-awareness
  找到对应的集群配置

  

  修改Host文件,添加 127.0.0.1 peer1 peer2,并将服务名设置一样

  服务1配置:

  

server:
  port: 8881

eureka:
  instance:
    hostname: peer1
  client:
    registerWithEureka: true #把自身当做客户端注册到其他Eureka服务器
    fetchRegistry: true #在本地缓存所有实例注册信息
    serviceUrl:
      #defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
      #设置与Eureka Server交互的地址,查询服务和注册服务都需要依赖这个地址。
      ##指向另一个注册中心
      defaultZone: http://peer2:8882/eureka/

spring:
  #profiles: peer1  #没做环境配置,注释掉
  application:
    name: tmsapi-discovery-server

  服务2配置:

server:
  port: 8882

eureka:
  instance:
    hostname: peer2
  client:
    registerWithEureka: true #把自身当做客户端注册到其他Eureka服务器
    fetchRegistry: true #在本地缓存所有实例注册信息
    serviceUrl:
      #defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
      #设置与Eureka Server交互的地址,查询服务和注册服务都需要依赖这个地址。
      ##指向另一个注册中心
      defaultZone: http://peer1:8881/eureka/

spring:
  #profiles: peer2  #没做环境配置,注释掉
  application:
    name: tmsapi-discovery-server

  启动两个服务,成功浏览器输入:http://peer1:8881/ 和http://peer2:8882/,同一个Application中就有两个实例了
  peer1:

  

  peer2:

  

  至此Eureka Server集群就搭建成功了。

  Eureka相关资料:

  https://blog.csdn.net/neosmith/article/details/53131023

原文地址:https://www.cnblogs.com/townsend/p/9519741.html

时间: 2024-08-25 22:52:48

升级微服务架构1:搭建Eureka Server服务中心的相关文章

升级微服务架构2:服务注册

微服务架构中,服务是最小的可伸缩的独立部署的单位,同一个服务提供可以有多个实例,这些实例都会注册到服务注册中心(Eureka Server)上进行统一的管理及调用的负载均衡. 因Spring Cloud的是已Java为主要开发语言,本文会先讲Java语言的服务怎么注册到服务中心,然后按照这个逻辑移植到.net版本上. 1.创建java版服务,并注册到服务中心 1.1创建一个Eureka Client的Maven项目 操作模式和上一篇使用Maven创建Eureka Server一样,模块名:use

spring cloud微服务架构b2b2c电子商务-Eureka保护机制

首先对Eureka注册中心需要了解的是Eureka各个节点都是平等的,没有ZK中角色的概念, 即使N-1个节点挂掉也不会影响其他节点的正常运行.了解springcloud架构可以加求求:三五三六二四七二五九 默认情况下,如果Eureka Server在一定时间内(默认90秒)没有接收到某个微服务实例的心跳,Eureka Server将会移除该实例.但是当网络分区故障发生时,微服务与Eureka Server之间无法正常通信,而微服务本身是正常运行的,此时不应该移除这个微服务,所以引入了自我保护机

【码上微服务】- 环境搭建 - Eureka注册中心

一.前言 本章将讲述基于Spring Cloud的注册中心Eureka的简单工程搭建及Docker部署. 二.环境准备 操作系统:CentOS 7.2 项目管理:MAVEN(推荐使用阿里源中央仓库:http://maven.aliyun.com/nexus/content/repositories/central/) 开发IDE:IDEA 所用语言:JAVA 所用容器:Docker 三. Eureka注册中心项目搭建 JAVA工程创建(这里使用了IDEA) 相关的pom.xml <?xml ve

Spring Cloud微服务实践之路- Eureka Server 中的第一个异常

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

Re:从0开始的微服务架构--(二)快速快速体验微服务架构?--转

原文地址:https://mp.weixin.qq.com/s/QO1QDQWnjHZp8EvGDrxZvw 这是专题的第二篇文章,看看如何搭建一个简单模式的微服务架构. 记得好久之前看到一个大牛说过:如果单体架构都搞不好,就别搞微服务架构.乍一看,这句很有道理,后来发现这句话是不太对的,因为微服务架构的目的就是为了降低系统的复杂性,所以 微服务架构应该比单体架构更简单.更好实践才对. 这篇文章,我们就分享一下如何搭建一个 简单模式 的微服务架构. 什么是微服务架构的简单模式? 相对于大型互联网

《Spring Cloud与Docker微服务架构实战》配套代码

不才写了本使用Spring Cloud玩转微服务架构的书,书名是<Spring Cloud与Docker微服务架构实战> - 周立,已于2017-01-12交稿.不少朋友想先看看源码,现将代码放出. 本次放出的代码: 共计70+个DEMO 覆盖Eureka.Ribbon.Feign.Hystrix.Zuul.Spring Cloud Config.Spring Cloud Bus.Spring Cloud Sleuth.Docker.Docker Compose等. 1-11章代码地址: ht

从 Spring Cloud 开始,聊聊微服务架构实践之路

[编者的话]随着公司业务量的飞速发展,平台面临的挑战已经远远大于业务,需求量不断增加,技术人员数量增加,面临的复杂度也大大增加.在这个背景下,平台的技术架构也完成了从传统的单体应用到微服务化的演进. 系统架构的演进过程 单一应用架构(第一代架构) 这是平台最开始的情况,当时流量小,为了节约成本,并将所有应用都打包放到一个应用里面,采用的架构为 .NET SQL Server: 表示层:位于最外层(最上层),最接近用户.用于显示数据和接收用户输入的数 据,为用户提供一种交互式操作的界面,平台所使用

【 ECUG 演讲分享】吴海黎:CODING 微服务架构演进之路

近日,CODING 平台技术总监吴海黎参加了由 ECUG 社区举办的技术大会,与听众一同分享了 CODING 微服务架构的演进历程.让我们一起来欣赏精彩的演讲内容吧. 大家好!我是来自 CODING 的吴海黎,今天我给大家分享的内容是微服务拆分的实践,微服务几乎可以说是当下的一个主流架构,希望今天的分享能给大家落地微服务带来帮助.整个分享分为三个部分: 第一是单体架构的简介,第二是微服务架构落地方案,第三是 DevOps 之于微服务的重要性. 一.单体架构简介 虽然第一部分是介绍单体架构的主要痛

微服务架构:Eureka集群搭建

版权声明:本文为博主原创文章,转载请注明出处,欢迎交流学习! 服务注册.发现是微服务架构的关键原理之一,由于微服务架构是由一系列职责单一的细粒度服务构成的网状结构,服务之间通过轻量机制进行通信,这就必然引入一个服务注册发现的问题,也就是说服务提供方要注册报告服务地址,服务调用方要能发现目标服务.在我们的微服务架构中我们采用了Eureka来完成微服务的注册与发现.微服务通过Eureka进行注册,服务调用方通过Eureka找到目标服务.由于服务提供方以集群方式提供服务,Eureka也采用集群的方式来