• 概述
     最近研究了一下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. [排序][链表]Leetcode147 对链表进行插入排序

    思路: 插入算法的思想很简单,此题比较为链表数据类型,方便的是不用一个一个的向后移动元素,但是找到应该插入的位置相对麻烦,因为链表只有next指针,无法快速定位要插入的位置.在链表前面插入一个空指针, ...

  2. PHP连接Navicat For Mysql并取得数据

    Navicat For Mysql中新建数据库 数据库中新建表 保存表 表中添加数据 打开ide,输入以下php代码,使用localhost打开该php文件 <?php // ip地址.用户名. ...

  3. ubuntu建立文件或者文件夹软链接

    文件夹建立软链接(用绝对地址) ln -s 源地址  目的地址 比如我把linux文件系统rootfs_dir软链接到/home/jyg/目录下 ln -s /opt/linux/rootfs_dir ...

  4. luoguP4588 [TJOI2018]数学计算

    题意 考虑一个操作会对一段时间内的询问产生影响,于是将线段树上的这段时间打上乘这个数的标记,最后dfs整颗线段树. code: #include<bits/stdc++.h> using ...

  5. Java进阶的道路,怎么成为大牛?

    已然励志在java路上走的更远,那就有必要了解java的途径.先看图 image.png 愈加细化的细节如下​ 一: 编程基础 不管是C仍是C++,不管是Java仍是PHP,想成为一名合格的程序员,根 ...

  6. [PKUSC2018]最大前缀和(状压DP)

    题目大意:求给定的 $n$ 个数的所有排列的最大前缀和(不能为空)之和对 $10^9+7$ 取模的值. $1\le n\le 20,1\le\sum|a_i|\le 10^9$. 神级DP.杂题选讲的 ...

  7. 第02组 Beta冲刺(2/5)

    队名:無駄無駄 组长博客 作业博客 组员情况 张越洋 过去两天完成了哪些任务 数据库实践 提交记录(全组共用) 接下来的计划 加快校园百科的进度 还剩下哪些任务 学习软工的理论课 学习代码评估.测试 ...

  8. 公式推导【BACF//ICCV2017】

    HK Galoogahi, A Fagg, S Lucey. Learning Background-Aware Correlation Filters for Visual Tracking[C]. ...

  9. 诡异问题:tomcat启动一直卡住,strace跟踪提示apache-tomcat核心文件找不到。

    最近遇到了一个诡异的tomcat问题,被这个问题折磨了2天.是这样的,启动tomcat后一直卡在这个点上: org.apache.catalina.core.StandardEngine.startI ...

  10. (三十九)golang--反序列化

    反序列化:是指将json字符串反序列化成原来的数据类型. import ( "encoding/json" "fmt" ) type monster struc ...