-
Notifications
You must be signed in to change notification settings - Fork 24
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
Error: migrations table is already locked #252
Comments
I cleaned this up in a somewhat destructive manner.
It seems using bun as the ORM backend to lndhub it should be trivial to scale. Does anyone know what that would take so this wouldn't happen. |
We are also running lndhub.go in Kubernetes (managed k8s + managed Postgres db from Digital Ocean). Like you, we're using a single replica with the RollingUpdate strategy, but we are not experiencing this issue. I can see this being a possible issue in the hypothetical scenario where you would run multiple replicas, but you shouldn't do this anyway: we're using a GRPC stream inside LNDhub.go to update settled invoices so running multiple copies results in invoice amounts being credited more than once. In the future we might support a different kind of update mechanism (I'm thinking about a GRPC push instead of pull), so LNDhub.go can be scaled up trivially. Can you recreate this issue? If you delete the lndhub pod, does it get into this state again? |
Sadly after changing the deployment strategy to recreate I ran into this again :( {"level":"fatal","time":"2023-01-02T14:16:45Z","message":"Error migrating database: migrate: migrations table is already locked (ERROR: duplicate key value violates unique constraint \"bun_migration_locks_table_name_key\" (SQLSTATE=23505))"} I decided to hold off trying to clean it until there was some light shed here. Thanks for the GRPC Push/Pull info! This migration error has a slight chance of coming when I was in the process of changing from recreate to rollingUpdate but I find it unlikely. You can see my configuration here: |
Interesting :) What does the initContainer "ghcr.io/onedr0p/postgres-initdb" do exactly? |
It simply instances the database and user if it's non-existent https://github.com/onedr0p/containers/blob/main/apps/postgres-initdb/entrypoint.sh I have just removed my stale lock:
|
Hello 👋🏼
I run my lndhub.go deployment in Kubernetes with a RollingUpdate strategy with 1 replica. This appears to have a ill effect possibly.
Does anyone know how I can manually clean this up?
The text was updated successfully, but these errors were encountered: