如何连接到另一台主机上的MySQL服务器?

7

Django可以通过在settings.py中将HOSTPORT设置为空字符串,来简单地连接到自己的MySQL服务器:

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql', # Add 'postgresql_psycopg2', 'postgresql', 'mysql', 'sqlite3' or 'oracle'.
        'NAME': 'dbname',                   # Or path to database file if using sqlite3.
        'USER': 'root',                      # Not used with sqlite3.
        'PASSWORD': 'root',                  # Not used with sqlite3.
        'HOST': '',                      # Set to empty string for localhost. Not used with sqlite3.
        'PORT': '',                      # Set to empty string for default. Not used with sqlite3.
    }
}

我的问题是如何使它能够连接到另一个主机上的另一个数据库?假设我的计算机是192.168.1.33,要连接的另一台计算机是192.168.1.34,两者都在同一个网络上。我尝试将其设置为:

'HOST': '192.168.1.34',
'PORT': '3306',

并且

'HOST': '192.168.1.34',
'PORT': '',

但是这两者都会导致 OperationalError 的出现:
(2003, "Can't connect to MySQL server on '192.168.1.34'(10061)")

解决方案:感谢 @cdhowie
  1. /etc/mysql/my.cnf 中配置 bind-address 为您想要的主机。

  2. 为您想要授予权限的主机创建新用户(如果没有)。

  3. 检查该用户的权限(如果访问被拒绝)。


你检查了192.168.1.34上的防火墙吗?MySQL在192.168.1.34上绑定到127.0.0.1了吗? - cdhowie
@cdhowie 我不知道如何检查MySQL的防火墙和绑定,请告诉我该怎么做。 - Protocole
MySQL服务器运行在哪个操作系统上? - Jess
5
默认情况下,基于Debian的发行版将MySQL配置为仅绑定到本地主机,这意味着其他主机无法连接。调整你的MySQL配置,问题将得到解决。 - cdhowie
@cdhowie:这可能应该是一个答案。 - Jim Garrison
显示剩余2条评论
1个回答

23

默认情况下,基于Debian的发行版将MySQL配置为仅绑定到本地主机,这意味着其他主机无法连接。修复MySQL配置即可解决此问题。

编辑/etc/mysql/my.cnf文件,并更改以下行:

bind-address = 127.0.0.1

变成这样:

bind-address = 0.0.0.0

这将使MySQL对所有网络接口都可见,因此如果该服务器暴露给不受信任的主机,请确保已经采取了安全措施。


工作得很好!!非常感谢,但正如您所提到的,让我考虑安全性,因为它对每个IP都是开放的。 - dav
@Davo 当然你也会想要使用防火墙来限制对服务器的访问。 ;) - cdhowie
谢谢你的回答 :) - dav

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接