栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Spring Cloud Turbine集群监控一直Loading问题

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Spring Cloud Turbine集群监控一直Loading问题

这是最近在 学习Spring Cloud 按照书或者网上的例子敲示例遇到的问题,这个问题网上有很多答案,但是我遇到的问题和其他人不同, 如果你也遇到类似问题,希望下面的解决方法能帮助到你




问题描述:

搭建Spring Cloude Turbine集群监控

参考代码: GitHub - PNZBEIJINGL/spring-cloud-lab  

服务端口
eureka-peer1000Eureka服务注册中心
hystrix-dashboard2001Hystrix仪表板
hystrix-turbine2002Turbine 集群监控
ms-customer8001客户服务
ms-customer_interface客户接口工程
ms-ribbon-consumer8002消费服务(测试调用客户服务)

第一步: 先创建标准的spring boot工程,命名为hystrix-turbine ,pom增加依赖

    

        
        
            org.springframework.cloud
            spring-cloud-starter-turbine
        

        
        
            org.springframework.boot
            spring-boot-starter-actuator
        

        
            org.springframework.boot
            spring-boot-starter-hateoas
        

    

这里要注意:《Spring Cloud 微服务实战》和网上的一些例子没有说明 添加spring-boot-starter-hateoas 依赖 ,我在测试的时候发现没有此依赖会因为缺少TypeConstrainedMappingJackson2HttpMessageConverter,报ClassNotFoundException。没有进一步研究原因,猜测可能是因为版本引起。 增加依赖后报错解决

Caused by: java.lang.ClassNotFoundException: 

org.springframework.hateoas.mvc.TypeConstrainedMappingJackson2HttpMessageConverter

第二步:启动类增加注解@EnableTurbine@EnableDiscoveryClient@SpringBootApplication ,并设置application.properties

# 应用名称
spring.application.name=hystrix-turbine
server.port=2002
management.port=8990

############ Eureka ################
eureka.instance.hostname=localhost
#指定服务注册中心
eureka.client.serviceUrl.defaultZone=http://${eureka.instance.hostname}:1000/eureka/
############ Eureka ################

############ Turbine ################
#参数指定了需要手机监控信息的服务名
turbine.app-config=MS-RIBBON-ConSUMER
#指定了集群名称为default,参数用于区分不同的聚合集群,
turbine.cluster-name-expression="default"
#可以让同一主机上的服务通过主机名于端口号的组合来进行区分
turbine.combine-host-port=true
############ Turbine ################

启动上面的5个服务后,访问 http://127.0.0.1:2001/hystrix.stream Hystrix的仪表盘监控界面,并开启对集群监控,http://127.0.0.1:2002/turbine.stream,界面一直Loading 

 其后台报错Connection refused: connect

java.net.ConnectException: Connection refused: connect
	at java.base/java.net.PlainSocketImpl.waitForConnect(Native Method) ~[na:na]
	at java.base/java.net.PlainSocketImpl.socketConnect(PlainSocketImpl.java:107) ~[na:na]
	at java.base/java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:399) ~[na:na]
	at java.base/java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:242) ~[na:na]
	at java.base/java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:224) ~[na:na]
	at java.base/java.net.SocksSocketImpl.connect(SocksSocketImpl.java:403) ~[na:na]
	at java.base/java.net.Socket.connect(Socket.java:591) ~[na:na]
	at org.apache.http.conn.scheme.PlainSocketFactory.connectSocket(PlainSocketFactory.java:121) ~[httpclient-4.5.3.jar:4.5.3]
	at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:180) ~[httpclient-4.5.3.jar:4.5.3]
	at org.apache.http.impl.conn.ManagedClientConnectionImpl.open(ManagedClientConnectionImpl.java:326) ~[httpclient-4.5.3.jar:4.5.3]
	at org.apache.http.impl.client.DefaultRequestDirector.tryConnect(DefaultRequestDirector.java:610) ~[httpclient-4.5.3.jar:4.5.3]
	at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:445) ~[httpclient-4.5.3.jar:4.5.3]
	at org.apache.http.impl.client.AbstractHttpClient.doExecute(AbstractHttpClient.java:835) ~[httpclient-4.5.3.jar:4.5.3]
	at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:83) ~[httpclient-4.5.3.jar:4.5.3]
	at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:108) ~[httpclient-4.5.3.jar:4.5.3]
	at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:56) ~[httpclient-4.5.3.jar:4.5.3]
	at com.netflix.turbine.monitor.instance.InstanceMonitor.init(InstanceMonitor.java:307) ~[turbine-core-1.0.0.jar:na]




原因分析:

开始从网络上查找问题发现几种原因

  • Turbine应用没有添加spring-boot-starter -actuator 依赖
  • Turbine应用主类注解不正确
  • Turbine应用applicaiton.properties中turbine.app-config 服务名称拼写不催
  • Turbine应用applicaiton.properties中turbine.cluster-name-expression 配置的值需要修改成new String("default")

检查和测试发现自己的问题仍然没有解决, 因此断点调试才发现问题

 turbine监控服务的时候,根据监控的服务名称来得到监控地址是 http://192.168.20.134:8002/hystrix.stream, 尝试浏览器输入http://192.168.20.134:8002/hystrix.stream发现找不到访问结果,再查看ms-ribbon-consumer 配置发现配置了server.address=127.0.0.1 , spring boot 配置中server.address=127.0.0.1时候,只有localhost和127.0.0.1可以方法,不能使用IP192.168.20.134访问,因此造成监控失败




解决方案:

Spring Boot 中server.address 的配置方式

  • server.address 配置为对应机器ip地址时 ,如 192.168.20.134 只能用此IP访问
  • server.address 配置为127.0.0.1 的时候, 只能用127.0.0.1 和localhost访问,不能用机器IP访问
  • server.address 配置不设置的时候,可以用127.0.0.1 和localhost和机器IP访问

因为turbine监控是按照IP访问的所以需要保证http://192.168.20.134:8002/hystrix.stream访问成功,因此将ms-ribbon-consumer 中配置server.address=127.0.0.1 删除后,我的问题得到解决

      上一篇:Spring Cloud Hystrix断路器应用学习

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/461971.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号