1
0
mirror of https://github.com/pgbackrest/pgbackrest.git synced 2026-05-02 21:14:58 +02:00
Commit Graph

4757 Commits

Author SHA1 Message Date
David Steele 6904cdf5a8 Simplify log-level options in config.yaml.
These were overly verbose -- inheritance is the way to do this.
2026-01-11 21:00:39 +07:00
David Steele d76da852ee Remove unused error parameter from strIdFromZN().
This parameter was made obsolete in 85caeda4.
2026-01-11 18:42:27 +07:00
David Steele d12aa6fcda Update strIdFromZN() comment missed in 6e11d650. 2026-01-11 15:02:22 +07:00
David Steele 35505d63fd Use more generic expression to fetch container IP addresses.
The IP address has been moved in newer versions of Docker but this expression will fetch the IP address from the old or new location.
2026-01-10 19:13:55 +07:00
David Steele 85caeda4e5 Throw errors on invalid StringIds in config/parse.c.
Now that the StringIds are not stored in parse.auto.c.inc it may not be obvious if an invalid StringId is generated. By moving the encoding to after the value has been validated we can error if the StringId is invalid rather than throwing an error that the value does not exist in the allow list.
2026-01-10 15:52:06 +07:00
David Steele 5898806473 Add PARSE_RULE_VAL_STR_IDX() to simplify logic in config/parse.c.
Mostly this just makes the code cleaner but there are also a few function calls that were replaced with the macro.

Also tighten up the logic in cfgParseOptionValuePack() a bit even though is not related to this macro change.
2026-01-10 15:35:37 +07:00
David Steele 31d4aaa19f Remove generated StringIds from parse.auto.c.inc.
These StringIds use space and increase churn when new ids are added. It is easy and efficient to use strings for comparison and convert to StringId in code.
2026-01-10 15:08:05 +07:00
wolrajhti 79544f64a3 Support for S3 EKS pod identity.
Fetch credentials automatically using EKS pod identity, which removes the need for static configuration. Credentials are automatically updated before they expire to support long-running commands.
2026-01-09 15:18:28 +07:00
David Steele 91ad65537f Fix flapping common/io-tls unit test added in fbc607a4.
Since the server exits on error in this test there is no need to shut it down when the script completes. This usually worked because the message would arrive before the server had shutdown completely but sometimes it would error on a broken pipe.
2026-01-08 11:45:14 +07:00
David Steele a7e5f28511 Clarify that bundling is useful for filesystems with large block sizes. 2026-01-08 10:53:51 +07:00
Gunnar "Nick" Bluth fbc607a48b Allow configuration of TLS cipher suites.
Configuration of specific cipher suites may be required for compliance or to use preferred ciphers for security.

Cipher suites are applied to the entire process and cannot be configured on a per-connection basis, except that for object store clients (e.g. S3) verification can be disabled.
2026-01-08 09:17:17 +07:00
David Steele 5b4b20a8d7 Require TLS >= 1.2 unless verification is disabled.
TLS 1.0 and 1.1 have been deprecated since 2021 (see RFC-8996) and TLS 1.2 has been available since 2008. As such it makes sense to require TLS >= 1.2 when verification is enabled. Verification is always enabled for TLS protocol sessions within pgBackRest but can be disabled for object stores (.e.g. S3) to support self-signed certificates on internal servers.

There is a slight change in behavior when verification is disabled. In prior versions SSL 2/3 would be disabled but now they are allowed (as well as TLS 1.0/1.2). With verification disabled it doesn't seem useful to be picky about protocol versions and disabling TLS 1.0/1.1 could easily cause breakage on older TLS servers.
2026-01-07 08:22:01 +07:00
Moiz Ibrar 38f14d73b6 Support for Azure managed identities.
Fetch credentials automatically using managed identities, which removes the need for static configuration. Credentials are automatically updated before they expire to support long-running commands.
2026-01-05 18:42:11 +07:00
David Steele 67c8b3462d Fix minor formatting issue. 2026-01-05 09:34:46 +07:00
David Steele 6e11d65074 Remove prefix functionality from StringId.
In practice StringIds that could not be output as the original string were not useful. Remove this functionality to simplify the code and reclaim the bit for other purposes.
2026-01-02 12:02:48 +07:00
David Steele d269d1d9bd Move object code out of StringId module.
Functions for creating String and StringZ objects should be in their respective modules so move them there. This simplifies the dependencies for StringId and is more modular.
2026-01-02 11:16:28 +07:00
David Steele 9118571196 Move constants required for debug logging.
Moving these constants to stringStatic.h reduces the dependency on stringZ.h for low-level debug logging. This makes it possible to add new capabilities to stringZ.c.
2026-01-02 10:47:45 +07:00
David Steele 84778658ac Use JsonRead for all info JSON parsing.
After JsonRead was introduced the performance-sensitive areas of info were migrated from Variant. However, other areas were left using Variant because they were not important enough to update at that time.

Migrate remaining Variant usage to JsonRead wherever possible for consistency. Also improve memory management to avoid some cruft that would end up in the object mem context and avoid switching to the object mem context when possible.
2025-12-30 17:40:18 +07:00
David Steele d88ae74282 Fix test comment. 2025-12-29 19:40:26 +07:00
Will Morland 2398dd4d43 HTTP support for S3, GCS, and Azure.
Allow users to specify HTTP in the endpoint but default to using HTTPS in all other scenarios to preserve the existing behavior.

Extend HttpUrl with a `defaultType` parameter to support either:
- Explicitly specifying a protocol via `.type` and enforcing that protocol is used in the URL.
- Allowing protocol to be parsed from URL, but providing default via `.defaultType` if no protocol is found in the URL.

Add partial write handling in fdWrite() to support non-blocking socket operations. The write loop now handles EAGAIN errors by waiting for the file descriptor to become writable, and continues writing the remaining bytes when write() returns fewer bytes than requested. This is required for HTTP, which may use non-blocking sockets, but doesn't have built in handling like the TLS client we are using for HTTPS. Also wrap the write() call and add a shim and additional logging for easier unit testing.
2025-12-29 10:39:21 +07:00
David Steele 1afaab1c1e Removed redundant documentation variables and references. 2025-12-23 17:24:49 +07:00
David Steele fdeb46be83 Remove PDF documentation output.
PDF output is not longer used by the project. Removal will make documentation maintenance and improvements simpler.
2025-12-23 16:59:08 +07:00
Maxim Michkov e13c462908 Fix deadlock due to logging in signal handler.
Previously it was possible to achieve a deadlock in a signal handler, for example when SIGTERM (i.e. sent by `pgbackrest stop --force`) arrives when a lock used in `gmtime_r` is taken. Then the next time logging is done, it will deadlock on `gmtime_r`.

In general, most stdlib functions are not safe to call in signal handlers, only so called async-signal safe functions are. In particular, `snprintf` isn't safe since it is allowed to internally call `malloc`. The `exitSafe` function isn't safe due to extensive use of allocations. Because of this, we need to use a simpler logging format in signal handlers, one that only uses async-signal safe functions.
2025-12-22 14:43:15 +07:00
David Steele cc7b9b7271 Fix missing parameter logging in storageS3New(). 2025-12-22 14:23:08 +07:00
Stefan Fercot bf2b276dc0 Allow expiration of oldest full backup regardless of current retention.
Prior to this commit it was difficult to expire just the oldest full backup while ignoring current retention settings. The user had to manually update retention or script something to automate it. Expiring the oldest full backup is useful when disk space is running low.

Add the --oldest option to allow expiration of the oldest full backup and any dependent backups regardless of the current retention settings. Archive retention is also adjusted to expire WAL before the oldest retained full backup.
2025-12-11 20:10:32 +05:30
Joakim Hindersson 3fdb4a1ea0 Allow dots in S3 bucket names when using path-style URIs.
The reasoning in the FAQ and code about RFC-2818 is only valid when using host style URIs. According to AWS S3 bucket naming standard the allowed characters is any lowercase alphanumeric including dash and dot.

Most self hosted S3 services utilize path based URIs where dots are valid in a bucket name so this check should only apply for host based buckets. Even though its use is not recommended and path-based access is being phased out of AWS S3 it is still valid and should function for other providers.
2025-12-07 11:29:12 +05:30
David Steele 8a4df08bd2 Update Cirrus-CI FreeBSD 14 runner version. 2025-12-07 10:51:19 +05:30
Stefan Fercot 09efab039a Fix WAL segment numbering in command/expire unit test.
WAL segments were being numbered in decimal format rather than hex. This worked in the prior cases (more or less) but is not correct or flexible.
2025-11-29 11:39:01 +05:30
David Steele 38ac6387cb Improve logging of default for options with an unresolved dependency.
Options with unresolved dependencies can have an implied default specified. This makes the code a bit simpler since we don't need to check for option validity.

