Skip to content

Commit

Permalink
Lock principal keys in RAM
Browse files Browse the repository at this point in the history
We just lock the hash table entry. Although it will lock the whole mem page we ok with that potential waste. The number of principal keys should be less than internal and allocated in the shared memory once for all backends (unlike internal keys in the TopMemoryContext of every backend). Plus hash table (via dsa) allocates in 4kb pages and hopefully, principal keys end up compactly placed.
  • Loading branch information
dAdAbird committed Sep 13, 2024
1 parent b62b165 commit 9b3dfca
Showing 1 changed file with 4 additions and 0 deletions.
4 changes: 4 additions & 0 deletions src/catalog/tde_principal_key.c
Original file line number Diff line number Diff line change
Expand Up @@ -662,6 +662,10 @@ push_principal_key_to_cache(TDEPrincipalKey *principalKey)
if (!found)
memcpy(cacheEntry, principalKey, sizeof(TDEPrincipalKey));
dshash_release_lock(get_principal_key_Hash(), cacheEntry);

/* we don't want principal keys to end up paged to the swap */
if (mlock(cacheEntry, sizeof(TDEPrincipalKey)) == -1)
elog(ERROR, "could not mlock principal key cache entry: %m");
}

/*
Expand Down

0 comments on commit 9b3dfca

Please sign in to comment.