我是靠谱客的博主 缓慢星月,最近开发中收集的这篇文章主要介绍mysql远程主机强迫关闭了_HAProxy出现"远程主机强迫关闭了一个现有的连接 " 的错误及解决...,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

使用haproxy作为sql server 的负载均衡器。

使用了文档中的示例配置项:

timeout client 50s

timeout server 50s

采用这个配置项,有时会出现“远程主机强迫关闭了一个现有的连接”的错误。

出现这个错误的原因是:一旦sql client超过50s没有给haproxy发送数据,则haproxy会关闭这个连接,此时sql client中的以为连接还是通的,此时发送数据就会出现异常。

在查看了HAProxy的官方文档,以及mysql和sql server的文档之后,将配置改为:

timeout client 8h

timeout server 8h

之后正常了。为什么设置为8小时呢?sql server没有查到类似wait timeout的资料,于是借鉴了mysql的配置项,mysql有一个名为wait timeout的配置项,它的默认时间为8小时,这个配置项的意思是当mysql发现与客户端的tcp连接如果超过8个小时不活动的话(收发数据),那么mysql就关闭这个连接。这个配置项跟http1.1中的keep alive timeout是类似的。

参考:

Apache: Keep-alive timeout

Amount of time the server will wait for subsequent requests on a persistent connection

Mysql: wait_timeout

The number of seconds the server waits for activity on an interactive connection before closing it.

HAProxy: timeout client

The inactivity timeout applies when the client is expected to acknowledge or send data.

最后

以上就是缓慢星月为你收集整理的mysql远程主机强迫关闭了_HAProxy出现"远程主机强迫关闭了一个现有的连接 " 的错误及解决...的全部内容,希望文章能够帮你解决mysql远程主机强迫关闭了_HAProxy出现"远程主机强迫关闭了一个现有的连接 " 的错误及解决...所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(45)

评论列表共有 0 条评论

立即
投稿
返回
顶部