发布于2025-01-02 16:55 阅读(155) 评论(0) 点赞(9) 收藏(1)
I have an aplication with two containers, one of then has my database. When i try run the alembic command alembic revision --autogenerate -m "create cases table"
to update migrations i'm getting the following error:
sqlalchemy.exc.OperationalError: (psycopg.OperationalError) [Errno -3] Temporary failure in name resolution
(Background on this error at: https://sqlalche.me/e/20/e3q8)
In the file alembic.ini the variable sqlalchemy.url is configured to get the database url through environment variable.
file env.py
config.set_main_option('sqlalchemy.url', Settings().DATABASE_URL)
file .env
DATABASE_URL=postgresql+psycopg://app_user:app_password@giatros_db:5432/app_db
POSTGRES_USER=app_user
POSTGRES_DB=app_db
POSTGRES_PASSWORD=app_password
I need understand why is this error occuring and help to find a solution.
You might be running the alembic command from a local terminal.
In the env file, it is mentioned that the database is available at giatros_db
. But when running locally, giatros_db
is not resolved.
This can be fixed by:
overriding the DATABASE_URL
before running the alembic command:
export DATABASE_URL="postgresql+psycopg://app_user:app_password@localhost:5432/app_db"
alembic revision --autogenerate -m "create cases table"
or override for the command
DATABASE_URL="postgresql+psycopg://app_user:app_password@localhost:5432/app_db" alembic revision --autogenerate -m "create cases table"
running the alembic command inside the container
docker exec -it <container_name_or_id> alembic revision --autogenerate -m "create cases table"
Notice that the server name in the DATABASE_URL
has been changed from giatros_db
to localhost
.
作者:黑洞官方问答小能手
链接:https://www.pythonheidong.com/blog/article/2046697/313457a01b02d461486a/
来源:python黑洞网
任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任
昵称:
评论内容:(最多支持255个字符)
---无人问津也好,技不如人也罢,你都要试着安静下来,去做自己该做的事,而不是让内心的烦躁、焦虑,坏掉你本来就不多的热情和定力
Copyright © 2018-2021 python黑洞网 All Rights Reserved 版权所有,并保留所有权利。 京ICP备18063182号-1
投诉与举报,广告合作请联系vgs_info@163.com或QQ3083709327
免责声明:网站文章均由用户上传,仅供读者学习交流使用,禁止用做商业用途。若文章涉及色情,反动,侵权等违法信息,请向我们举报,一经核实我们会立即删除!