I want to create an umbrella app with the following apps:
router: routes incoming requests to web or web_app
web: serves a REST api
web_admin: serves a REST api, but only for admin
repo: has an ecto repo, shared by web and web_admin
The idea is that both web and web_admin will use the repo app (that actually has an ecto repo) to access the database. Also, with time, more and more apps will be added to the umbrella.
I already configured the :ecto_repos in the config.exs for both web and web_admin, and the application is running.
My goal is to setup migrations inside the projects, not int the repo project.
However, when I try to create an ecto migration from web or web_admin apps, the migration is being created inside the repo app, not the original app. If I move the the priv/ folder from repo to the original application and then run mix ecto.migrate, ecto complains that the project doesn’t have any migrations.
So, now I have some questions:
Is this the expected behaviour? Can I configure it to do something different?
Should each app have its own repo?
If each app had a repo, can I at least share the connection pool and configs?
I have a similar setup, the only solution I found so far, was to create an empty priv/repo/migrations directory inside the repo app, just to disable the warning…
@webdeb I think I’m missing something about the setup here; I don’t understand why the two API apps would need different migrations if they’re sharing a single repo and database.
The apps are sharing the repo, yes… but they are serving different purposes. The Repo is just the DB-Connection. It’s not only the APIs, but imagine you are building an application for Chat only. So it maybe makes sense to put the migrations for the Chat there (Conversation, Message… etc.).
It doesn’t make sense to have migrations on each other app, migrations are tightly coupled to the DB schema (do not confuse with Ecto schemas), so they should be located where the Repo is (the repo app in this specific case).
If you need separate services (think microservices) then you should have different repos, migrations and DBs for each app.
I believe that 2 different apps declaring the BD shema is an error, you should handle all of that inside the app with the Ecto (and ecto_sql in this case) dependency.
Then from the other apps you can just consume your DB service. Other apps should not know about the implementation details behind it.