flink连接Holo报错Exception in thread "main" java.lang.RuntimeException: com.alibaba.hologres.client.exception.HoloClientException: [UNKNOW:null]com.alibaba.hologres.client.exception.HoloClientException: [100]尝试连线已失败。
咋回事?Endpoint和80端口都是通的
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
根据您提供的报错信息和知识库中的相关资料,以下是可能的原因及解决方案:
Hologres后端写入压力过大
报错中提到尝试连线已失败
,可能是由于Hologres实例的后端写入压力过大,导致连接失败。这种情况通常与Memtable刷盘不及时或集群负载过高有关。
连接数超出限制
如果当前作业或其他作业占用了过多的连接数,可能会导致新的连接请求被拒绝。Hologres对每个接入节点(Frontend,FE)的连接数有限制,超出限制时会报错。
Endpoint配置问题
虽然您确认Endpoint和80端口是通的,但可能存在以下问题:
ip:port
)。客户端重试机制不足
默认情况下,Flink Hologres Connector的重试次数可能不足以应对偶发的连接失败问题。如果未设置足够的重试参数,可能会导致连接失败。
其他潜在问题
connectionSize
过大)。增加重试次数
在Sink中添加以下参数以增加写入重试次数:
rpcRetries = '100'
这可以有效应对偶发的连接失败问题。
调整JDBC连接池大小
如果使用JDBC模式,检查connectionSize
参数是否合理。默认值为3,建议根据实际吞吐需求调整。例如:
connectionSize = '5'
启用固定连接模式
如果Connector版本>=1.2.0且Hologres引擎版本>=1.3,可以启用fixedConnectionMode
以减少连接数占用:
fixedConnectionMode = 'true'
ip:port
)。跨区域访问时需使用公共网络地址。rpcRetries
参数,以应对偶发的连接失败问题。connectionSize
参数,避免连接数超出限制。如果按照上述步骤排查后问题仍未解决,请联系Hologres技术支持人员,提供详细的报错日志和实例信息以便进一步排查。您可以复制页面截图提供更多信息,我可以进一步帮您分析问题原因。
实时计算Flink版是阿里云提供的全托管Serverless Flink云服务,基于 Apache Flink 构建的企业级、高性能实时大数据处理系统。提供全托管版 Flink 集群和引擎,提高作业开发运维效率。