Commit 5035701e authored by Tom Lane's avatar Tom Lane

Improve generation algorithm for database system identifier.

As noted some time ago, the original coding had a typo ("|" for "^")
that made the result less unique than intended.  Even the intended
behavior is obsolete since it was based on wanting to produce a
usable value even if we didn't have int64 arithmetic --- a limitation
we stopped supporting years ago.  Instead, let's redefine the system
identifier as tv_sec in the upper 32 bits (same as before), tv_usec
in the next 20 bits, and the low 12 bits of getpid() in the remaining
bits.  This is still hardly guaranteed-universally-unique, but it's
noticeably better than before.  Per my proposal at
<29019.1374535940@sss.pgh.pa.us>
parent 528c454b
...@@ -4889,15 +4889,16 @@ BootStrapXLOG(void) ...@@ -4889,15 +4889,16 @@ BootStrapXLOG(void)
* field, as being about as unique as we can easily get. (Think not to * field, as being about as unique as we can easily get. (Think not to
* use random(), since it hasn't been seeded and there's no portable way * use random(), since it hasn't been seeded and there's no portable way
* to seed it other than the system clock value...) The upper half of the * to seed it other than the system clock value...) The upper half of the
* uint64 value is just the tv_sec part, while the lower half is the XOR * uint64 value is just the tv_sec part, while the lower half contains the
* of tv_sec and tv_usec. This is to ensure that we don't lose uniqueness * tv_usec part (which must fit in 20 bits), plus 12 bits from our current
* unnecessarily if "uint64" is really only 32 bits wide. A person * PID for a little extra uniqueness. A person knowing this encoding can
* knowing this encoding can determine the initialization time of the * determine the initialization time of the installation, which could
* installation, which could perhaps be useful sometimes. * perhaps be useful sometimes.
*/ */
gettimeofday(&tv, NULL); gettimeofday(&tv, NULL);
sysidentifier = ((uint64) tv.tv_sec) << 32; sysidentifier = ((uint64) tv.tv_sec) << 32;
sysidentifier |= (uint32) (tv.tv_sec | tv.tv_usec); sysidentifier |= ((uint64) tv.tv_usec) << 12;
sysidentifier |= getpid() & 0xFFF;
/* First timeline ID is always 1 */ /* First timeline ID is always 1 */
ThisTimeLineID = 1; ThisTimeLineID = 1;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment