You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
postgres/src/backend/storage/ipc
Peter Eisentraut 1cd4c14116 Fixed all elog related warnings, as well as a few others. 27 years ago
..
Makefile New LDOUT makefile variable for QNX os. 27 years ago
README Postgres95 1.01 Distribution - Virgin Sources 30 years ago
ipc.c Fixed all elog related warnings, as well as a few others. 27 years ago
ipci.c XLOG (also known as WAL -:)) Bootstrap/Startup/Shutdown. 27 years ago
shmem.c XLOG (also known as WAL -:)) Bootstrap/Startup/Shutdown. 27 years ago
shmqueue.c Move some system includes into c.h, and remove duplicates. 27 years ago
sinval.c Several changes here, not very related but touching some of the same files. 27 years ago
sinvaladt.c Several changes here, not very related but touching some of the same files. 27 years ago
spin.c XLOG (also known as WAL -:)) Bootstrap/Startup/Shutdown. 27 years ago

README

$Header: /cvsroot/pgsql/src/backend/storage/ipc/README,v 1.1.1.1 1996/07/09 06:21:54 scrappy Exp $
Mon Jul 18 11:09:22 PDT 1988 W.KLAS

Cache invalidation synchronization routines:
===========================================

The cache synchronization is done using a message queue. Every
backend can register a message which then has to be read by
all backends. A message read by all backends is removed from the
queue automatically. If a message has been lost because the buffer
was full, all backends that haven't read this message will be
noticed that they have to reset their cache state. This is done
at the time when they try to read the message queue.

The message queue is implemented as a shared buffer segment. Actually,
the queue is a circle to allow fast inserting, reading (invalidate data) and
maintaining the buffer.

Access to this shared message buffer is synchronized by the lock manager.
The lock manager treats the buffer as a regular relation and sets
relation level locks (with mode = LockWait) to block backends while
another backend is writing or reading the buffer. The identifiers used
for this special 'relation' are database id = 0 and relation id = 0.

The current implementation prints regular (e)log information
when a message has been removed from the buffer because the buffer
is full, and a backend has to reset its cache state. The elog level
is NOTICE. This can be used to improve teh behavior of backends
when invalidating or reseting their cache state.