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


相关推荐

  • 忍不住为这样的智慧课堂打call!

    忍不住为这样的智慧课堂打call!

    2022年3月8日
    49
  • nextint() java_java中random.nextint()的用法

    nextint() java_java中random.nextint()的用法java中random.nextint()的用法发布时间:2020-06-1514:41:57来源:亿速云阅读:193作者:鸽子random.nextInt()的用法1、不带参数的nextInt()会生成所有有效的整数(包含正数,负数,0)2、带参的nextInt(intx)则会生成一个范围在0~x(不包含X)内的任意正整数例如:intx=newRandom.nextInt(100);则x…

    2022年7月22日
    14
  • 超级详细 倍增法 实现 LCA

    描述:倍增法用于很多算法当中,通过字面意思来理解就是翻倍增加嘛,这里着重讲使用倍增法在树中的应用求LCA;LCA是啥呢 在一棵树当中 lca表示的是两个节点最近公共祖先, 大家看这课树哈节点5,3的lca就是1,13和11的LCA就是6。节点8,12的lca就是8,那么我们如何通过被增来实现LCA呢。首先大家看下这个数组grand[x][i],这个数组表示标号为x节

    2022年4月9日
    49
  • 如何获取讯飞星火 API Key 密钥(分步指南)

    如何获取讯飞星火 API Key 密钥(分步指南)

    2026年3月14日
    1
  • coreseek_coreone

    coreseek_coreoneSQL结构化查询语言(是一种标准,所有的关系型数据库Mysql,sqlserver,oracle)sphinx的使用两种方式:第一种:使用sphinx的API来操作sphinx(常用)sphi

    2022年8月2日
    10
  • rebar3使用介绍(六)用户自定义文件配置

    rebar3使用介绍(六)用户自定义文件配置rebar3 使用介绍 五 用户自定义文件配置例子选项合并算法依赖和配置文件依赖永远按照 prod 模式对应的 profile 进行编译 不会有其他 当然不包括 default 任何东西会被额外的套用上来 即使它们是为 prod 依赖项配置的 仍然会将其提取到其声明的配置文件的配置文件目录中 例如 顶层的依赖关系 deps 将放在 build default lib 下 test 将放在 build test li

    2025年7月13日
    6

发表回复

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

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