在使用Spring Cloud的过程中,难免会遇到一些问题。所以对Spring Cloud的常用问题做一些总结。需要JAVA Spring Cloud大型企业分布式微服务云构建的B2B2C电子商务平台源码 一零三八七七四六二六

一、Eureka常见问题

1.1 Eureka 注册服务慢

默认情况下,服务注册到Eureka Server的过程较慢。在开发或测试时,常常希望能够加速这一 过程,从而提升工作效率。

该问题的原因及解决方案:

服务的注册涉及周期性心跳,默认30秒一次(通过客户端配置的serviceUrl)。只有当实例、服务端和客户端的本地缓存中的元数据都相同时,服务才被其他客户端发现(所以可能需要3次心跳)。可以使用参数 eureka.instance.leaseRenewalInSeconds 修改时间间隔, 从而加快客户端连接到其他服务的过程。在生产环境中最好坚持使用默认值,因为在服务器内部有一些计算,它们会对续约做出假设。

综上所述,要想解决服务注册慢的问题,只须将  eureka.instance.leaseRenewalInSeconds 设成一个更小的值。该配置用于设置 Eureka Client 向 Eureka Server 发送心跳的时间间隔, 默认是30,单位是秒。在生产环境中,建议坚持使用默认值。

1.2 已停止的微服务节点注销慢或不注销

在开发环境下,常常希望 Eureka Server 能迅速有效地注销已停止的微服务实例。然而,由于 Eureka Server 清理无效节点周期长(默认90秒),以及自我保护模式等原因,可能会遇到微服务注销慢甚至不注销的问题。解决方案如下:

· Eureka Server 端:

配置关闭自我保护,并按需配置 Eureka Server 清理无效节点的时间间隔。

eureka.server.enable-self-preservation
# 设为false, 关闭自我保护, 从而保证会注销微服务eureka.server.eviction-interval-timer-in-ms
# 清理间隔(单位毫秒,默认是60 * 1000)
复制代码

Eureka Client 端:

配置开启健康检查, 并按需配置续约更新时间和到期时间。

eureka.client.healthcheck.enabled
# 设为true,开启健康检查(需要spring-boot-starter-actuator 依赖)eureka.instance.lease-renewal-interval-in-seconds
# 续约更新时间间隔(默认是30秒)eureka.instance.lease-expiration-duration-in-seconds
# 续约到期时间(默认90秒)
复制代码

值得注意的是,这些配置仅建议开发或测试时使用,生产环境建议坚持使用默认值。

1.3 Eureka 的 UNKNOWN 问题总结与解决

注册信息 UNKNOWN ,是新手常会遇到的问题。但往往很多新手,并不清楚有两种 UNKNOWN 的情况,一种是应用名称 UNKNOWN,另一种是应用状态 UNKNOWN 。

1)应用名称UNKNOWN

应用名称UNKNOWN 显然不合适,首先是微服务的名称不够语义化,无法直观看出这是哪个微服务;更重要的是,我们常常使用应用名称消费对应微服务的接口。

一般来说,有两种情况会导致该问题的发生:

· 未配置spring.application.name 或者 eureka.instance.appname 属性。如果这两个属性均不配置,就会导致应用名称 UNKNOWN 的问题。

· 某些旧版本的SpringFox 会导致该问题,例如 SpringFox 2.6.0 。建议使用SpringFox 2.6.1或更新版本。

2) 微服务实例状态UNKNOWN

微服务实例状态UNKNOWN 同样很麻烦。一般来讲,只会请求状态是 UP 的微服务。该问题一般由健康检查导致。

eureka.client.healthcheck.enabled=true必须设置在application.yml中,而不能设置在bootstrap.yml 中,否则一些场景下会导致应用状态 UNKNOWN 的问题。JAVA 多用户商城系统b2b2c

转载于:https://juejin.im/post/5cce51ade51d456e811d2748

