Pro*_*ole 7 mysql django database-connection
Django的可以简单地通过设置连接到自己的MySQL服务器HOST
,并PORT
在settings.py
为""(空字符串):
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.
}
}
Run Code Online (Sandbox Code Playgroud)
我的问题是如何使它能够连接另一台主机上的另一个数据库?假设我的机器192.168.1.33
和另一台要连接的机器192.168.1.34
都在同一个网络上.我试图将其设置为:
'HOST': '192.168.1.34',
'PORT': '3306',
Run Code Online (Sandbox Code Playgroud)
和
'HOST': '192.168.1.34',
'PORT': '',
Run Code Online (Sandbox Code Playgroud)
但两者都导致了这个OperationalError
:
(2003, "Can't connect to MySQL server on '192.168.1.34'(10061)")
Run Code Online (Sandbox Code Playgroud)
解决方案:信用@cdhowie
将绑定地址配置到所需的主机 /etc/mysql/my.cnf
为要授予访问权限的主机创建新用户(如果没有).
检查该用户的权限(如果访问被拒绝).
cdh*_*wie 22
默认情况下,基于Debian的发行版将MySQL配置为仅绑定到localhost,这意味着其他主机无法连接到它.修复你的MySQL配置,它会工作.
编辑/etc/mysql/my.cnf
并更改此行:
bind-address = 127.0.0.1
Run Code Online (Sandbox Code Playgroud)
对此:
bind-address = 0.0.0.0
Run Code Online (Sandbox Code Playgroud)
这将使MySQL暴露给所有网络接口,因此如果此服务器暴露给不受信任的主机,请确保您已采取安全措施.
归档时间: |
|
查看次数: |
20355 次 |
最近记录: |