-
Notifications
You must be signed in to change notification settings - Fork 14.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
sqlite3.OperationalError: no such table: dag #15965
Comments
The problem is that you are using sqlite database. Sqlite works in different way than postgres/mysql. Instead of having a server where different containers connect to, sqlites writes local file where the database is kept. Unless you create a shared volume which is mounted in all the containers, the database initialization you do in in "init" container is gone at the moment the container finishes. In your case, when webserver or scheduler start - each of them have their own new, fresh, non-initialized sqlite database and it is not going to work, because all of them should share a single database. There are two ways you can approach it:
Please let me know what worked for you and I will close the issue then. |
I will close it for now. let me know if the issue is not solved, then I re-open it. |
Hi @potiuk , Thank you so much for your assistance. Regarding your suggestions, I would prefer to go with number 2, since it's the most standard and requires less intervention - and less place to mess up. However, I am using Airflow's original image (slightly modified for testing, which includes a common network to debug possible communication issues between services), in fact, here it is: Which makes it even stranger for the message to appear. In fact, the alchemy connection and result backend are hardcoded with a postgres connection string, so the sqlite error becomes even odder. |
@potiuk can you re-open the issue? |
Not really. The docker compose.yaml ONLY supports Postgres. It does not support sqlite. You can read more about why it is just a quick start and example and not anything that is customizable and supposed to work in various combinations here: #16041 . Also there is an issue about adding more examples (maybe one including sqlite as well in #16031 ) - so you can comment in that issue and maybe even you could contribute a docker compose example with working SQLite if you would like to (similarly as one user who volunteered to contribute LocalExecutor example). |
I understand, but I'm not trying to use it with SQL Lite. I am using the default docker image, so shouldn't it automatically use the Postgres version? There is nothing in my docker-compose that references SQL Lite. |
Well this is at least what your log says: Did you run the "orignal" docker-compose and original image before and after your modifications to see if it's your modification that causes it? I think this is the easiest way to diagnose it (and if you can send what exactly modifications you made and where (diff's ? ) that could help. |
Problem fixed. I downed the docker-compose deleting the volume and rebooted with the official image. Seems to be running smoothly. Thank you for your help. |
We had race condition, but I fixed the problem, so we are safe now. #16180 |
Apache Airflow version: 2.0.2
Environment:
Cloud provider or hardware configuration:
OS (e.g. from /etc/os-release): Ubuntu 20.04.2 LTS
First of all, I apologize for opening a new issue, however, and unfortunately, my previous issue was incorrectly closed since another user responded the problem was solved - which was not.
My webserver was failing to start and would boot recurrently with a series of cryptic errors. @mik-laj then suggested I increase the log verbosity via logging_level option in the [logging] section. This did indeed clarify the problem, but I have to say, its even stranger than before:
To clarify:
In summary, the problem seems to be the 'dag' table not being found, as evidenced by this recurrent piece of log error:
The text was updated successfully, but these errors were encountered: