Skip to content
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

sql: fill out pg_advisory_lock stubs #13546

Open
jordanlewis opened this issue Feb 12, 2017 · 25 comments
Open

sql: fill out pg_advisory_lock stubs #13546

jordanlewis opened this issue Feb 12, 2017 · 25 comments
Labels
A-sql-pgcompat Semantic compatibility with PostgreSQL A-tools-prisma C-enhancement Solution expected to add code/behavior + preserve backward-compat (pg compat issues are exception) T-sql-foundations SQL Foundations Team (formerly SQL Schema + SQL Sessions)

Comments

@jordanlewis
Copy link
Member

jordanlewis commented Feb 12, 2017

As @bdarnell points out in #13429,

it seems bad to lie about locking like this. Even if ActiveRecord is (currently) OK with us stubbing out this lock, implementing this function in a silently broken way could cause problems for other frameworks in the future.

We should provide an actual implementation of these builtins. I suppose it won't be too difficult to implement by writing some lock keys in a special system range.

Also Drupal uses this see #22211.

Epic CRDB-12077

Jira issue: CRDB-6112

@cuongdo
Copy link
Contributor

cuongdo commented Feb 16, 2017

should this be closed?

@jordanlewis
Copy link
Member Author

No - we have no-op stubs for these functions, but as Ben points out, we probably shouldn't just pretend that they work correctly.

@cuongdo
Copy link
Contributor

cuongdo commented Apr 4, 2017

@jordanlewis does this need to be fixed for 1.0?

@jordanlewis
Copy link
Member Author

No, I don't think so.

@jordanlewis jordanlewis modified the milestones: Later, 1.0 Apr 4, 2017
@andreimatei
Copy link
Contributor

I think it's unlikely we'll ever implement the pg_advisory_lock functions because I don't think we can provide their semantics - locks tied to sessions, blocking semantics - in a distributed system such as ours. When do you release a lock when the node of the session that acquired it dies? The best you can do is lease semantics, which is not what these functions want.
A number of people have requested this; I think we should close this issue and provide an FAQ instead explaining why we don't support it.
cc @jseldess, @bdarnell

@jseldess
Copy link
Contributor

An FAQ sgtm, pending @bdarnell's response.

@jordanlewis
Copy link
Member Author

@andreimatei I'm not convinced we couldn't provide a close-enough approximation. We don't need perfect blocking semantics (polling would be fine), and it's not totally clear to me whether advisory locks need to be completely robust in the face of node failure. Perhaps we could use a (session id, node id, lock id) triple as the lock id and lazily invalidate locks if a node id corresponds to one that's been detected as down? I'm not familiar with how dead node detection works so perhaps this is misguided.

@andreimatei
Copy link
Contributor

But what about partitioned nodes? How do you tell a client that its lock is gone when the node it was talking to is partitioned away from... the quorum of the locks table?

@bdarnell
Copy link
Contributor

I think we have enough flexibility in the semantics that we can implement something that will work.

pg_advisory_xact_lock would be easier than pg_advisory_lock, I think, since we could be sure to push the transaction when we're breaking its lock. But it seems that the session-scoped variants are more commonly requested/used.

How do you tell a client that its lock is gone when the node it was talking to is partitioned away from... the quorum of the locks table?

The same way postgres does - we don't. In the event of a partition you're not guaranteed to be notified that you've lost your lock before someone else gets it.

@andreimatei
Copy link
Contributor

How do you tell a client that its lock is gone when the node it was talking to is partitioned away from... the quorum of the locks table?

The same way postgres does - we don't. In the event of a partition you're not guaranteed to be notified that you've lost your lock before someone else gets it.

What do you mean by "the same way postgres does"? How does a single-node Postgres have the same issue? If the client is partitioned away from the server, and the session loses the lock, I assume you can't do anything with that session anymore (probably because some TCP connection timed out somewhere). So you may not be notified of anything necessarily, but at least you won't be able to commit stuff while you believe you have the lock.

Anyway, I was thinking that we could also abruptly close the client connection when we fail to heartbeat some session lease...

@bdarnell
Copy link
Contributor

