2017-09-05 3 views
0

Projekt structue (nur Verzeichnis mit DB-Migrationen):Warum habe ich Probleme mit alembic Migrationen

--db_manage: 
    alembic.ini 
    --alembic: 
    env.py 
    script.py.mako 
    README 
    --versions: 
     #migration files 

Wenn ich versuche Befehl auszuführen: python db_manage/alembic/env.py, ich habe Antwort wie:

Traceback (most recent call last): 
    File "db_manage/alembic/env.py", line 8, in <module> 
    config = context.config 
AttributeError: module 'alembic.context' has no attribute 'config' 

In In welchem ​​Fall habe ich dieses Problem?
P.S.
Datei alembic.ini:

# A generic, single database configuration. 

[alembic] 
# path to migration scripts 
script_location = alembic 

# template used to generate migration files 
# file_template = %%(rev)s_%%(slug)s 

# max length of characters to apply to the 
# "slug" field 
#truncate_slug_length = 40 

# set to 'true' to run the environment during 
# the 'revision' command, regardless of autogenerate 
# revision_environment = false 

# set to 'true' to allow .pyc and .pyo files without 
# a source .py file to be detected as revisions in the 
# versions/ directory 
# sourceless = false 

# version location specification; this defaults 
# to numus/versions. When using multiple version 
# directories, initial revisions must be specified with --version-path 
# version_locations = %(here)s/bar %(here)s/bat numus/versions 

# the output encoding used when revision files 
# are written from script.py.mako 
# output_encoding = utf-8 

sqlalchemy.url = postgresql://test:[email protected]/test 


# Logging configuration 
[loggers] 
keys = root,sqlalchemy,alembic 

[handlers] 
keys = console 

[formatters] 
keys = generic 

[logger_root] 
level = WARN 
handlers = console 
qualname = 

[logger_sqlalchemy] 
level = WARN 
handlers = 
qualname = sqlalchemy.engine 

[logger_alembic] 
level = INFO 
handlers = 
qualname = alembic 

[handler_console] 
class = StreamHandler 
args = (sys.stderr,) 
level = NOTSET 
formatter = generic 

[formatter_generic] 
format = %(levelname)-5.5s [%(name)s] %(message)s 
datefmt = %H:%M:%S 

Datei env.py:

from __future__ import with_statement 
from alembic import context 
from sqlalchemy import engine_from_config, pool 
from logging.config import fileConfig 

# this is the Alembic Config object, which provides 
# access to the values within the .ini file in use. 
config = context.config 

# Interpret the config file for Python logging. 
# This line sets up loggers basically. 
fileConfig(config.config_file_name) 

# add your model's MetaData object here 
# for 'autogenerate' support 
# from myapp import mymodel 
# target_metadata = mymodel.Base.metadata 
target_metadata = None 

# other values from the config, defined by the needs of env.py, 
# can be acquired: 
# my_important_option = config.get_main_option("my_important_option") 
# ... etc. 


def run_migrations_offline(): 
    """Run migrations in 'offline' mode. 

    This configures the context with just a URL 
    and not an Engine, though an Engine is acceptable 
    here as well. By skipping the Engine creation 
    we don't even need a DBAPI to be available. 

    Calls to context.execute() here emit the given string to the 
    script output. 

    """ 
    url = config.get_main_option("sqlalchemy.url") 
    context.configure(
     url=url, target_metadata=target_metadata, literal_binds=True) 

    with context.begin_transaction(): 
     context.run_migrations() 


def run_migrations_online(): 
    """Run migrations in 'online' mode. 

    In this scenario we need to create an Engine 
    and associate a connection with the context. 

    """ 
    connectable = engine_from_config(
     config.get_section(config.config_ini_section), 
     prefix='sqlalchemy.', 
     poolclass=pool.NullPool) 

    with connectable.connect() as connection: 
     context.configure(
      connection=connection, 
      target_metadata=target_metadata 
     ) 

     with context.begin_transaction(): 
      context.run_migrations() 

if context.is_offline_mode(): 
    run_migrations_offline() 
else: 
    run_migrations_online() 
+0

'Python db_manage/alembic/env.py --autogenerate' – Mekicha

+0

@Mekicha nichts geändert, – Klimenkomud

+0

gleiche Ausgabe Es scheint würden Sie den Befehl aus einem anderen Verzeichnis laufen lassen als dort, wo Ihre': Zum Beispiel alembic.ini' befindet sich. Versuchen Sie es explizit mit '-c' oder' --config' zu übergeben, wie in 'alembic --config db_manage/alembic.ini ...'. Nicht sicher, ob dies die Ursache ist, aber einen Versuch wert. –

Antwort

1

Es gibt zwei Dinge falsch in der Art und Weise Sie versuchen, das Migrations-Tool aufzurufen. Zuerst sollten Sie das alembic Skript verwenden, anstatt zu versuchen, das env.py direkt auszuführen. Von den tutorial:

env.py - Dies ist ein Python-Skript, das , wenn das alembic Migrations-Tool ausgeführt wird, wird aufgerufen. Zumindest enthält es Anweisungen zum Konfigurieren und Generieren einer SQLAlchemy-Engine, zum Herstellen einer Verbindung von dieser Engine zu einer Transaktion und zum anschließenden Aufrufen der Migrations-Engine unter Verwendung der Verbindung als Quelle für die Datenbankkonnektivität.

Zweitens, obwohl Sie halten Ihre alembic.ini wo auch immer, das Standardverhalten im aktuellen Verzeichnis suchen ist:

Alembic eine Datei alembic.ini in das aktuelle Verzeichnis platziert. Dies ist eine Datei, nach der das Skript alembic sucht, wenn es aufgerufen wird. Diese Datei kann überall sein, entweder im gleichen Verzeichnis, aus dem das alembic Skript wird normalerweise aufgerufen werden, oder wenn sie in einem anderen Verzeichnis, kann mithilfe die --config Option zum alembic Läufer angegeben werden.

Also, wenn es woanders stattfindet, müssen Sie über den Standort alembic anweisen, die -c, oder --config, Schalter. Versuchen

alembic --config db_manage/alembic.ini 
+0

Es hilft mir sehr, aber jetzt habe ich ein neues Problem: meine Anmeldeinformationen sind falsch, wenn ich versuche, "Alembic Upgrade-Kopf" laufen zu lassen, sagen Sie mir, dass mein DB-Passwort falsch ist. An welcher Stelle kann ich es ändern? P.S. Sorry für blöde Frage, ich bin neu bei Python und versuche, ein bestehendes Projekt einzurichten. – Klimenkomud

+0

Die 'sqlalchemy.URL in der 'alembic.ini' ist der Ort, um damit umzugehen. Überprüfen Sie auch, ob Ihre Postgresql-Konfiguration die erforderlichen Authentifizierungsmethoden in der ['pg_hba.conf'] (https://www.postgresql.org/docs/current/static/auth-pg-hba-conf.html), falls erforderlich, zulässt Sein. –

+0

Ja, finde es, vielen Dank! Alles funktioniert – Klimenkomud