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)
上一篇 2022年6月23日 下午6:16
下一篇 2022年6月23日 下午6:16


相关推荐

  • 数据库关系代数除法意义_关系代数运算除法

    数据库关系代数除法意义_关系代数运算除法除法运算的定义:这个概念的描述的非常抽象,刚开始学习的同学完全不知所云。这里通过一个实例来说明除法运算的求解过程设有关系R、S如图所示,求R÷S的结果求解步骤过程:第一步:找出关系R和关系S中相同的属性,即Y属性。在关系S中对Y做投影(即将Y列取出);所得结果如下第二步:被除关系…

    2025年8月1日
    4
  • js 三目运算详解

    js 三目运算详解JavaScript 三目运算 1 三目运算的公式公式 代码 1 代码 2 此为判断条件 结果 1 结果 2 当条件成立时运行结果 1 当条件不成立时运行结果 2 可以自行尝试一下代码 varpass true pass 1 alert 1 alert 2 此时会弹出 1 pass 1 alert 1 alert 2 此时会弹出 2

    2026年3月18日
    2
  • ELK+FileBeat日志分析系统(正式环境nginx日志)

    ELK+FileBeat日志分析系统(正式环境nginx日志)

    2021年5月29日
    159
  • JVM架构和GC垃圾回收机制(JVM面试不用愁)[通俗易懂]

    JVM架构和GC垃圾回收机制(JVM面试不用愁)[通俗易懂]JVM架构和GC垃圾回收机制详解JVM架构图分析下图:参考网络+书籍,如有侵权请见谅(想了解Hadoop内存溢出请看:Hadoop内存溢出(OOM)分类、参数调优化)JVM被分为三个主要的子系统(1)类加载器子系统(2)运行时数据区(3)执行引擎1.类加载器子系统Java的动态类加载功能是由类加载器子系统处理。当它在运行时(不是编译时)首次引用一个类时,它加载、链…

    2022年4月28日
    59
  • Softmax函数求导

    Softmax函数求导来源:https://blog.csdn.net/zt_1995/article/details/62227603其实整个推导,上面这个图片已经介绍得十分清楚了,但是仍有很多小步骤被省略掉了,我会补上详细的softmax求导的过程:…

    2025年6月2日
    7
  • django pycharm_pycharm调试django

    django pycharm_pycharm调试django前言:主要是在开发过程中一些采坑和记录,整理一下资料以防自己以后忘了,也为正在初学或者还未特别熟练使用django的同学能够避开这些,且能够系统性的学习django的使用,这里就不写目录了按照我自己的开发顺序来,大家看到专栏里面的文章顺序就是我的目录了,在本专栏里的代码争取让大家拿到就能用,做一个伸手党,网上好多代码不知道是版本原因还是其他简直是无语,不能用还一堆bug。…

    2022年8月28日
    3

发表回复

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

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