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

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

  1. 升级微服务架构5:API网关

    API网关是一个服务器,是系统的唯一入口.从面向对象设计的角度看,它与外观模式类似.API网关封装了系统内部架构,为每个客户端提供一个定制的API.它可能还具有其它职责,如身份验证.监控.负载均衡.缓 ...

  2. Spring Cloud之服务注册中心搭建Eureka Server服务注册中⼼

    Spring Cloud并不与Spring MVC类似是一个开源框架,而是一组解决问题的规范(个人理解).解决哪些问题呢?如下: 1)服务管理:⾃动注册与发现.状态监管 2)服务负载均衡 3)熔断 4 ...

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

    EMERGENCY! EUREKA MAY BE INCORRECTLY CLAIMING INSTANCES ARE UP WHEN THEY'RE NOT. RENEWALS ARE LESSER ...

  4. 庐山真面目之十二微服务架构基于Docker搭建Consul集群、Ocelot网关集群和IdentityServer版本实现

    庐山真面目之十二微服务架构基于Docker搭建Consul集群.Ocelot网关集群和IdentityServer版本实现 一.简介      在第七篇文章<庐山真面目之七微服务架构Consul ...

  5. 微服务架构集大成者—Spring Cloud (转载)

    软件是有生命的,你做出来的架构决定了这个软件它这一生是坎坷还是幸福. 本文不是讲解如何使用Spring Cloud的教程,而是探讨Spring Cloud是什么,以及它诞生的背景和意义. 1 背景 2 ...

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

    不才写了本使用Spring Cloud玩转微服务架构的书,书名是<Spring Cloud与Docker微服务架构实战> - 周立,已于2017-01-12交稿.不少朋友想先看看源码,现将 ...

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

    [编者的话]随着公司业务量的飞速发展,平台面临的挑战已经远远大于业务,需求量不断增加,技术人员数量增加,面临的复杂度也大大增加.在这个背景下,平台的技术架构也完成了从传统的单体应用到微服务化的演进. ...

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

    原文地址:https://mp.weixin.qq.com/s/QO1QDQWnjHZp8EvGDrxZvw 这是专题的第二篇文章,看看如何搭建一个简单模式的微服务架构. 记得好久之前看到一个大牛说过 ...

  9. Spring Cloud与Docker微服务架构实战 PDF

    电子版百度云下载 链接: https://pan.baidu.com/s/115u011CJ8MZzJx_NqutyTQ 提取码: 关注公众号[GitHubCN]回复2019获取 本书的代码 共计70 ...

随机推荐

  1. 如何去除List集合中的重复元素?

    一.问题由来 在实际开发的时候,我们经常会碰到这么一个问题:一个集合容器里面有很多重复的对象,里面的对象没有主键,或者说忽略主键,根据业务的需求,我们需要根据条件筛选出没有重复的对象. 二.去重操作 ...

  2. CODING DevOps 微服务项目实战系列第一课,明天等你

    CODING DevOps 微服务项目实战系列第一课<DevOps 微服务项目实战:DevOps 初体验>将由 CODING DevOps 开发工程师 王宽老师 向大家介绍 DevOps ...

  3. 关于haar特征的理解及使用(java实现)

    Haar特征原理综述Haar特征是一种反映图像的灰度变化的,像素分模块求差值的一种特征.它分为三类:边缘特征.线性特征.中心特征和对角线特征.如下所示: Haar-like矩形特征拓展  Lienha ...

  4. Ncdu强大的磁盘查看命令

    简介 项目地址: https://dev.yorhel.nl/ncdu Ncdu (NCurses Disk Usage) 是一个基于 Ncurses 库的 du 命令的界面.它通过大家熟知的 du ...

  5. WSGI 配置禁止反向DNS查找

    原文链接:https://opendev.org/starlingx/ha/src/commit/045a37c672a92f1412629a176f51183c88882e61/service-mg ...

  6. MySQL数据库中查询数据库表、字段总数量,查询数据总量

    最近要查询一些数据库的基本情况,由于以前用oracle数据库比较多,现在换了MySQL数据库,就整理了一部分语句记录下来. 1.查询数据库表数量 #查询MySQL服务中数据库表数据量 SELECT C ...

  7. Java动态代理(三)——Cglib动态代理

    一.Cglib动态代理Cglib是一个优秀的动态代理框架,它的底层使用ASM在内存中动态的生成被代理类的子类,使用Cglib即使代理类没有实现任何接口也可以实现动态代理功能.而且,它的运行速度要远远快 ...

  8. MacOS开发环境搭建

    1 Java 安装jdk 下载安装即可,没什么可说的,着重说一下配置mac下的环境变量 $ /usr/libexec/java_home -V #查看安装的jdk版本和路径 $ vim ~/.bash ...

  9. Spark本地配置

    1. 下载解压安装包 tar -xvf spark-2.0.2-bin-hadoop2.6.tgz tar -xvf scala-2.11.8.tgz 2. 修改Spark配置文件 cd spark- ...

  10. Python趣味入门5:循环语句while

    跟着小牛叔,找准正确编程入门姿势,每天只要阅读10分钟. 任何语言都有循环语句,在Python里循环更是变化无穷,有基本的循环,有循环else语句,引伸出来的还有迭代器.推导式,咱们先学习最简单的一种 ...