JAVA 多用户商城系统b2b2c-Spring Cloud常见问题与总结(一)相关推荐

  1. JAVA 多用户商城系统b2b2c-服务容错保护(Hystrix依赖隔离)

    依赖隔离 "舱壁模式"对于熟悉Docker的读者一定不陌生,Docker通过"舱壁模式"实现进程的隔离,使得容器与容器之间不会互相影响.而Hystrix则使用该 ...

  2. java多用户商城系统架构之第一篇——总的介绍

    系列文章主要是针对Java商城相关架构演化的介绍,不讲解具体业务.技术等. 最近公司要搞商城,让我多方咨询,最后看了很多,要不就是代码.表字段注释不全,要不就是bug多,要么就是文档缺少,最后决定自己 ...

  3. (十四)Java springcloud B2B2C o2o多用户商城 springcloud架构- Spring Cloud构建分布式电子商务平台...

    通过Spring Cloud构建PC+微信+APP+云服务的云商平台系统,其中包括B2B.B2C.C2C.O2O.新零售.直播电商等子平台,之前我们讲了很多关于Spring Cloud的概念文章,从本 ...

  4. JAVA 多用户商城系统b2b2c-Spring Cloud Stream 介绍

    介绍Spring Cloud Stream 电子商务平台源码请加企鹅求求:一零三八七七四六二六. Spring Cloud Stream是构建消息驱动的微服务应用程序的框架.Spring Cloud ...

  5. JAVA 多用户商城系统b2b2c-kafka处理超大消息

    Kafka设计的初衷是迅速处理短小的消息,一般10K大小的消息吞吐性能最好.但有时候,我们需要处理更大的消息,比如XML文档或JSON内容,一个消息差不多有10-100M,这种情况下,Kakfa应该如 ...

  6. JAVA 多用户商城系统b2b2c---配置中心和消息总线

    Spring Cloud Bus 电子商务平台源码请加企鹅求求:一零三八七七四六二六. Spring cloud bus通过轻量消息代理连接各个分布的节点.这会用在广播状态的变化(例如配置变化)或者其 ...

  7. 分享大型Java多用户商城系统开发历程

    最近公司要搞商城,让我多方咨询,最后看了很多,要不就是代码.表字段注释不全,要不就是bug多,要么就是文档缺少,最后决定自己开发一套商城. 下面是开发的一些心得体会,权且记录下来,给自己做个记录把. ...

  8. java广告投放系统_[Spring cloud 一步步实现广告系统] 5. 投放系统配置+启动+实体类...

    广告投放系统启动主类说明 /** * sponsorapplication for 广告赞助商/投递服务启动类 * 添加注解{@link enablefeignclients}之后,当前微服务就可以调 ...

  9. 搭搭云-超级应用平台 与JNPF Java多用户商城系统源码

    搭搭云 搭搭云是非常灵活的一站式企业管理超级平台,企业在一个云端账户中即可使用包含CRM.OA.进销存.HR.财务.项目管理.ERP在内的全系列SaaS软件:应用软件开发者可以基于搭搭云低代码PaaS ...

最新文章

  1. I.MX6 Android 5.1 纯Linux、U-Boot编译
  2. 前端开发大众手册(转)
  3. 英雄会被表彰,这些技术与代码也将被历史铭记
  4. idea上一步下一步快捷键_【MySQL】一步一步的教你在windows下安装MySQL5.7
  5. 04-树6 Complete Binary Search Tree(30 分)
  6. Linux 内核下载地址
  7. 7个良心到难以置信的自媒体免费网站推荐
  8. 三星Note3开发者模式
  9. Linux系统管理命令(1)accton的使用
  10. 京东到家机器学习平台建设
  11. 使用SketchUp制作球体的方法(图文教程)
  12. 【数据分析之道】数据分析导读
  13. ESP Wi-Fi 连接异常断开原因排查分析
  14. 同态加密中的一些技术概念
  15. 2020华为实习生(提前批)面试经验
  16. 爱奇艺搜索排序算法实践(内附福利)
  17. 【无限互联】iOS开发视频教程 — 3.4 @property属性和点语法
  18. 解决realplay在ubuntu中没有声音且画面很卡的问题
  19. Pr自学(抠图、调色)
  20. 从0.1开始学Python——[17]

热门文章

  1. Spring Mock单元测试
  2. WMI技术介绍和应用——查询时间信息
  3. 图像处理和图像识别中常用的CxImage函数
  4. 【驱动】GNSS驱动基础
  5. jupyter怎么调字体_AJ里最低调的系列之一:Air Jordan 3
  6. java nextline_Java编程语言基础的9根支柱
  7. 在python中使用关键字define定义函数_python自定义函数def的应用详解
  8. autolayout autoresizing
  9. lisp语言cond和if套用_在'if'语句中设置多行条件的样式?
  10. 优雅地分离tableview回调