問題:
今早,發現昨天部署的JAVA-WEB服務,不正常啓動了,因而查看後臺日誌,發現java
11:07:05.358 [Druid-ConnectionPool-Create-1102883776] ERROR com.alibaba.druid.pool.DruidDataSource - create connection holder error com.mysql.cj.jdbc.exceptions.CommunicationsException: Communications link failure The last packet successfully received from the server was 1,003 milliseconds ago. The last packet sent successfully to the server was 1,003 milliseconds ago. at com.mysql.cj.jdbc.exceptions.SQLError.createCommunicationsException(SQLError.java:172) ~[mysql-connector-java-8.0.11.jar:8.0.11] at com.mysql.cj.jdbc.exceptions.SQLExceptionsMapping.translateException(SQLExceptionsMapping.java:64) ~[mysql-connector-java-8.0.11.jar:8.0.11] at com.mysql.cj.jdbc.ConnectionImpl.isReadOnly(ConnectionImpl.java:1518) ~[mysql-connector-java-8.0.11.jar:8.0.11] at com.mysql.cj.jdbc.ConnectionImpl.isReadOnly(ConnectionImpl.java:1487) ~[mysql-connector-java-8.0.11.jar:8.0.11] at com.alibaba.druid.pool.DruidConnectionHolder.<init>(DruidConnectionHolder.java:143) ~[druid-1.0.29.jar:1.0.29] at com.alibaba.druid.pool.DruidConnectionHolder.<init>(DruidConnectionHolder.java:83) ~[druid-1.0.29.jar:1.0.29] at com.alibaba.druid.pool.DruidDataSource.put(DruidDataSource.java:1890) [druid-1.0.29.jar:1.0.29] at com.alibaba.druid.pool.DruidDataSource$CreateConnectionThread.run(DruidDataSource.java:2143) [druid-1.0.29.jar:1.0.29] Caused by: com.mysql.cj.exceptions.CJCommunicationsException: Communications link failure
解決:
打開navicat,進行解決mysql
一、選擇navicat的"工具-->命令列界面"
二、查看WAIT_TIMEOUT的值
mysql> show global variables like 'wait_timeout'; +---------------+-------+ | Variable_name | Value | +---------------+-------+ | wait_timeout | 28800 | +---------------+-------+ 1 row in set (0.24 sec) mysql> select variable_name,variable_value from information_schema.session_variables where variable_name in ('interactive_timeout','wait_timeout'); 1109 - Unknown table 'SESSION_VARIABLES' in information_schema mysql> set session WAIT_TIMEOUT=1814400; Query OK, 0 rows affected (0.01 sec) mysql> show global variables like 'wait_timeout'; +---------------+-------+ | Variable_name | Value | +---------------+-------+ | wait_timeout | 28800 | +---------------+-------+ 1 row in set (0.03 sec) mysql> show global variables like 'timeout'; Empty set mysql> set global WAIT_TIMEOUT=1814400; Query OK, 0 rows affected (0.00 sec) mysql> show global variables like 'wait_timeout'; +---------------+---------+ | Variable_name | Value | +---------------+---------+ | wait_timeout | 1814400 | +---------------+---------+ 1 row in set (0.04 sec) mysql>
三、再次刷新JAVA-WEB界面,成功
總結:
1. 控制鏈接最大空閒時長的wait_timeout參數。
2. 對於非交互式鏈接,相似於jdbc鏈接,wait_timeout的值繼承自服務器端全局變量wait_timeout(set session WAIT_TIMEOUT=1814400;是不起做用的,只有set global WAIT_TIMEOUT=1814400;才行)
對於交互式鏈接,相似於mysql客戶單鏈接,wait_timeout的值繼承自服務器端全局變量interactive_timeout。
3. 判斷一個鏈接的空閒時間,可經過show processlist輸出中Sleep狀態的時間。
sql