postgresql锁

postgresql锁

postgresql中根据不同的对象,不同使用场景,使用三种不同的锁,spinLock,LWLock,Lock

spinLock:自旋锁,是并发场景下,保护共享资源的有一种机制。实现的成本最低,一般是使用基于硬件的TAS(test-and-set)操作。

SpinLock不能用于需要长久持有锁的逻辑,在postgresql中,spinlock主要用于对于临界变量的并发访问控制,所保护的临界区通常是简单的赋值语句来,读取语句等等。

特点:

  • 申请锁的进程一直在尝试能否加锁成功,只有等到持有锁的线程释放锁之后才可以获取
  • 只有独占一种模式
  • 在等待锁的过程中进程并不会切入内核态进行sleep,而是一直忙等待,因此user态会一直使用CPU

1.CPU指令集TAS方式
2.使用semaphore实现

LWLock(Lightweight Lock):轻量级锁,这个轻量是相对第三种lock而言的。基于spinLock实现,除了独占模式,还有共享模式和special mode。

主要是以互斥访问的方式用来保护内存数据结构,比如Clog buffer(事务提交状态缓存)、Shared buffers(数据页缓存)、wal buffer(wal缓存)等等。

Lock:重量级锁,持有时间可以很长,等锁通过epoll实现
使用场景:对所有数据库对象的操作,例如表的增删查改

你可能感兴趣的:(postgresql,mysql,linux,postgresql)