2017-07-31 53 views
0

我使用elasticsearch數據庫爲我的Django應用程序(Elasticsearch)。但每當我運行python manage.py rebuild_index我想出了以下錯誤:settings.DATABASES配置不當

Traceback (most recent call last): 
    File "manage.py", line 22, in <module> 
    execute_from_command_line(sys.argv) 
    File "/Manish/Projects/Spark/ad-tracking-django-env/lib/python2.7/site-packages/django/core/management/__init__.py", line 367, in execute_from_command_line 
    utility.execute() 
    File "/Manish/Projects/Spark/ad-tracking-django-env/lib/python2.7/site-packages/django/core/management/__init__.py", line 359, in execute 
    self.fetch_command(subcommand).run_from_argv(self.argv) 
    File "/Manish/Projects/Spark/ad-tracking-django-env/lib/python2.7/site-packages/django/core/management/base.py", line 305, in run_from_argv 
    self.execute(*args, **cmd_options) 
    File "/Manish/Projects/Spark/ad-tracking-django-env/lib/python2.7/site-packages/django/core/management/base.py", line 356, in execute 
    output = self.handle(*args, **options) 
    File "/Manish/Projects/Spark/ad-tracking-django-env/lib/python2.7/site-packages/haystack/management/commands/rebuild_index.py", line 37, in handle 
    call_command('update_index', **options) 
    File "/Manish/Projects/Spark/ad-tracking-django-env/lib/python2.7/site-packages/django/core/management/__init__.py", line 130, in call_command 
    return command.execute(*args, **defaults) 
    File "/Manish/Projects/Spark/ad-tracking-django-env/lib/python2.7/site-packages/django/core/management/base.py", line 356, in execute 
    output = self.handle(*args, **options) 
    File "/Manish/Projects/Spark/ad-tracking-django-env/lib/python2.7/site-packages/haystack/management/commands/update_index.py", line 214, in handle 
    self.update_backend(label, using) 
    File "/Manish/Projects/Spark/ad-tracking-django-env/lib/python2.7/site-packages/haystack/management/commands/update_index.py", line 240, in update_backend 
    total = qs.count() 
    File "/Manish/Projects/Spark/ad-tracking-django-env/lib/python2.7/site-packages/django/db/models/query.py", line 369, in count 
    return self.query.get_count(using=self.db) 
    File "/Manish/Projects/Spark/ad-tracking-django-env/lib/python2.7/site-packages/django/db/models/sql/query.py", line 476, in get_count 
    number = obj.get_aggregation(using, ['__count'])['__count'] 
    File "/Manish/Projects/Spark/ad-tracking-django-env/lib/python2.7/site-packages/django/db/models/sql/query.py", line 457, in get_aggregation 
    result = compiler.execute_sql(SINGLE) 
    File "/Manish/Projects/Spark/ad-tracking-django-env/lib/python2.7/site-packages/django/db/models/sql/compiler.py", line 824, in execute_sql 
    sql, params = self.as_sql() 
    File "/Manish/Projects/Spark/ad-tracking-django-env/lib/python2.7/site-packages/django/db/models/sql/compiler.py", line 374, in as_sql 
    from_, f_params = self.get_from_clause() 
    File "/Manish/Projects/Spark/ad-tracking-django-env/lib/python2.7/site-packages/django/db/models/sql/compiler.py", line 612, in get_from_clause 
    clause_sql, clause_params = self.compile(from_clause) 
    File "/Manish/Projects/Spark/ad-tracking-django-env/lib/python2.7/site-packages/django/db/models/sql/compiler.py", line 353, in compile 
    sql, params = node.as_sql(self, self.connection) 
    File "/Manish/Projects/Spark/ad-tracking-django-env/lib/python2.7/site-packages/django/db/models/sql/datastructures.py", line 146, in as_sql 
    base_sql = compiler.quote_name_unless_alias(self.table_name) 
    File "/Manish/Projects/Spark/ad-tracking-django-env/lib/python2.7/site-packages/django/db/models/sql/compiler.py", line 344, in quote_name_unless_alias 
    r = self.connection.ops.quote_name(name) 
    File "/Manish/Projects/Spark/ad-tracking-django-env/lib/python2.7/site-packages/django/db/backends/dummy/base.py", line 21, in complain 
    raise ImproperlyConfigured("settings.DATABASES is improperly configured. " 
django.core.exceptions.ImproperlyConfigured: settings.DATABASES is improperly configured. Please supply the ENGINE value. Check settings documentation for more details. 

主要錯誤是:

raise ImproperlyConfigured("settings.DATABASES is improperly configured. " 
    django.core.exceptions.ImproperlyConfigured: settings.DATABASES is improperly configured. Please supply the ENGINE value. Check settings documentation for more details. 

我也是用草堆我的搜索引擎。我對草堆連接settings.py是:

HAYSTACK_CONNECTIONS = { 
    'default': { 
     'ENGINE': 'haystack.backends.elasticsearch2_backend.Elasticsearch2SearchEngine', 
     'URL': 'http://127.0.0.1:9200/', 
     'INDEX_NAME': 'haystack', 
    }, 
} 
+0

顯示數據庫的設置發生了誤差,有 – Exprator

+0

我我不瞭解數據庫部分。我應該聲明DATABASE設置還是HAYSTACK_CONNECTIONS將扮演數據庫連接的角色?如果我必須編寫數據庫設置,應該如何編寫它以將我的django應用程序與elasticsearch連接起來? –

+0

不是乾草堆連接與數據庫不同,您需要在設置文件中聲明DATABASE設置,否則將不會運行 – Exprator

回答

1
DATABASES = { 
    'default': { 
     'ENGINE': 'django.db.backends.sqlite3', 
     'NAME': 'mydatabase', 
    } 
} 

創建一個名爲db.sqlite3文件,其中manage.py是,然後運行你正在運行什麼

+0

將不會保存所有的數據在sqlite中嗎?我還沒有理解到底發生了什麼。你能詳細解釋一下嗎?如果可能的話,請啓動「聊天」跟我 –

+0

沒有,當您使用草垛會重定向到,數據庫只是爲了使Django的正常運行 – Exprator

+0

我有一個數據庫中創建的,所以我用它'「默認」:{ 'ENGINE':'django.db.backends.postgresql_psycopg2', 'NAME':'core', 'USER':'user', 'PASSWORD':'user', 'HOST':'10.10.105.253' ' 'PORT':'」, }'我被錯誤'ValueError異常:期待屬性名:行11列10(字符274)' –

相關問題