电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

MySQL數據庫連接異常匯總(值得收藏)

瀏覽:55日期:2023-10-13 09:25:19

在Centos上部署項目發現一個奇怪的問題,數據庫連接一直拋異常。于是花了兩個小時搜了各種數據庫連接異常導致的原因,最終問題得以解決。同時,把解決過程中搜集到的異常信息匯總一下,當大家遇到類似的問題時,給大家以思路。必須珍藏。

問題現象

先來說說我遇到的問題。項目中遇到的問題很奇怪,在Centos上安裝了Mysql數據庫,項目使用的是Spring Boot。

項目在本地啟動連接服務器數據庫正常、本地數據庫客戶端連接服務器數據庫正常、服務器本地連接client連接數據庫正常。唯獨把項目部署到服務器上啟動時拋出異常。

異常信息大概(當時未保留異常信息)如下:

com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure The last packet sent successfully to the server was 0 milliseconds ago. The driver has not received any packets from the server. at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source) at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source) at java.lang.reflect.Constructor.newInstance(Unknown Source) at com.mysql.jdbc.Util.handleNewInstance(Util.java:425) at com.mysql.jdbc.SQLError.createCommunicationsException(SQLError.java:989) at com.mysql.jdbc.MysqlIO.<init>(MysqlIO.java:341) at com.mysql.jdbc.ConnectionImpl.coreConnect(ConnectionImpl.java:2196) at com.mysql.jdbc.ConnectionImpl.connectOneTryOnly(ConnectionImpl.java:2229) at com.mysql.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:2024) at com.mysql.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:779) at com.mysql.jdbc.JDBC4Connection.<init>(JDBC4Connection.java:47) at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source) at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source) at java.lang.reflect.Constructor.newInstance(Unknown Source) at com.mysql.jdbc.Util.handleNewInstance(Util.java:425) at com.mysql.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:389) at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:330) at java.sql.DriverManager.getConnection(Unknown Source) at java.sql.DriverManager.getConnection(Unknown Source) at com.ad.MysqlDemo.main(MysqlDemo.java:32)Caused by: java.net.ConnectException: Connection refused: connect at java.net.DualStackPlainSocketImpl.connect0(Native Method) at java.net.DualStackPlainSocketImpl.socketConnect(Unknown Source) at java.net.AbstractPlainSocketImpl.doConnect(Unknown Source) at java.net.AbstractPlainSocketImpl.connectToAddress(Unknown Source) at java.net.AbstractPlainSocketImpl.connect(Unknown Source) at java.net.PlainSocketImpl.connect(Unknown Source) at java.net.SocksSocketImpl.connect(Unknown Source) at java.net.Socket.connect(Unknown Source) at com.mysql.jdbc.StandardSocketFactory.connect(StandardSocketFactory.java:211) at com.mysql.jdbc.MysqlIO.<init>(MysqlIO.java:300) ... 15 more

異常原因

幾乎嘗試了網絡上所有的解決方案均無效。漸漸開始懷疑是JDK在作怪。本地使用的JDK版本是1.8.0_151,服務器使用的是1.8.0.242,理論上是沒有影響的。

于是把服務器上的jdk卸載,從官網下載了安裝包重新安裝了1.8.0_241,數據庫連接的問題消失了。

后來仔細一想,不是小版本號的問題,而是安裝JDK的版本問題,本機安裝的JDK是從Oracle官網下載的,而服務器上存儲為了省事直接使用yum命令安裝的。而centos上默認給安裝了OpenJDK。我們知道,從jdk7之后,JDK和OpenJDK屬于兩個不同授權協議的版本,而OpenJDK源代碼不完整、OpenIDK只包含最精簡的JDK。

下面分享一下搜索上述異常過程中發現的其他原因導致類似的異常的情況及解決方案。

sock路徑問題

問題現象與上述一樣,除了服務器部署應用無法連接服務器之外,其他方式都可以連接數據庫。

導致問題的原因是:服務器有兩塊磁盤,中間執行過mv命令,將數據庫的存儲內容進行了移動操作,同時修改了datadir指向新的目錄。

