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

时间:2011-08-20 06:47:22

标签: mysql django database-connection

Django可以通过将HOST中的PORTsettings.py设置为''(空字符串)来简单地连接到自己的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

  2. 中将绑定地址配置到您想要的主机
  3. 为要授予访问权限的主机创建新用户(如果没有)。

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

1 个答案:

答案 0 :(得分:22)

默认情况下,基于Debian的发行版将MySQL配置为仅绑定到localhost,这意味着其他主机无法连接到它。修复你的MySQL配置,它会工作。

修改/etc/mysql/my.cnf并更改此行:

bind-address = 127.0.0.1

对此:

bind-address = 0.0.0.0

这会将MySQL暴露给所有网络接口,因此如果此服务器暴露给不受信任的主机,请确保您已采取安全措施。