关于连接 VirtualBox NAT 下的 MySQL 服务

这两天尝试外部连接 VirtualBox 中 CentOS 的 MySQL 服务器,可谓历尽一番辛苦。


最开始用的是 Java 的 mysql 驱动连接,无奈连接不上。然后下载 SQLyog 的 Community 版进行连接,依然难以通过。


于是开始此次的辛苦旅程。


1 首先想到的 MySQL 服务本身设置的问题。


问题何在呢,端口 or IP?检查尝试设置之后,无论是port forwarding 还是 bind-address,问题依旧。


之后尝试修改MySQL的用户访问控制。


GRANT ALL ON *.* TO root@'%' IDENTIFIED BY 'root'; 

继续测试:

mysql:
     [echo] running
     [java] ......
     [java] Error
     [java] com.mysql.jdbc.CommunicationsException: Communications link failure due to underlying exception:
     [java]
     [java] ** BEGIN NESTED EXCEPTION **
     [java]
     [java] com.mysql.jdbc.CommunicationsException
     [java] MESSAGE: Communications link failure due to underlying exception:
     [java]
     [java] ** BEGIN NESTED EXCEPTION **
     [java]
     [java] java.io.EOFException
     [java]
     [java] STACKTRACE:
     [java]
     [java] java.io.EOFException
     [java]     at com.mysql.jdbc.MysqlIO.readFully(MysqlIO.java:1963)
     [java]     at com.mysql.jdbc.MysqlIO.readPacket(MysqlIO.java:557)
     [java]     at com.mysql.jdbc.MysqlIO.doHandshake(MysqlIO.java:1027)
     [java]     at com.mysql.jdbc.Connection.createNewIO(Connection.java:2743)
     [java]     at com.mysql.jdbc.Connection.<init>(Connection.java:1553)
     [java]     at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:266)
     [java]     at java.sql.DriverManager.getConnection(DriverManager.java:620)
     [java]     at java.sql.DriverManager.getConnection(DriverManager.java:200)
     [java]     at org.huys.db.MySQLConnect.main(Unknown Source)
     [java]     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
     [java]     at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
     [java]     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
     [java]     at java.lang.reflect.Method.invoke(Method.java:616)
     [java]     at org.apache.tools.ant.taskdefs.ExecuteJava.run(ExecuteJava.java:217)
     [java]     at org.apache.tools.ant.taskdefs.ExecuteJava.execute(ExecuteJava.java:152)
     [java]     at org.apache.tools.ant.taskdefs.Java.run(Java.java:764)
     [java]     at org.apache.tools.ant.taskdefs.Java.executeJava(Java.java:218)
     [java]     at org.apache.tools.ant.taskdefs.Java.executeJava(Java.java:132)
     [java]     at org.apache.tools.ant.taskdefs.Java.execute(Java.java:105)
     [java]     at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:288)
     [java]     at sun.reflect.NativeMeth
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
VirtualBox NAT网络无法连接到外部互联网时,有几种可能的原因和解决方法。 1. 防火墙设置:首先检查主机和虚拟机的防火墙设置。确保主机和虚拟机的防火墙允许“VirtualBox NAT网络”通过,并禁用对该网络的任何阻止或限制。 2. 网络适配器设置:确保虚拟机的网络适配器配置正确。在VirtualBox中,选择虚拟机,然后点击“设置”按钮。在“网络”选项卡中,确保网络适配器选择为“NAT”。 3. DHCP设置:检查虚拟机中的DHCP设置。在虚拟机中,打开网络配置或设置界面,并确保DHCP已启用。这样虚拟机将获得有效的IP地址和网关信息,从而连接到外部网络。 4. DNS设置:尝试手动设置虚拟机的DNS服务器。打开虚拟机中的网络配置,输入可靠的DNS服务器地址,例如“8.8.8.8”(Google的公共DNS服务器)。这样可确保虚拟机能够正确解析外部域名。 5. 虚拟网络编辑器设置:有时,VirtualBox的虚拟网络编辑器可能需要调整。打开VirtualBox管理界面,点击“文件”>“主机网络管理器”,然后检查并更正任何可能的配置错误。 6. 更新和修复:确保运行的是最新版本的VirtualBox。在VirtualBox网站上下载并安装最新版本。此外,还可以尝试重新安装VirtualBox来修复任何潜在的软件问题。 如果以上方法都无法解决问题,可以在VirtualBox的官方网站或论坛上寻求进一步的帮助和支持。这些渠道通常会提供更专业的解决方案和支持。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值