Spring Cloud定位问题思路总结

Spring Cloud进入Camden时代后,已经比较稳定。一般来说,问题都不是Spring Cloud本身的Bug导致。建议按照如下步骤进行定位。
一 排查配置问题
1 YALM缩进是否正确
如果YALM配置文件缩进不正确,Spring Cloud应用程序无法正常启动,或配置无法正常加载。
类似问题应该在编码过程中严格避免。
2 配置属性是否正确
配置属性写错,不少初学者都会遇到这个问题。
很多场景下,这类问题可借助IDE的提示功能来排查——当IDE不自动提示或给出警告时,应格外注意。
3 配置属性位置是否正确
配置属性位置不正确可能会导致应用的不正常。举几个例子说明:
3.1 应当配置在Eureka Client项目上的属性,配置在了Eureka Server项目上。
3.2 应当些在bootstrap.yml中的属性,写在了application.yml中,例如:
spring:
  cloud:
    config:
      uri: http://localhost:8080/
该属性应当存放在bootstrap.yml中。
3.3 应当写在application.yml中的属性,写在了bootstrap.yml中,例如:
eureka.client.healthcheck.enabled=true
二 排查环境问题
1 环境变量
例如Java环境变量、Maven环境变量以及Docker容器环境变量等。当应用无法正常工作时,应该确保环境变量配置正确。
2 依赖下载是否完整
曾经有人遇到无法正常启动的问题,最终发现仅仅是依赖没有下载完整所致。因此,建议在启动应用前,使用以下命令打包,从而确认依赖的完整性。
mvn clean package
3 网络问题
微服务之间通过网络保持通信,因此,网络常常是排查问题的关键。当问题发生时,可优先排查网络问题。

三 排查代码问题
经过以上步骤,依然没有定位到Spring Cloud的问题,那么可能是编写代码出了问题。很多时候,常常因为少了某个注解,或是依赖缺失,而导致各种异常。
许多场景下,设置合理的日志级别,会对问题定位有奇效。

四 排查Spring Cloud自身问题
如果确定不是自身代码问题,就可Debug一下Spring Cloud的代码了。同时,可在Github等平台给Spring Cloud项目组提交Issue,然后参考官方答复,尝试避免相应问题。如问题无法规避,就需要Spring Cloud进行扩展,或者修复Spring Cloud的Bug,从而满足需求。此时,请不要忘记在Spring Cloud的Github上Pull Request,协助官方改进Spring Cloud,让Spring Cloud更加完善、稳定。

猜你喜欢

转载自blog.csdn.net/chengqiuming/article/details/80949184
今日推荐