Hi,

Setting io_min_workers to a value greater than io_max_workers is
silently accepted, but the minimum has no effect and the worker pool
never grows past io_max_workers. This can confuse users who expect at
least io_min_workers workers to always be running.

Compare with autovacuum which properly warns:

    WARNING:  "autovacuum_max_workers" (3) should be less than or equal
    to "autovacuum_worker_slots" (1)
    DETAIL:  The server will only start up to "autovacuum_worker_slots" (1)
    autovacuum workers at a given time.

The attached patch adds check_io_worker_gucs() in
storage/aio/method_worker.c that emits a WARNING similar to what
autovacuum does for autovacuum_worker_slots vs autovacuum_max_workers:

    WARNING:  "io_min_workers" (5) should be less than or equal to
              "io_max_workers" (3)
    DETAIL:  The I/O worker pool will not exceed "io_max_workers" (3)
             workers.

The check runs in IO worker 0 at startup and after each configuration
reload.

Thanks,
Baji Shaik

Attachment: 0001-Warn-when-io_min_workers-exceeds-io_max_workers.patch
Description: Binary data

Reply via email to