19.10. Automatic Vacuuming
These settings control the behavior of the autovacuum feature. Refer to Section 24.1.6 for more information. Note that many of these settings can be overridden on a per-table basis; see Storage Parameters.
- autovacuum(- boolean)
- Controls whether the server should run the autovacuum launcher daemon. This is on by default; however, track_counts must also be enabled for autovacuum to work. This parameter can only be set in the - postgresql.conffile or on the server command line; however, autovacuuming can be disabled for individual tables by changing table storage parameters.- Note that even when this parameter is disabled, the system will launch autovacuum processes if necessary to shrink - pg_xactand- pg_multixact. See Section 24.1.5 for more information.
- log_autovacuum_min_duration(- integer)
- Causes each action executed by autovacuum to be logged if it ran for at least the specified amount of time. Setting this to zero logs all autovacuum actions. - -1(the default) disables logging autovacuum actions. If this value is specified without units, it is taken as milliseconds. For example, if you set this to- 250msthen all automatic vacuums and analyzes that run 250ms or longer will be logged. In addition, when this parameter is set to any value other than- -1, a message will be logged if an autovacuum action is skipped due to a conflicting lock or a concurrently dropped relation. Enabling this parameter can be helpful in tracking autovacuum activity. This parameter can only be set in the- postgresql.conffile or on the server command line; but the setting can be overridden for individual tables by changing table storage parameters.
- autovacuum_max_workers(- integer)
- Specifies the maximum number of autovacuum processes (other than the autovacuum launcher) that may be running at any one time. The default is three. This parameter can only be set at server start. 
- autovacuum_naptime(- integer)
- Specifies the minimum delay between autovacuum runs on any given database. In each round the daemon examines the database and issues - VACUUMand- ANALYZEcommands as needed for tables in that database. If this value is specified without units, it is taken as seconds. The default is one minute (- 1min). This parameter can only be set in the- postgresql.conffile or on the server command line.
- autovacuum_vacuum_threshold(- integer)
- Specifies the minimum number of updated or deleted tuples needed to trigger a - VACUUMin any one table. The default is 50 tuples. This parameter can only be set in the- postgresql.conffile or on the server command line; but the setting can be overridden for individual tables by changing table storage parameters.
- autovacuum_vacuum_insert_threshold(- integer)
- Specifies the number of inserted tuples needed to trigger a - VACUUMin any one table. The default is 1000 tuples. If -1 is specified, autovacuum will not trigger a- VACUUMoperation on any tables based on the number of inserts. This parameter can only be set in the- postgresql.conffile or on the server command line; but the setting can be overridden for individual tables by changing table storage parameters.
- autovacuum_analyze_threshold(- integer)
- Specifies the minimum number of inserted, updated or deleted tuples needed to trigger an - ANALYZEin any one table. The default is 50 tuples. This parameter can only be set in the- postgresql.conffile or on the server command line; but the setting can be overridden for individual tables by changing table storage parameters.
- autovacuum_vacuum_scale_factor(- floating point)
- Specifies a fraction of the table size to add to - autovacuum_vacuum_thresholdwhen deciding whether to trigger a- VACUUM. The default is 0.2 (20% of table size). This parameter can only be set in the- postgresql.conffile or on the server command line; but the setting can be overridden for individual tables by changing table storage parameters.
- autovacuum_vacuum_insert_scale_factor(- floating point)
- Specifies a fraction of the table size to add to - autovacuum_vacuum_insert_thresholdwhen deciding whether to trigger a- VACUUM. The default is 0.2 (20% of table size). This parameter can only be set in the- postgresql.conffile or on the server command line; but the setting can be overridden for individual tables by changing table storage parameters.
- autovacuum_analyze_scale_factor(- floating point)
- Specifies a fraction of the table size to add to - autovacuum_analyze_thresholdwhen deciding whether to trigger an- ANALYZE. The default is 0.1 (10% of table size). This parameter can only be set in the- postgresql.conffile or on the server command line; but the setting can be overridden for individual tables by changing table storage parameters.
- autovacuum_freeze_max_age(- integer 64)
- Specifies the maximum age (in transactions) that a table's - pg_class.- relfrozenxidfield can attain before a- VACUUMoperation is forced to shrink- pg_xact. Note that the system will launch autovacuum processes for this purpose even when autovacuum is otherwise disabled. The default is 10 billion.- Vacuum also allows removal of old files from the - pg_xactsubdirectory. This parameter can only be set at server start, but the setting can be reduced for individual tables by changing table storage parameters. For more information see Section 24.1.5.
- autovacuum_multixact_freeze_max_age(- integer 64)
- Specifies the maximum age (in multixacts) that a table's - pg_class.- relminmxidfield can attain before a- VACUUMoperation is forced to shrink- pg_multixact. Note that the system will launch autovacuum processes for this purpose even when autovacuum is otherwise disabled. The default is 20 billion.- This parameter can only be set at server start, but the setting can be reduced for individual tables by changing table storage parameters. For more information see Section 24.1.5.1. 
- autovacuum_vacuum_cost_delay(- floating point)
- Specifies the cost delay value that will be used in automatic - VACUUMoperations. If -1 is specified, the regular vacuum_cost_delay value will be used. If this value is specified without units, it is taken as milliseconds. The default value is 2 milliseconds. This parameter can only be set in the- postgresql.conffile or on the server command line; but the setting can be overridden for individual tables by changing table storage parameters.
- autovacuum_vacuum_cost_limit(- integer)
- Specifies the cost limit value that will be used in automatic - VACUUMoperations. If -1 is specified (which is the default), the regular vacuum_cost_limit value will be used. Note that the value is distributed proportionally among the running autovacuum workers, if there is more than one, so that the sum of the limits for each worker does not exceed the value of this variable. This parameter can only be set in the- postgresql.conffile or on the server command line; but the setting can be overridden for individual tables by changing table storage parameters.