com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure

com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure一、前言在学习AndroidAndroid入门案例(二)——JDBC连接MySql数据库使用jdbc方式连接本地数据库时报错:com.mysql.jdbc.exceptions.jdbc4.CommunicationsException:CommunicationslinkfailureThelastpacketsentsuccessfullytotheserve……

大家好,又见面了,我是你们的朋友全栈君。

目录

一、前言

二、解决


一、前言

在学习AndroidAndroid入门案例(二)——JDBC连接MySql数据库使用jdbc方式连接本地数据库时报错:

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.

网上百度方案绝大部分有:

1.网上说是出现这个问题是因为超时,数据库连接(java.sql.Connection)连接关闭,因此可以设置连接最长时间,wait_timeout的默认最长时间是28800秒,也就是8小时时间

以root打开该文件:sudo gedit /etc/mysql/my.cnf

再末尾添加:

[mysqld]
     wait_timeout=31536000
     interactive_timeout=31536000

保存重启生效

但是并没有解决我的问题,  各位可以试一下是否可以 解决你们的问题,如若不行,再看下文

二、解决

1.如果访问的是本地数据库,localhost或者127.0.0.1的ip其实是不对的  

连接数据库超时,可能是因为ip不对,网上使用jdbc连接数据库,有一部分数据库ip中为localhost或者127.0.0.1,刚开始我也是,结果一直报错,然后在测试类中却可以,运行安卓案例就不可以,问了师傅才明白,数据库是安装才本机上的,安卓程序运行访问的数据库ip地址是localhost,安卓程序是独立在Virtual Device中的,难道你虚拟手机中安装了数据库???

所以说,电脑和安卓虚拟机其实是两个ip地址,应该改为本机数据库地址,

  • 可以在cmd中输入ipconfig查看Ipv4地址,换掉localhost 或者127.0.0.1
  • 或者ip改为10.0.2.2,这是Android虚拟机的默认宿主IP地址

本人的到此还是有问题,所以接着下文!

2.如果访问的是远程数据库或者本地数据库还是连接失败,检查数据库是否公开权限

MySQL中root用户默认只能用于本地本机连接数据库,如果你的数据库没有公开过权限的话,默认是没有远程访问权限的

本人为了方便,新建了一个local用户,新建用户及授权操作如下:

1)进入数据库:mysql -u root -p密码

2)use mysql;

3)create user ‘userName’@’host’ identified by ‘password’;

      com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure

  • userName:创建数据库新用户的用户名
  • host:指定该用户在哪个主机上可以登陆,如果是本地用户可用localhost;如果想让该用户可以从任意远程主机登陆,可以使用通配符%
  • password:该用户的登陆密码,密码可以为空,如果为空则该用户可以不需要密码登陆服务器

4)grant all privileges on databaseName.tableName to ‘userName’@’host’;

     com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure

  • privileges:用户的操作权限,如SELECT,INSERT,UPDATE等,如果要授予所的权限则使用all privileges 
  • databaseName:数据库名
  • userName:指定需要赋予权限的用户
  • tableName:表名,如果要授予该用户对所有数据库和表的相应操作权限则可用*表示,如*.*
  • host:指定该用户在哪个主机上可以登陆,如果是本地用户可用localhost;如果想让该用户可以从任意远程主机登陆,可以使用通配符%

现在连接数据库信息变为:

private static String driver = "com.mysql.jdbc.Driver";//MySQL 驱动
    private static String url = "jdbc:mysql://ip:3306/dbname";//MYSQL数据库连接Url  ip:数据库ip地址    dbname:连接的数据库名
    private static String user = "local";//用户名
    private static String password = "123456";//密码

终于OK了!!!

欢迎访问我的个人小站哦:我爱吃土豆

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/152234.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • sql语句的简单用法 db2删除修改字段名,db2一次增加多个字段

    sql语句的简单用法 db2删除修改字段名,db2一次增加多个字段

    2021年7月16日
    128
  • vs2008sp1补丁怎么安装_win10系统怎么安装cad2005

    vs2008sp1补丁怎么安装_win10系统怎么安装cad2005我第一次安装这个补丁的时候就挂了,搞得VS2005和相关的一些程序都不能运行,后来在网上找到了一些解决方法,结合自己的实际体验,写了这篇教程。补丁相关资料:简体中文版补丁名称:VS80sp1-KB926604-X86-CHS.exe版本:50727.762知识库(KB)文章:KB928957发布日期:2006/12/14简体中文版补丁大小:430

    2022年9月28日
    2
  • Java Bean详解

    Java Bean详解JavaBean是一种JAVA语言写成的可重用组件。为写成JavaBean,类必须是具体的和公共的,并且具有无参数的构造器。JavaBean通过提供符合一致性设计模式的公共方法将内部域暴露成员属性,set和get方法获取。众所周知,属性名称符合这种模式,其他Java类可以通过自省机制(反射机制)发现和操作这些JavaBean的属性。功能特点用户可以使…

    2022年6月12日
    25
  • UML图之四——活动图

    UML图之四——活动图点击打开链接活动图是一种流程图,用来描述活动的序列,从一个活动到另一个活动的控制流。活动图的作用:描述用例,描述类的操作。 活动图的构成必要组成元素:1、活动:命令的执行,活动的进行。图符表示:2、状态:开始状态,结束状态。图符表示: 3、转移:活动之间,活动与状态之间的转换。4、判断:对一个动作或者状态进行判断,然后选择要执行的下一步操作。

    2022年5月5日
    41
  • 斐波那契数列python实现

    斐波那契数列python实现方法一deffbnc(n):ifnotisinstance(n,int):raiseValueError('nmustbeint')ifn==1:retu

    2022年7月6日
    20
  • int转long类型[通俗易懂]

    int转long类型[通俗易懂]一.将long型转化为int型,这里的long型是基础类型:longa=10;intb=(int)a;二.将Long型转换为int型的,这里的Long型是包装类型:Longa=10;intb=a.intValue();三.将int型转化为long型,这里的int型是基础类型:inta=10;longb=(int)a;四.将Integer…

    2022年6月6日
    301

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号