java.net.ConnectException: Connection timed out: connect

来源:互联网 发布:男网红淘宝店前十名 编辑:程序博客网 时间:2024/06/11 09:02

在编写应用的时候,为了调试程序方便,可以在异常处理代码中把异常信息显示出来,这样可以根据错误提示调试代码。异常处理代码通常可以写成这样:
try{

}catch(Exception e){
System.out.println(e.toString());
}
下面是一些常见的错误信息:
(1)驱动程序不存在
提示的错误信息如下:
java.lang.ClassNotFoundException: com.mysql.jdbc.Drive
后半部分是您在程序中写的驱动程序的名字。
解决方法:仔细检查类名是否写错,如果类名没有写错,则是驱动程序所在的压缩包没有引入工程,想办法引入。
(2)URL写错
提示的错误信息如下:
java.sql.SQLException: No suitable driver
解决方法:仔细检查URL的格式是否正确,不同数据库的URL格式不同。
(3)主机IP地址不正确或者网络不通
提示的错误信息如下:
com.mysql.jdbc.CommunicationsException: Communications link failure due to underlying exception:

** BEGIN NESTED EXCEPTION **

java.net.ConnectException
MESSAGE: Connection timed out: connect

STACKTRACE:

java.net.ConnectException: Connection timed out: connect
at java.net.PlainSocketImpl.socketConnect(Native Method)
at java.net.PlainSocketImpl.doConnect(Unknown Source)
at java.net.PlainSocketImpl.connectToAddress(Unknown Source)
at java.net.PlainSocketImpl.connect(Unknown Source)
at java.net.SocksSocketImpl.connect(Unknown Source)
at java.net.Socket.connect(Unknown Source)
at java.net.Socket.connect(Unknown Source)
at java.net.Socket.<init>(Unknown Source)
at java.net.Socket.<init>(Unknown Source)
at com.mysql.jdbc.StandardSocketFactory.connect(StandardSocketFactory.java:132)
at com.mysql.jdbc.MysqlIO.<init>(MysqlIO.java:273)
at com.mysql.jdbc.Connection.createNewIO(Connection.java:1639)
at com.mysql.jdbc.Connection.<init>(Connection.java:393)
at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:262)
at java.sql.DriverManager.getConnection(Unknown Source)
at java.sql.DriverManager.getConnection(Unknown Source)
at test.JDBCTest.oracleTest(JDBCTest.java:25)
at test.JDBCTest.main(JDBCTest.java:12)
** END NESTED EXCEPTION **
解决方法:查看IP地址是否正确,网络是否有问题。
(4)端口错误或者数据库服务器没有启动
提示的错误信息如下:
com.mysql.jdbc.CommunicationsException: Communications link failure due to underlying exception:

** BEGIN NESTED EXCEPTION **

java.net.ConnectException
MESSAGE: Connection refused: connect

STACKTRACE:

java.net.ConnectException: Connection refused: connect
at java.net.PlainSocketImpl.socketConnect(Native Method)
at java.net.PlainSocketImpl.doConnect(Unknown Source)
at java.net.PlainSocketImpl.connectToAddress(Unknown Source)
at java.net.PlainSocketImpl.connect(Unknown Source)
at java.net.SocksSocketImpl.connect(Unknown Source)
at java.net.Socket.connect(Unknown Source)
at java.net.Socket.connect(Unknown Source)
at java.net.Socket.<init>(Unknown Source)
at java.net.Socket.<init>(Unknown Source)
at com.mysql.jdbc.StandardSocketFactory.connect(StandardSocketFactory.java:132)
at com.mysql.jdbc.MysqlIO.<init>(MysqlIO.java:273)
at com.mysql.jdbc.Connection.createNewIO(Connection.java:1639)
at com.mysql.jdbc.Connection.<init>(Connection.java:393)
at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:262)
at java.sql.DriverManager.getConnection(Unknown Source)
at java.sql.DriverManager.getConnection(Unknown Source)
at test.JDBCTest.oracleTest(JDBCTest.java:25)
at test.JDBCTest.main(JDBCTest.java:12)


** END NESTED EXCEPTION **
解决方法:查看端口是否正确,数据库服务器是否启动。
(5)数据库名字不正确
提示的错误信息如下:
java.sql.SQLException: Unknown database 'test2'
解决方法:查看数据库是否存在。
(6)用户名或者口令不正确
提示的错误信息如下:
java.sql.SQLException: Access denied for user
'roo'@'localhost' (using password: YES)
解决方法:确认用户名和口令是否正确。
(7)表名错误
提示的错误信息如下:
java.sql.SQLException: Table 'test.student1' doesn't exist
解决方法:查看表是否存在,表名是否写错。
(8)列名错误
提示的错误信息如下:
java.sql.SQLException: Unknown column 'sid' in 'field list'
解决方案:仔细查看数据库表中的列名。
(9)处理结果集的时候,要获取的列的序号大于列数,或者小于0
提示的错误信息如下:
java.sql.SQLException: Column Index out of range, 4 > 3.
这个错误产生的背景是:数据库表中只有3列,而在取信息的时候使用了rs.getString(4),尤其是在使用循环处理的时候容易犯这样的错误。
(10)执行insert语句的时候,表中的列数与插入语句中的不相同
提示的错误信息如下:
java.sql.SQLException: Column count doesn't match value count at row 1
该错误产生的背景是:数据库表中有3列,而插入的时候给了4个值,SQL语句如下:
insert into student values('0011323','李旭',22,99)。
(11)执行insert语句的时候,主键重复。
提示的错误信息如下:
java.sql.SQLException: Duplicate entry '0011323' for key 1
该错误产生的背景是:1条SQL语句连续执行了两遍,第二遍就出错了。
(12)执行insert语句的时候,值过长
提示的错误信息如下:
java.sql.SQLException: Data too long for column 'id' at row 1
解决方案,查看数据库中列的长度。
详细出处参考:
http://www.jb51.net/article/18421.htm

mysql与tomcat不在一台机器上
(1):mysql默认不支持远程连接的【即非一台机器上的应用无法访问mysql】,如要远程访问mysql需要配置远程访问权限【这个你上网上查一下吧】,等有时间我写个blog整理下。
(2):mysql机器是否有什么设置导致3306端口不能让其他机器访问【如防火墙】。
可以使用telnet访问下3306端口。
(3):mysql应用出现问题,这你在mysql服务器尝试下访问下【这个问题的可能性很少】;
mysql与tomcat在同一台机器上
(1):mysql端口是否正确。
(2):服务器是否采用正确的连接方式
(3):是否和本地软件产生冲突。

 

原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 红米5连wifi很慢怎么办 电脑百度网盘下载速度慢怎么办 新手机与旧手机同步了怎么办 百度网盘2t满了怎么办 魅族手机相册的密码忘了怎么办 手机百度网盘本地空间不足怎么办 百度网盘保存视频内存不够怎么办 别人的百度网盘链接打不开怎么办 百度网盘视频插件升级失败怎么办 退苹果id重新登陆照片没了怎么办 苹果升级后照片效果没了怎么办 360云盘个人云盘停止服务怎么办 小米手机账号掉了手机卡没了怎么办 百度网盘下载后不能注册怎么办 微信发出的文件无法撤回怎么办 微信群发错消息无法撤回怎么办 百度网盘登录要验证码怎么办 百度网盘备份记录怎么办能删掉 手机酷狗听歌耳机声音太小了怎么办 苹果6s微信通话声音变粗怎么办 千千静听多个列表合成一个了怎么办 别人用手机号注册了邮箱怎么办 微信身份信息验证未通过怎么办 快递地址填错了已经发到了怎么办 孩子威胁同学给她买东西吃怎么办 在超市买小孩米粉过期了怎么办 出口货物被海关扣了说仿牌怎么办 有一批仿牌被宁波海关查了怎么办 付了定金不想要车了怎么办 泥墙刮石灰上涂料现在刮腻子怎么办 月经最后一天同房了怎么办吃什么药 奶水太多了宝宝总是呛到了怎么办 婴儿刚吃完奶大量喷奶怎么办 我干活细致领导说我慢怎么办 怀孕初期吃了加明矾的粉皮怎么办 绿豆面黄豆面白面蒸馒头怎么办 画油画时把颜料染在衣服上怎么办 买的布衣柜少了一个管子怎么办 小2球刚好进2球怎么办 大2球刚好进2球怎么办 大球2进了2球怎么办