結果:用JAVA程序本地連接失敗,拋出org.apache.commons.dbcp.SQLNestedException: Cannot create PoolableConnectionFactory (Communications link failure 異常。

解決方案:修改了datadir相應配置之后,要核查一下mysql.sock文件路徑的配置。默認會在/var/lib/mysql/mysql.sock或/temp/mysql.sock。然后,統一修改所有的端([client]、[mysql]、[mysqld]等)均使用統一路徑。

SSL連接問題

如果一次信息中還出現如下異常信息:

javax.net.ssl.SSLHandshakeException: No appropriate protocol (protocol is disabled or cipher suites are inappropriate) at sun.security.ssl.Handshaker.activate(Handshaker.java:529) at sun.security.ssl.SSLSocketImpl.kickstartHandshake(SSLSocketImpl.java:1492) at sun.security.ssl.SSLSocketImpl.performInitialHandshake(SSLSocketImpl.java:1361) at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1413) at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1397)

則有可能是SSL連接的問題。網絡是有朋友升級到jdk1.8之后出現上述異常。

解決方案:刪掉SSLv3。在JAVA_HOME/jre/lib/security/java.security文件中找到jdk.tls.disabledAlgorithns=SSLv3,……相關的配置,刪掉SSLv3部分。刪掉SSLv3就是允許SSL調用。

針對SSL連接的問題,還有一種情況就是Mysql使用SSL連接。關于如何配置可參看該文章:https://www.jb51.net/article/100432.htm。

數據庫連接超時

這種情況是網上主流的信息,有大量的文章,但往往都沒有說明具體的場景:應用程序使用過程中出現類似上述異常,注意這里是使用過程中,而不是啟動拋異常。

導致使用過程中出現異常的原因是:Mysql服務器默認的“wait_timeout”是8小時(28800秒),也就是一個connection空閑(沒有活動)超過8個小時,Mysql將自動斷開該connection。而連接池卻認為該連接還是有效的(因為并未校驗連接的有效性),當應用申請使用該連接時,就會導致上面的報錯。

解決方案:修改my.ini配置,增加超時時間或在連接url中添加“&autoReconnect=true”。

在port=3306下面添加如下配置:

wait_timeout=31536000interactive_timeout=31536000

然后重啟MySQL。

這種情況也有可能是數據庫連接池maxIdleTime配置導致的。

<!-- 最大空閑時間,60秒內未使用則連接被丟棄。若為0則永不丟棄。Default: 0 --> <property name='maxIdleTime' value='0'></property>

由于mysql的連接空閑超過8個小時就關閉了,但是連接池卻永不丟棄連接,認為該連接還是有效的(因為并未校驗連接的有效性),當應用申請使用該連接時,就會導致上面的報錯。

解決方法:將value設置為20。

其他原因

當然,關于MySQL連接出現類似異常還有其他很多原因:

數據庫賬戶訪問權限問題:指定ip和賬戶授權; 網絡權限問題:防火墻是否開啟對應的訪問權限; 端口問題:訪問的端口是否正確,端口是否開啟防火墻權限; 賬戶密碼問題:賬戶密碼錯誤或賬戶沒有指定ip的訪問權限; 數據庫驅動問題:數據庫驅動與數據庫對應版本不匹配。 網絡穩定問題:網絡不穩定導致的問題。 數據庫連接池問題:數據庫連接池配置過大,導致mysql默認連接數不夠的問題。 ipv4與ipv6的問題。

以上就是MySQL數據庫連接異常匯總的詳細內容,更多關于MySQL數據庫連接異常的資料請關注好吧啦網其它相關文章!

