mirror of
https://github.com/postgres/postgres.git
synced 2025-11-09 06:21:09 +03:00
Introduce io_max_combine_limit.
The existing io_combine_limit can be changed by users. The new io_max_combine_limit is fixed at server startup time, and functions as a silent clamp on the user setting. That in itself is probably quite useful, but the primary motivation is: aio_init.c allocates shared memory for all asynchronous IOs including some per-block data, and we didn't want to waste memory you'd never used by assuming they could be up to PG_IOV_MAX. This commit already halves the size of 'AioHandleIov' and 'AioHandleData'. A follow-up commit can now expand PG_IOV_MAX without affecting that. Since our GUC system doesn't support dependencies or cross-checks between GUCs, the user-settable one now assigns a "raw" value to io_combine_limit_guc, and the lower of io_combine_limit_guc and io_max_combine_limit is maintained in io_combine_limit. Reviewed-by: Andres Freund <andres@anarazel.de> (earlier version) Discussion: https://postgr.es/m/CA%2BhUKG%2B2T9p-%2BzM6Eeou-RAJjTML6eit1qn26f9twznX59qtCA%40mail.gmail.com
This commit is contained in:
@@ -3252,6 +3252,20 @@ struct config_int ConfigureNamesInt[] =
|
||||
NULL
|
||||
},
|
||||
|
||||
{
|
||||
{"io_max_combine_limit",
|
||||
PGC_POSTMASTER,
|
||||
RESOURCES_IO,
|
||||
gettext_noop("Server-wide limit that clamps io_combine_limit."),
|
||||
NULL,
|
||||
GUC_UNIT_BLOCKS
|
||||
},
|
||||
&io_max_combine_limit,
|
||||
DEFAULT_IO_COMBINE_LIMIT,
|
||||
1, MAX_IO_COMBINE_LIMIT,
|
||||
NULL, assign_io_max_combine_limit, NULL
|
||||
},
|
||||
|
||||
{
|
||||
{"io_combine_limit",
|
||||
PGC_USERSET,
|
||||
@@ -3263,7 +3277,7 @@ struct config_int ConfigureNamesInt[] =
|
||||
&io_combine_limit,
|
||||
DEFAULT_IO_COMBINE_LIMIT,
|
||||
1, MAX_IO_COMBINE_LIMIT,
|
||||
NULL, NULL, NULL
|
||||
NULL, assign_io_combine_limit, NULL
|
||||
},
|
||||
|
||||
{
|
||||
|
||||
@@ -200,6 +200,8 @@
|
||||
#backend_flush_after = 0 # measured in pages, 0 disables
|
||||
#effective_io_concurrency = 16 # 1-1000; 0 disables prefetching
|
||||
#maintenance_io_concurrency = 16 # 1-1000; 0 disables prefetching
|
||||
#io_max_combine_limit = 128kB # usually 1-32 blocks (depends on OS)
|
||||
# (change requires restart)
|
||||
#io_combine_limit = 128kB # usually 1-32 blocks (depends on OS)
|
||||
|
||||
#io_method = worker # worker, sync (change requires restart)
|
||||
|
||||
Reference in New Issue
Block a user