Обсуждение: pgsql/src/backend/access/transam (xact.c)

Поиск
Список
Период
Сортировка

pgsql/src/backend/access/transam (xact.c)

От
tgl@postgresql.org
Дата:
  Date: Thursday, December 21, 2000 @ 19:51:53
Author: tgl

Update of /home/projects/pgsql/cvsroot/pgsql/src/backend/access/transam
     from hub.org:/home/projects/pgsql/tmp/cvs-serv58115/src/backend/access/transam

Modified Files:
    xact.c

-----------------------------  Log Message  -----------------------------

Revise lock manager to support "session level" locks as well as "transaction
level" locks.  A session lock is not released at transaction commit (but it
is released on transaction abort, to ensure recovery after an elog(ERROR)).
In VACUUM, use a session lock to protect the master table while vacuuming a
TOAST table, so that the TOAST table can be done in an independent
transaction.

I also took this opportunity to do some cleanup and renaming in the lock
code.  The previously noted bug in ProcLockWakeup, that it couldn't wake up
any waiters beyond the first non-wakeable waiter, is now fixed.  Also found
a previously unknown bug of the same kind (failure to scan all members of
a lock queue in some cases) in DeadLockCheck.  This might have led to failure
to detect a deadlock condition, resulting in indefinite waits, but it's
difficult to characterize the conditions required to trigger a failure.


Re: pgsql/src/backend/access/transam (xact.c)

От
Bruce Momjian
Дата:
> I also took this opportunity to do some cleanup and renaming in the lock
> code.  The previously noted bug in ProcLockWakeup, that it couldn't wake up

The lock names were terrible.  I renamed some of them, but it clearly
needed more work.

--
  Bruce Momjian                        |  http://candle.pha.pa.us
  pgman@candle.pha.pa.us               |  (610) 853-3000
  +  If your life is a hard drive,     |  830 Blythe Avenue
  +  Christ can be your backup.        |  Drexel Hill, Pennsylvania 19026