mysql 报broken pipe_Mysql Broken pipe错误
mysql Broken pipe異常
Communications link failure due to underlying exception:
** BEGIN NESTED EXCEPTION **
java.net.socketException
MESSAGE: Broken pipe
STACKTRACE:
java.net.SocketException: Broken pipe
at java.net.SocketOutputStream.socketWrite0(Native Method)
at java.net.SocketOutputStream.socketWrite(SocketOutputStream.java:92)
at java.net.SocketOutputStream.write(SocketOutputStream.java:136)
at java.io.BufferedOutputStream.flushBuffer(BufferedOutputStream.java:65)
這個exception中我們可以得出是關于Socket的問題, 那么肯定就是關于網絡方面的原因, 比如mysql down了。 或者網絡有問題連不上mysql。
mysql會自動關閉掉空閑時間大于wait_timeout的連接。wait_timeout在可以在mysql配置文件里配置,默認的值是28800也就是8個小時。也就是說如果一個connection在8個小時候之內沒有用使用過過的話, mysql server會把這個connection銷毀掉。 這就是發生這個問題的原因了。 那么如何解決呢? 我們一般都用連接池來保存連接, 一般連接池都會有許多參數讓你的連接池更高效。 我們以c3p0作為例子。 http://www.mchange.com/projects/c3p0/index.html, 這個是c3p0的文檔,里面有許多參數,但是我們只要注意這個參數就行了。 maxIdleTime以下是對這個參數的解釋。
引用
maxIdleTime
Default: 0
Seconds a Connection can remain pooled but unused before being discarded. Zero means idle connections never expire. [See "Basic Pool Configuration"]
在c3p0中maxIdleTime的默認值是0,也就是說永遠都不會被expire, 解決這個問題的辦法就是設置maxIdleTime比mysql的wait_timeout的值小一些就行了。
微信 賞一包辣條吧~
支付寶 賞一聽可樂吧~
總結
以上是生活随笔為你收集整理的mysql 报broken pipe_Mysql Broken pipe错误的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Delphi7学习记录-demo实例
- 下一篇: Metro风格的开源项目 MahApps