• 概述
     最近研究了一下springCloud的微服务集群,主要用到了SpringCloud的服务发现和服务器端负载均衡,所有的项目都是用的springboot,
    可以和springCloud无缝对接。
  • 技术选型

    服务发现:eureka
    负载均衡:zuul
  • 实现
    Eureka集群(eurekaServer):8001、8002、8003
    服务提供方(eurekaClient):9001、9002
    服务端负载均衡服务:9100

    1、新建工程eureka服务器,用idea创建springboot项目,引入eureka依赖

    下面是三台服务器的配置文件

    //第一台
    server:
    port: 8001 spring:
    application:
    name: eureka-server eureka:
    server:
    use-read-only-response-cache: false #禁用readOnlyMap,分为ReadWriteMap和ReadOnlyMap
    eviction-interval-timer-in-ms: 3000 #主动失效检测时间
    instance:
    hostname: server8001
    client:
    # register-with-eureka: false #false表示不将自己也作为服务注册到eureka
    # fetch-registry: false
    service-url:
    #集群设置,搭建eureka集群,用逗号分隔
    defaultZone: http://localhost:8002/eureka/,http://localhost:8003/eureka/ //第二台
    server:
    port: 8002 spring:
    application:
    name: eureka-server eureka:
    server:
    use-read-only-response-cache: false
    eviction-interval-timer-in-ms: 3000
    instance:
    hostname: server8002
    client:
    # register-with-eureka: false #表示不将自己作为服务注册进eureka
    # fetch-registry: false
    service-url:
    #集群设置,搭建eureka集群,用逗号分隔,defaultZone是map类型,所以没有提示
    defaultZone: http://localhost:8001/eureka/,http://localhost:8003/eureka/ //第三台
    server:
    port: 8003 spring:
    application:
    name: eureka-server eureka:
    server:
    use-read-only-response-cache: false
    eviction-interval-timer-in-ms: 3000
    instance:
    hostname: server8003
    client:
    # register-with-eureka: false #表示不将自己作为服务注册进eureka
    # fetch-registry: false
    service-url:
    #集群设置,搭建eureka集群,用逗号分隔,defaultZone是map类型,所以没有提示
    defaultZone: http://localhost:8001/eureka/,http://localhost:8002/eureka/

    在入口处加上EnableEurekaServer注解

    2、服务提供者

    //第一台
    server:
    port: 9001 spring:
    application:
    name: eureka-client eureka:
    client:
    service-url:
    # 指定集群服务器列表
    defaultZone: http://localhost:8001/eureka/,http://localhost:8002/eureka/,http://localhost:8003/eureka/
    instance:
    instance-id: client9001.com
    prefer-ip-address: true
    lease-renewal-interval-in-seconds: 5 #发送心跳包服务刷新时间
    lease-expiration-duration-in-seconds: 15 #服务过期时间 //第二台
    server:
    port: 9002
    spring:
    application:
    name: eureka-client eureka:
    client:
    service-url:
    # 指定集群服务器列表
    defaultZone: http://localhost:8001/eureka/
    instance:
    instance-id: client9002.com
    prefer-ip-address: true
    lease-renewal-interval-in-seconds: 5 #发送心跳包服务刷新时间
    lease-expiration-duration-in-seconds: 15 #服务过期时间

    添加EnableEurekaClient注解,并添加api业务测试接口

    3、zuul负载均衡服务

    server:
    port: 9100 spring:
    application:
    name: zuul-gateway eureka:
    client:
    service-url:
    defaultZone: http://localhost:8001/eureka,http://localhost:8002/eureka,http://localhost:8003/eureka
    registry-fetch-interval-seconds: 5 #拉取服务列表时间
    instance:
    instance-id: gateway-9100.com
    prefer-ip-address: true zuul:
    prefix: /gateway
    ignored-services: eureka-client
    routes:
    eureka-client.serviceId: eureka-client
    eureka-client.path: /client/**

    依次启动Eureka服务器、服务提供者client,zull服务,访问其中一台Eureka服务器的控制台显示如下

    问题:
    1)、在配置eureka时,defaultZone是个map类型,不提供检测,所以会发现在配置时没有提示,直接写就行;
    2)、eurekaServer的hostname起的作用暂不明确,在控制台显示的都是application的name,三台eureka集群和两台服务提供客户端的application.name分别是一样的;
    3)、eureka服务器的服务清单分为ReadWriteMap和ReadOnlyMap,其他服务读取时是从ReadOnlyMap读取的,当有服务注册时,写入的是ReadWriteMap,然后会同步到
    ReadOnlyMap,这是为了解决读写锁的问题。当一台服务提供应用宕机之后会发现控制台还是有这台服务器的信息,表示没有将服务下线,服务清单列表没有删除这台
    服务器的信息,导致zuul在负载均衡时,有时会调用到宕机的那台应用导致返回异常,解决方法是禁用掉eureka服务器的ReadOnlyMap,设置主动失效检测时间,让服务器定时
    去检测服务,服务提供者设置服务失效时间和发送心跳包的时间,zuul设置拉取服务清单的时间间隔
    4)、zuul路由设置,设置路径前缀和服务的匹配关系

  • 测试

    不停刷新页面,会在9001和9002之间切换,证明配置成功,关闭9002应用,刷新页面,刚开始还会出现访问失败,过了一段时间后就稳定了,
    会有一个时间差,也可以给zuul配置熔断器来进行服务降级或者转发请求到其他正常服务。

springCloud搭建微服务集群+Zuul服务器端负载均衡的更多相关文章

  1. Spring Cloud(Dalston.SR5)--Zuul 网关-微服务集群

    通过 url 映射的方式来实现 zuul 的转发有局限性,比如每增加一个服务就需要配置一条内容,另外后端的服务如果是动态来提供,就不能采用这种方案来配置了.实际上在实现微服务架构时,服务名与服务实例地 ...

  2. Eclipse启动SpringCloud微服务集群的方法

    1.说明 下面这篇文章介绍了Eureka Server集群的启动方法, SpringCloud创建Eureka模块集群 是通过jar包启动时指定配置文件的方式实现的. 现在只有Eureka Serve ...

  3. Spring Cloud Turbine微服务集群实时监控

    本文代码下载地址: https://gitlab.com/mySpringCloud/turbine SpringBoot版本:1.5.9.RELEASE (稳定版) SpringCloud版本:Ed ...

  4. 一个C#开发者学习SpringCloud搭建微服务的心路历程

    前言 Spring Cloud很火,很多文章都有介绍如何使用,但对于我这种初学者,我需要从创建项目开始学起,所以这些文章对于我的启蒙,帮助不大,所以只好自己写一篇文章,用于备忘. SpringClou ...

  5. Dubbo工作原理,集群容错,负载均衡

    Remoting:网络通信框架,实现了sync-over-async和request-response消息机制. RPC:一个远程过程调用的抽象,支持负载均衡.容灾和集群功能. Registry:服务 ...

  6. 4.Dubbo2.5.3集群容错和负载均衡

    转载请出自出处:http://www.cnblogs.com/hd3013779515/ 1.集群容错和负载均衡原理 各节点关系: 这里的Invoker是Provider的一个可调用Service的抽 ...

  7. Dubbo之旅--集群容错和负载均衡

    当我们的系统中用到Dubbo的集群环境,由于各种原因在集群调用失败时,Dubbo提供了多种容错方案,缺省为failover重试. Dubbo的集群容错在这里想说说他是由于我们实际的项目中出现了此类的问 ...

  8. ASP.NET Core使用Docker-Swarm集群部署实现负载均衡实战演练

    一.需求背景 人生苦短,我用.NET Core!阿笨对Docker是这样评价的:Docker在手,环境我有!Docker出手,集群我有!前面的Doc基础课程我们学习了如何使用Docker来部署搭建单机 ...

  9. Openfire 集群部署和负载均衡方案

    Openfire 集群部署和负载均衡方案 一.   概述 Openfire是在即时通讯中广泛使用的XMPP协议通讯服务器,本方案采用Openfire的Hazelcast插件进行集群部署,采用Hapro ...

随机推荐

  1. [PHP] 深度解析Nginx下的PHP框架路由实现

    所有的框架处理业务请求时,都会处理URL的路径部分,分配到指定的代码中去处理.实现这一功能的关键就是获取$_SERVER全局变量中对于URL部分的数据 当请求的路径为http://test.com/a ...

  2. Incorrect datetime value: '' for column 'examDate' at row 1

    出问题的程序:user.setCreateTime(new Date()); 控制台图片一张,问题是:Incorrect datetime value: '' for column 'createTi ...

  3. Vue props中Object和Array设置默认值

    Vue中,在props中设置Object和Array的默认值 seller: { type: Object, default() { return {} } } seller: { type: Obj ...

  4. Pwn-level3

    题目地址 https://dn.jarvisoj.com/challengefiles/level3.rar.2047525b05c499c9dd189ba212bba1f8 借鉴 https://w ...

  5. pymongo 笔记(转)

    1. 安装MongoDB并启动服务,安装PyMongo2. 连接MongoDB,并指定连接数据库.集合 import pymongo client = pymongo.MongoClient(host ...

  6. Redis Pipelining

    Redis是一种基于客户端-服务端模型以及请求/响应协议的TCP服务.这意味着通常情况下一个请求会遵循以下步骤: 客户端向服务端发送一个查询请求,并监听Socket返回,通常是以阻塞模式,等待服务端响 ...

  7. 奇安信集团笔试题:二叉树的最近公共祖先(leetcode236),杀死进程(leetcode582)

    1. 二叉树最近公共祖先     奇安信集团 2020校招 服务端开发-应用开发方向在线考试 编程题|20分2/2 寻祖问宗 时间限制:C/C++语言 1000MS:其他语言 3000MS 内存限制: ...

  8. java.util.concurrent各组件分析 一 sun.misc.Unsafe

    java.util.concurrent各组件分析 一 sun.misc.Unsafe 说到concurrent包也叫并发包,该包下主要是线程操作,方便的进行并发编程,提到并发那么锁自然是不可缺少的, ...

  9. docker Dockerfile实战

    目录 Dockerfile实战 基础pm2 Dockerfile keymetrics/pm2:8-alpine keymetrics/pm2:12-alpine pm2 node Dockerfil ...

  10. vscode自定义vue模板代码

    File--->preference -->user Snippets-->搜索html.json 编辑 加入以下自定义代码内容 "Html5-Vue": { & ...