JAVA 多用户商城系统b2b2c-Spring Cloud常见问题与总结(一)
在使用Spring Cloud的过程中,难免会遇到一些问题。所以对Spring Cloud的常用问题做一些总结。
一、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
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
java B2B2C源码电子商城系统-Spring Cloud常见问题与总结(二)
在使用Spring Cloud的过程中,难免会遇到一些问题。所以对Spring Cloud的常用问题做一些总结。 一、整合Hystrix后首次请求失败 1.1 原因分析 Hystrix 默认的超时时间是1秒,如果在1秒内得不到响应,就会进入 fallback 逻辑。由于 Spring 的懒加载机制,首次请求往往会比较慢,因此在某些机器(特别是配置低的机器)上,首次请求需要的时间可能就会大于1秒。 1.2 解决方案 有很多方式解决该问题,下面列举几种比较简单的方案: 1) 方法一:为Ribbon配置饥饿加载。 ribbon: eager-load: enabled: true clients: client1,client2 对于Zuul: zuul: ribbon: eager-load: enabled: true 2) 方法二:延长 Hystrix 的超时时间,示例如下 hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds:5000 该配置让 Hystrix 的超时时间改为5秒。 3) 方法...
- 下一篇
微服务架构下分布式事务解决方案 | 第一章 : 分布式事务
- 微服务的发展 微服务倡导将复杂的单体应用拆分为若干个功能简单,松耦合的服务。这样可以降低开发难度、增强扩展性、便于敏捷开发,当前被越来越多的开发者推崇。很多互联网行业巨头、开源社区等都开始了微服务的讨论和实践。当前微服务的开发框架也非常多,比较著名的有Dubbo、SpringCloud、thrift 、grpc等。 - 微服务落地存在的问题 目前存在的主要困难有如下几方面: 单体应用拆分为分布式系统后,进程之间的通讯机制和故障处理措施变得更加复杂。 系统微服务化后,一个看似简单的功能,内部可能需要调用多个服务并操纵多个数据库来实现,服务间的调用导致分布式事务问题变得非常突出。 微服务数量众多,其测试,部署,监控等都变得更加困难。 随着RPC框架的成熟,第一个问题已经逐步得到解决。例如Dubbo支持多种通讯协议,Spring Cloud下的Ribbon,Feign等很好的支持Restful调用。对于第三个问题,随着docker、devops技术的发展以及各公有云paas平台自动化运维工具的推出,微服务的测试、部署与运维会变得越来越容易。而对于第二个问题,现在还没有通用方案很好的解决微...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- CentOS关闭SELinux安全模块
- Hadoop3单机部署,实现最简伪集群
- CentOS8编译安装MySQL8.0.19
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- CentOS8安装Docker,最新的服务器搭配容器使用
- SpringBoot2整合Thymeleaf,官方推荐html解决方案
- CentOS7编译安装Cmake3.16.3,解决mysql等软件编译问题
- CentOS7编译安装Gcc9.2.0,解决mysql等软件编译问题
- 设置Eclipse缩进为4个空格,增强代码规范
- SpringBoot2初体验,简单认识spring boot2并且搭建基础工程