You can't do anything else on that session, and maybe that's enough. But I've seen people do all kinds of crazy things with the advisory locks, using them to control stuff done outside the session (I think all of these schemes are basically unsound). But my point is that since these locks are used to govern things that are essentially non-transactional like DDL statements (because regular transactions do their own locking and don't need another layer of artificial locks), and the lock may be broken by node/network failure, you still have to account for various kinds of inconsistencies. These locks cannot be used to protect invariants in the way that regular mutexes are.

@knz knz added C-enhancement Solution expected to add code/behavior + preserve backward-compat (pg compat issues are exception) A-sql-pgcompat Semantic compatibility with PostgreSQL labels May 5, 2018
@petermattis petermattis removed this from the Later milestone Oct 5, 2018
@asubiotto
Copy link
Contributor

@ajwerner can this be closed?

@ajwerner
Copy link
Contributor

ajwerner commented Apr 2, 2020

@ajwerner can this be closed?

No, we didn't do anything here. We prototyped something during the hackathon but it was far from something we'd merge.

@sandstrom
Copy link

Here is another popular Rails ActiveJob (async job) adapter using Advisory Locks:
/~https://github.com/bensheldon/good_job

@itmecho
Copy link

itmecho commented Aug 9, 2021

sqlx rust library also uses pg_advisory_lock(): /~https://github.com/launchbadge/sqlx/blob/f0d0dce8e25c40dffd1431776b6a38510a70bde0/sqlx-core/src/postgres/migrate.rs#L184

@nrueckmann
Copy link

I stumbled about this issue as well. May we at least document missing features like this in https://www.cockroachlabs.com/docs/stable/postgresql-compatibility.html?

@DXist
Copy link

DXist commented Jul 27, 2022

Lease pattern is an alternative to locks in distributed systems world.

Is it possible to expose application level leases in CockroachDB specific SQL dialect?

@sbward
Copy link

sbward commented Aug 20, 2022

Please implement this soon 😄

@abonander
Copy link

How are migration tools supposed to prevent multiple instances from trying to run migrations at the same time? If you have multiple instances of a high-availability application with embedded migrations coming online at the same time, they're all going to see that the database needs to be migrated and attempt to apply migrations. If the migrations themselves aren't written with this scenario in mind, they may fail or cause data loss.

@DXist
Copy link

DXist commented Aug 23, 2022

@abonander , I've personally decided not to run migrations from application servers (though they could validate if already applied migrations are valid during startup).

I decided to run migrations in a dedicated db manager service that runs at the beginning of deployment process. It runs queries from a db user that can change database schema. Application services run from another user that can change data but not the schema. So this approach gives improved security.

@AaronFriel
Copy link

Hey folks, would appreciate your advice on an infrastructure as code issue. I'm looking into this bug report on pulumi-postgresql:

That user reports an error when creating multiple grants in Postgres via Pulumi with an error like so:

error: could not execute revoke query: pq: tuple concurrently updated

This was supposedly fixed upstream of our bridged provider in this PR, adding pg_advisory_locks to limit concurrency:

However, that reportedly breaks compatibility with CockroachDB:

That chain led me here, and I think what would help us unblock this issue with managing role grants in IaC would be advice for the repository owner (@cyrilgdn).

I know my way around a SQL query and some Postgres internals, but I don't know the right answer here to address grants.

I'd love to unblock upgrading our Postgres provider and ensure our users have a great experience using it on Cockroach. Can you lend us some advice?

yuzefovich added a commit to cockroachdb/docs that referenced this issue Dec 14, 2023
We defined some builtins around pg_advisory locks, but they are no-ops,
and some functions are not even defined. This commit adds this
limitation to unsupported postgres features.

See cockroachdb/cockroach#13546.
yuzefovich added a commit to cockroachdb/docs that referenced this issue Dec 14, 2023
We defined some builtins around pg_advisory locks, but they are no-ops,
and some functions are not even defined. This commit adds this
limitation to unsupported postgres features.

See cockroachdb/cockroach#13546.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
A-sql-pgcompat Semantic compatibility with PostgreSQL A-tools-prisma C-enhancement Solution expected to add code/behavior + preserve backward-compat (pg compat issues are exception) T-sql-foundations SQL Foundations Team (formerly SQL Schema + SQL Sessions)
Projects
None yet
Development

No branches or pull requests