PG-1603 Make pg_basebackup work with encrypted WAL #513
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
When WAL is streamed during the backup (default mode), it comes in unencrypted. But we need keys to encrypt it. For now, we expect that the user would put
pg_tde
dir containing the1664_key
and1664_providers
into the destination directory before starting the backup. And we encrypt streamed WAL according to the internal keys. Nopg_tde
dir means no streamed WAL encryption.Why I created
TDEXLogCryptBuffer()
:stream->walmethod->ops
is an interface and there are at least four implementation of thewrite()
method which accepts a buffer as argument. I thought about usingTDEXLogSmgrInitWriteReuseKey()
+pipe
+xlog_smgr->seg_write()
, but my experiments show that it is possible for pg_basebackup to start a stream from a couple of "wal keys back", therefore reusing of the last key won't work.