However, there was an edge case where if an option was specified in the config file and ultimately the dependency was not resolved then the option would not be marked as default and therefore show up in the option logging at the beginning of a command. The default value was correct so everything operated as expected but the logging was confusing.

In the case of an implied default, reinitialize the option struct so that any leftover settings will be reset.
2025-11-28 14:27:36 +05:30
David Steele 28bfa20ba3 Optimize S3/GCS/Azure chunk size for small files.
The prior code allocated the entire chunk buffer when the file was opened. However, in practice many files are smaller than the chunk buffer, especially in the main process.

Instead grow the chunk buffer as data comes in to save memory when smaller files are being processed. This adds some overhead for reallocations but modern processors do this very efficiently so it should not be significant compared to the cost of compressing, encrypting, and transferring files. Even so, the growth is fairly aggressive when the input buffers are full so only one or two reallocation are required to get to the default chunk size.
2025-11-25 17:28:20 +05:30
David Steele 86554faa70 Dynamically size S3/GCS/Azure chunks for large uploads.
Previously an S3 upload with default repo-storage-upload-chunk-size would only work for files <= 50GiB because of the limited number of chunks allowed. GCS has a smaller chunk size default so it topped out at 40GiB. Azure allows 50,000 chunks so it allowed up to 200GiB.

These are all far larger than files PostgreSQL will create but these days a data directory might also contain files created by plugins that can be much larger.

Since the eventual file size is not known in advance (due to compression) it is hard to pick an appropriate chunk size in advance. Instead, dynamically grow the chunk size over time to reach 5TiB for S3 and GCS (their upper limit). Azure has more parts so it will reach 45TiB, which is smaller than the upper limit of 190TiB, but seems sufficient for now.

The default buffer size is used for the first GiB (plus some) to provide compatibility with any clones that do not support variable block sizes. There is no evidence that this is a problem but better to be safe.

The minimum values for repo-storage-upload-chunk-size have been increased to match vendor minimums and simply the chunk size algorithm.
2025-11-22 20:32:37 +04:00
David Steele bce97d3ea8 Remove explicit max_wal_senders/wal_level configuration from user guide.
Since PostgreSQL 10 these settings have been defaulted to values required by the user guide so there is no need to explicitly set them.

PostgreSQL 9.5/9.6 are still supported by pgBackRest but are not represented in the user guide since they are EOL.
2025-11-19 10:40:02 +02:00
David Steele d83019924b Fix 32-bit CI testing.
32-bit testing was broken by 24802a08, which was attempting to fix multi-architecture builds by using docker to set the architecture.

i386 is not a special case but the prior alternate architectures did not run integration tests. This requires passing the architecture around since the integration test main process runs on the host system, which may be a different architecture.
2025-11-12 14:27:22 +02:00
David Steele c6ebfc8fae Removed unused code in test container build. 2025-11-12 11:22:08 +02:00
David Steele 0fc7e96f5a Allow process priority to be set.
Decreasing process priority makes the pgBackRest processes less likely to interfere with the normal operation of PostgreSQL.
2025-11-11 21:06:42 +02:00
David Steele 8b9a19e078 Rearrange options for clarity.
Especially for pg-* and repo-*, groups options in a way that makes them easier to maintain with headers to make them easier to find.
2025-11-11 13:24:27 +02:00
David Steele 639f27f67e Move PostgreSQL connection options to the same section.
This makes maintenance easier. Also fix the command list for db-timeout so it matches pg-database, i.e. all the commands that can connect to the database.
2025-11-11 12:29:59 +02:00
David Steele f5b51a5680 Add new defines to help with option command maintenance.
Add +inherit, +role, and -command to help with command maintenance. These allow command lists to automatically add new commands without them needing to be added manually. They should also be easier to read than long command lists.
2025-11-11 11:53:59 +02:00
David Steele 9653d444f2 Use roles to simplify option command lists.
In many cases the valid commands are based on the commands valid for roles. In these cases derive the commands from a role list rather than an explicit command list.

Not only is this notation more compact but it helps prevent new commands from being missed.

This exposed a few issues:

1) The cmd option should only be valid when a command supports the local role since it is used to execute the local process. A number of commands were included before that did not have the local role.

