Re: WALWriteLock

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Wed, Jul 7, 2021 at 4:14 PM Vijaykumar Jain <vijaykumarjain.github@xxxxxxxxx> wrote:


On Thu, Jul 8, 2021, 1:22 AM Jeff Janes <jeff.janes@xxxxxxxxx> wrote:
On Tue, Jul 6, 2021 at 10:14 AM Yambu <hyambu@xxxxxxxxx> wrote:
Hello

I'm seeing a lot of WALWriteLocks , is this a bad sign , what might cause this?

Are you having a performance problem you are trying to track down?  If so, this probably indicates the cause.  If not, then it is probably not a bad sign.

The likely cause is that multiple sessions are trying to COMMIT at the same time, and are blocking on the slow fsync of the WAL data.  One process will block on WALSync, all the ones queued up behind it will block on WALWrite.

Is this reproducible ? I mean I have seen multiple ppl raising a similar issue but I could not really reproduce on my laptop, tried with slow disk, introducing random latency etc. I even tried running gdb on a few processes and trying to force into acquire a walwrite lock but not release it etc but I guess I was not doing it correctly.

It is easy to reproduce if you have WAL on a slow disk, but you need high concurrency to do it.  This for example should show it nicely:

pgbench -i -s20   ## set it up
pgbench -T600 -c10 -j10  ## run the test

If you initialize with the default scale of 1, then you won't get enough concurrency to show the problem, as all process will try to update the same row in pgbench_branches, which means only one process will commit at a time, with the rest blocking on the row lock, rather than on the WAL.

If the db is slowed down due to high concurrent usage trying to commit at same time, how do we arrive at a baseline of how much a server can handle before it starts tripping.

 The above benchmark should work for that, too.

Cheers,

Jeff

[Index of Archives]     [KVM ARM]     [KVM ia64]     [KVM ppc]     [Virtualization Tools]     [Spice Development]     [Libvirt]     [Libvirt Users]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite Questions]     [Linux Kernel]     [Linux SCSI]     [XFree86]

  Powered by Linux