標簽: MySQL 數據庫
相關文章:
主站蜘蛛池模板: 铁艺,仿竹,竹节,护栏,围栏,篱笆,栅栏,栏杆,护栏网,网围栏,厂家 - 河北稳重金属丝网制品有限公司 山东太阳能路灯厂家-庭院灯生产厂家-济南晟启灯饰有限公司 | 药品冷藏箱厂家_低温冰箱_洁净工作台-济南欧莱博电子商务有限公司官网 | 精密冲床,高速冲床等冲压设备生产商-常州晋志德压力机厂 | 大通天成企业资质代办_承装修试电力设施许可证_增值电信业务经营许可证_无人机运营合格证_广播电视节目制作许可证 | 超声骨密度仪-骨密度检测仪-经颅多普勒-tcd仪_南京科进实业有限公司 | 灌装封尾机_胶水灌装机_软管灌装封尾机_无锡和博自动化机械制造有限公司 | 环压强度试验机-拉链拉力试验机-上海倾技仪器仪表科技有限公司 | 代理记账_公司起名核名_公司注册_工商注册-睿婕实业有限公司 | 新能源汽车教学设备厂家报价[汽车教学设备运营18年]-恒信教具 | 合肥白癜风医院_合肥治疗白癜风医院_合肥看白癜风医院哪家好_合肥华研白癜风医院 | 北京三友信电子科技有限公司-ETC高速自动栏杆机|ETC机柜|激光车辆轮廓测量仪|嵌入式车道控制器 | 佛山商标注册_商标注册代理|专利注册申请_商标注册公司_鸿邦知识产权 | 齿轮减速电机一体机_蜗轮蜗杆减速马达-德国BOSERL齿轮减速机带电机生产厂家 | 在线PH计-氧化锆分析仪-在线浊度仪-在线溶氧仪- 无锡朝达 | 北京宣传片拍摄_产品宣传片拍摄_宣传片制作公司-现像传媒 | 数控走心机-走心机价格-双主轴走心机-宝宇百科 | 逗网红-抖音网红-快手网红-各大平台网红物品导航 | 单电机制砂机,BHS制砂机,制沙机设备,制砂机价格-正升制砂机厂家 单级/双级旋片式真空泵厂家,2xz旋片真空泵-浙江台州求精真空泵有限公司 | 冷水机,风冷冷水机,水冷冷水机,螺杆冷水机专业制造商-上海祝松机械有限公司 | 常州翔天实验仪器厂-恒温振荡器-台式恒温振荡器-微量血液离心机 恒温恒湿箱(药品/保健品/食品/半导体/细菌)-兰贝石(北京)科技有限公司 | 杭州网络公司_百度SEO优化-外贸网络推广_抖音小程序开发-杭州乐软科技有限公司 | 手持式浮游菌采样器-全排二级生物安全柜-浙江孚夏医疗科技有限公司 | 北京易通慧公司从事北京网站优化,北京网络推广、网站建设一站式服务商-北京网站优化公司 | 学叉车培训|叉车证报名|叉车查询|叉车证怎么考-工程机械培训网 | 板材品牌-中国胶合板行业十大品牌-环保板材-上海声达板材 | 2025世界机器人大会_IC China_半导体展_集成电路博览会_智能制造展览网 | 上海赞永| 龙门加工中心-数控龙门加工中心厂家价格-山东海特数控机床有限公司_龙门加工中心-数控龙门加工中心厂家价格-山东海特数控机床有限公司 | LINK FASHION 童装·青少年装展 河南卓美创业科技有限公司-河南卓美防雷公司-防雷接地-防雷工程-重庆避雷针-避雷器-防雷检测-避雷带-避雷针-避雷塔、机房防雷、古建筑防雷等-山西防雷公司 | 不干胶标签-不干胶贴纸-不干胶标签定制-不干胶标签印刷厂-弗雷曼纸业(苏州)有限公司 | 柔性测斜仪_滑动测斜仪-广州杰芯科技有限公司 | 医养体检包_公卫随访箱_慢病随访包_家签随访包_随访一体机-济南易享医疗科技有限公司 | 河南新乡德诚生产厂家主营震动筛,振动筛设备,筛机,塑料震动筛选机 | 污水提升器,污水提升泵,地下室排水,增压泵,雨水泵,智能供排水控制器-上海智流泵业有限公司 | 丹尼克尔拧紧枪_自动送钉机_智能电批_柔性振动盘_螺丝供料器品牌 | 医学动画公司-制作3d医学动画视频-医疗医学演示动画制作-医学三维动画制作公司 | 电脑刺绣_绣花厂家_绣花章仔_织唛厂家-[源欣刺绣]潮牌刺绣打版定制绣花加工厂家 | 网架支座@球铰支座@钢结构支座@成品支座厂家@万向滑动支座_桥兴工程橡胶有限公司 | 无压烧结银_有压烧结银_导电银胶_导电油墨_导电胶-善仁(浙江)新材料 | 废气处理_废气处理设备_工业废气处理_江苏龙泰环保设备制造有限公司 | 天津货架厂_穿梭车货架_重型仓储货架_阁楼货架定制-天津钢力仓储货架生产厂家_天津钢力智能仓储装备 |