Chapter 23. Routine Database Maintenance Tasks

Table of Contents

23.1. Routine Vacuuming
23.1.1. Vacuuming Basics
23.1.2. Recovering Disk Space
23.1.3. Updating Planner Statistics
23.1.4. Updating the Visibility Map
23.1.5. Preventing Transaction ID Wraparound Failures
23.1.6. The Autovacuum Daemon
23.2. Routine Reindexing
23.3. Log File Maintenance

LightDB, like any database software, requires that certain tasks be performed regularly to achieve optimum performance. The tasks discussed here are required, but they are repetitive in nature and can easily be automated using standard tools such as cron scripts. It is the database administrator's responsibility to set up appropriate scripts, and to check that they execute successfully.

One obvious maintenance task is the creation of backup copies of the data on a regular schedule. Without a recent backup, you have no chance of recovery after a catastrophe (disk failure, fire, mistakenly dropping a critical table, etc.). The backup and recovery mechanisms available in LightDB are discussed at length in Chapter 24.

The other main category of maintenance task is periodic vacuuming of the database. This activity is discussed in Section 23.1. Closely related to this is updating the statistics that will be used by the query planner, as discussed in Section 23.1.3.

Another task that might need periodic attention is log file management. This is discussed in Section 23.3.

check_postgres is available for monitoring database health and reporting unusual conditions. check_postgres integrates with Nagios and MRTG, but can be run standalone too.

LightDB is low-maintenance compared to some other database management systems. Nonetheless, appropriate attention to these tasks will go far towards ensuring a pleasant and productive experience with the system.