AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 652220
Accepted
Xeoncross
Xeoncross
Asked: 2014-12-13 12:23:45 +0800 CST2014-12-13 12:23:45 +0800 CST 2014-12-13 12:23:45 +0800 CST

无法从另一台服务器连接到 MySQL

  • 772

我在同一个子网上有两台服务器。

  • 192.168.100.1 (mysql)
  • 192.168.100.2 (php)

MySQL 似乎在它的盒子上运行良好,但我似乎无法连接到它。这些都是 ubuntu 盒子,iptables 和 ufw 没有运行。以下命令均来自 MySQL 机器本身。这些都不适用于.100.2(php)框中。

我的.cnf

#bind-address           = 127.0.0.1
bind-address = 192.168.100.1

netstat 说这是真的:

[email protected] /etc/mysql $ netstat -plutn
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN      8583/sshd       
tcp        0      0 192.168.100.1:3306      0.0.0.0:*               LISTEN      30654/mysqld    
tcp        0      0 0.0.0.0:2828            0.0.0.0:*               LISTEN      29946/monit     
tcp        0      0 0.0.0.0:1167            0.0.0.0:*               LISTEN      23175/cdp       
tcp6       0      0 :::22                   :::*                    LISTEN      8583/sshd  

telnet 说不错

[email protected] /etc/mysql $ telnet 192.168.100.1 3306
Trying 192.168.100.1...
Connected to 192.168.100.1.
Escape character is '^]'.
[
5.5.40-0ubuntu0.12.04.1&KM~Se$!u??L\hw=gp{<Uvrmysql_native_password

!#08S01Got packets out of orderConnection closed by foreign host.

mysql客户端说很好:

[email protected] /etc/mysql $ mysql -uroot -p
Enter password: 
Welcome to the MySQL monitor.  Commands end with ; or \g.

当我尝试连接时.100.2,在连接超时之前我什么也得不到:

[email protected] /etc/php5/fpm $ mysql -uroot -p -h 192.168.100.1 --connect-timeout 4
Enter password: 
ERROR 2003 (HY000): Can't connect to MySQL server on '192.168.100.1' (4)

我可以ping .100.1从.100.2包装盒中获得亚毫秒响应时间。

这是 MySQL 授权设置:

mysql> SELECT user,host from mysql.user;
+------------------+--------------+
| user             | host         |
+------------------+--------------+
| root             | 127.0.0.1    |
| root             | 192.168.1.%  |
| root             | 192.168.100.%|
| root             | 192.168.200.%|
| root             | ::1          |
| debian-sys-maint | localhost    |
| example          | localhost    |
| o3backup         | localhost    |
| root             | localhost    |
| root             | voice-mysql  |
+------------------+--------------+
10 rows in set (0.00 sec)

我为所有地方添加了新的赠款,但问题仍然存在。

mysql> show grants for 'root'@'%';
+--------------------------------------------------------------------------------------------------------------+
| Grants for root@%                                                                                            |
+--------------------------------------------------------------------------------------------------------------+
| GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY PASSWORD '...' |
+--------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

更新

原来系统被我不知道的系统文件更改以某种方式锁定。显然,它阻止了某些非标准的网络操作。老实说,给我这个盒子的人忘记了这一切,这真的令人沮丧。老实说,我不知道他们对它做了什么,甚至他们也不记得了。尽管如此,这里列出的答案是针对普通人的最彻底的故障排除指南。应该是这些问题之一。

ubuntu
  • 2 2 个回答
  • 7018 Views

2 个回答

  • Voted
  1. Best Answer
    user87664
    2014-12-13T12:51:27+08:002014-12-13T12:51:27+08:00

    从您的 php 服务器连接到您的 mysql 服务器时,您似乎收到了Enter password:提示,但之后就没有了。如果是这样,那么用户的 mysql 用户帐户设置root可能会拒绝连接。查看您的rootmysql 用户帐户并确保该Host字段设置为允许连接。

    来自(MySQL)拒绝访问错误的原因:

    如果您不知道您要连接的机器的 IP 地址或主机名,您应该在用户表中放置一个带有 '%' 作为 Host 列值的行。

    尝试从客户端计算机连接后,使用 SELECT USER() 查询来查看您是如何真正连接的。然后将用户表行中的“%”更改为日志中显示的实际主机名。否则,您的系统将不安全,因为它允许来自任何主机的给定用户名的连接。

    我怀疑连接时表格的排序方式会导致问题。您可能需要查看访问控制,第 1 阶段:连接验证

    • 2
  2. bbaassssiiee
    2014-12-13T13:52:25+08:002014-12-13T13:52:25+08:00

    在http://dev.mysql.com/doc/refman/5.0/en/access-denied.html阅读错误 2003 的详细手册

    • 0

相关问题

  • 无法通过 Ubuntu VPN 访问外部网络

  • ubuntu apt-get upgrade - 如何在 shell 中单击确定?

  • VirtualBox 上 Ubuntu 的访客优化技巧 [关闭]

  • 外部硬盘上的 virtualbox 虚拟硬盘驱动器(Vista 主机上的 ubuntu 客户机)

  • 如何在 Ubuntu 上挂载 LVM 分区?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve