2

我遵循了数据库连接配置的指南: https ://nesdis.github.io/djongo/database-configuration/

但是,它总是连接到本地主机,而不是我的设置。

有人对这个问题有任何想法吗?

我的包版本:

Django  2.0
django-cors-headers 2.4.0   
django-rest-auth    0.9.3   
djangorestframework 3.9.0   
djongo  1.1 
mongoengine 0.16.3  
pip 10.0.1  
pymongo 3.7.2   
urllib3 1.24.1  

我的设置

DATABASES = {
    'default': {
        'ENGINE': 'djongo',
        'NAME': 'test_db',
        'HOST': 'somewhere.com',
        'PORT': 27017
    }
}
4

3 回答 3

8

似乎在某个地方,djongo 改变了数据库设置的结构。在浪费了几天时间试图找到解决方案之后,我遇到了一个具有更新结构的页面,尝试将您的 DATABASE 结构设置为:

DATABASES = {
  'default': {  
    'ENGINE':   'djongo',
    'NAME':     'yourmongodb',
    'CLIENT': {
      'host': 'some-host.or.ip',
      'port': 27017,
      'username': 'youruser',
      'password': 'yourdbpass',
      'authSource': 'yourcollection',
    }
  },
}
于 2020-02-16T01:35:35.723 回答
0

您是否在 settings.py 文件中编辑了您的设置

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'XXXX',
        'USER': 'XXX',
        'PASSWORD': 'XXXX',
        'HOST': 'XXX.XXX.XXX.XXX',
        'PORT': '3306',
        'OPTION': {
            'init_command': "SET sql_mode='STRICT_TRANS_TABLES'"
        }
    }
}
于 2019-01-10T12:33:30.050 回答
0

首先:在 localhost 上创建一个到远程 mysql 服务器的 SSH 隧道

ssh -N -L 3306:127.0.0.1:3306 root@192.168.0.122

192.168.0.122 >> 是我的远程局域网服务器。

第二:使用 127.0.0.1 作为 Django 连接字符串的主机。

DATABASES = {
'default': {
    'ENGINE': 'django.db.backends.mysql',
    'NAME': 'XXXX',
    'USER': 'XXX',
    'PASSWORD': 'XXXX',
    'HOST': '127.0.0.1',
    'PORT': '3306',
    'OPTION': {
        'init_command': "SET sql_mode='STRICT_TRANS_TABLES'"
    }
}

或者如果使用环境文件,请将 .env 中的 HOST 更改为 127.0.0.1。

这对我有用。

于 2021-07-05T07:07:49.780 回答