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)
這個(gè)exception中我們可以得出是關(guān)于Socket的問題, 那么肯定就是關(guān)于網(wǎng)絡(luò)方面的原因, 比如mysql down了。 或者網(wǎng)絡(luò)有問題連不上mysql。
mysql會(huì)自動(dòng)關(guān)閉掉空閑時(shí)間大于wait_timeout的連接。wait_timeout在可以在mysql配置文件里配置,默認(rèn)的值是28800也就是8個(gè)小時(shí)。也就是說如果一個(gè)connection在8個(gè)小時(shí)候之內(nèi)沒有用使用過過的話, mysql server會(huì)把這個(gè)connection銷毀掉。 這就是發(fā)生這個(gè)問題的原因了。 那么如何解決呢? 我們一般都用連接池來保存連接, 一般連接池都會(huì)有許多參數(shù)讓你的連接池更高效。 我們以c3p0作為例子。 http://www.mchange.com/projects/c3p0/index.html, 這個(gè)是c3p0的文檔,里面有許多參數(shù),但是我們只要注意這個(gè)參數(shù)就行了。 maxIdleTime以下是對(duì)這個(gè)參數(shù)的解釋。
引用
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的默認(rèn)值是0,也就是說永遠(yuǎn)都不會(huì)被expire, 解決這個(gè)問題的辦法就是設(shè)置maxIdleTime比mysql的wait_timeout的值小一些就行了。
微信 賞一包辣條吧~
支付寶 賞一聽可樂吧~
總結(jié)
以上是生活随笔為你收集整理的mysql 报broken pipe_Mysql Broken pipe错误的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Delphi7学习记录-demo实例
- 下一篇: oracle数据库外联,Oracle数据