2) cmd-ssh should be valid for any command that allows remotes. The annotate command was missing from this list.

3) compress-level-network should be valid for any command that allows remotes. The repo-rm command was missing from this list.
2025-11-11 09:44:41 +02:00
David Steele 411c1d0a87 Cleanup pg-host options for unsupported remote restore.
Restoring to a remote pg-host is not supported but the options were a bit untidy. Many options were marked as internal but should be invalid. repo-host-type and repo-host are required to let restore know if a pg-host is configured and remain internal but the rest of the pg-host-* options are now invalid for restore.

The same applies to the archive-get and archive-push commands although these were less likely to cause confusion.

Also reverse the dependency of pg-host and pg-host-type, i.e. make pg-host-type depend on pg-host, and alter pg-host-cmd and pg-host-user to depend on pg-host-type=ssh.
2025-11-11 09:09:15 +02:00
David Steele 9be51f9bf3 Cleanup repo-host options for remote backup.
931435c0 added the ability to backup to a remote repo but did not quite get the option updates right. It worked, but a number of options were marked as internal so would not be visible to the user in command-line help.

Also reverse the dependency of repo-host and repo-host-type, i.e. make repo-host-type depend on repo-host, and alter repo-host-cmd and repo-host-user to depend on repo-host-type=ssh.
2025-11-11 08:52:36 +02:00
David Steele 7a74fd3fb9 Show internal state for commands/options in parse.auto.c.inc.
Previously internal state was not included because it does not affect how commands/options are used -- only whether they are shown in help. However, this makes it hard to know when the internal state changes because help is generated at build time and in any case is just a binary blob.

Internal state is not stored in the config structures since the macros resolve to nothing but it is handy for debugging to see when internal state has changed.
2025-11-10 20:05:42 +02:00
David Steele 40381c2fe8 Remove overly verbose command role rules.
The default rules work for most commands so use them. Exceptions for the repo option remain.
2025-11-10 19:54:05 +02:00
David Steele 2f4765c6fa Remove unused start/stop commands on repo options.
The logic defined start/stop as being valid for no roles but it is simpler to just omit them.
2025-11-10 19:34:48 +02:00
David Steele 91281b7144 Migrate document command/option description preprocessing to C.
The Perl processing of config.yaml put hard limits on the format of that file. To allow flexibility in the file format remove all Perl processing on config.yaml.

This is just the beginning of migrating the preprocessor to C but even this small bit allows the removal of a lot of Perl code.
2025-11-10 12:28:05 +02:00
David Steele 186ed610b5 Remove redundant command lists from src/build/config/config.yaml.
When not specified, the command list is generated based on all commands valid for the specified roles.
2025-11-09 13:59:20 +02:00
David Steele ff64ad688e Use get_option() for tasks supported by the new meson version.
55e9969 updated the meson version but only reverted one of the changes implemented in 0eccbc8 where the version was lowered to >= 0.45.

Use get_option() as allowed by the updated version for clearer and more robust build code.
2025-11-08 15:43:12 +02:00
David Steele 5171e8bde3 Remove support for PostgreSQL 9.5.
Per our policy to support five EOL versions of PostgreSQL, 9.5 is no longer supported by pgBackRest. Remove all logic associated with 9.5 and update the tests.

An effort was made to advance versions as much as possible in the tests while still providing coverage. Hopefully this will reduce churn when future versions expire, though it has created a bit more here.

Tests for 9.4/9.5 are left in the expire/info tests to demonstrate that these commands work with old versions present.
2025-11-07 10:01:50 +02:00
David Steele 1f2b2778ab Fix incorrect pg_control struct used for PostgreSQL 9.5.
The 9.6 pg_control struct was being used for 9.5. This was not detected by testing because the new field introduced for 9.6 fit into an alignment hole in the 9.5 struct so the size of the struct and offset of all other members did not change. Since the new member was not used there was no impact on functionality.

9.5 is being removed in the next release so the only reason to fix this is to make the diff for that change more sensible, and to document that this happened.
2025-11-06 10:21:23 +02:00
David Steele 1c976ded91 Remove versioning from static types used by versioned PostgreSQL types.
Some of these types were versioned at one time. Others were not but it seemed better to version all of them for consistency. In fact this just creates churn when PostgreSQL versions are expired.

Also move the uint64 type to version.vendor.h since it is only used by versioned types.
2025-11-05 23:18:29 +02:00