Saya memiliki server PostgreSQL 9.1 yang berjalan pada OS CentOS 5.8 32bit dan saya telah mengaktifkan pengarsipan WAL. Di server ini, ada tiga database: databaseA, databaseB, dan databaseC. Seseorang menghapus tabel pada jam 12 siang di databaseB dan saya ingin mengembalikan databaseB sebelum waktu tabel itu dihapus. Sekarang pukul 3 sore.
Bagaimana saya bisa mengembalikan databaseB hingga jam 12 malam tanpa kehilangan data selama tiga jam di dua basis data lainnya?
postgresql.conf
wal_level = archive
archive_mode = on
archive_command = 'test ! -f /opt/pgsql/logs/%f && cp %p /opt/pgsql/logs/%f'
max_wal_senders = 100
recovery.conf
restore_command = 'cp /opt/pgsql/logs/%f %p'
recovery_target_time = '2012-06-29 11:59:59 CEST'
Saya menjalankan backup basis saya pada jam 9 pagi
pg_basebackup -h 127.0.0.1 -D /opt/pgsql/backup
Layanan PostgreSQL dimatikan pada jam 3 sore.
sumber
Untuk memperluas jawaban kgrittn, Anda juga dapat melakukan
pg_dump
hanya dari tabel yang dijatuhkan dan membangunnya kembali di database yang sudah adaB, jadi Anda tidak perlu kehilangan 6 jam data di tabel lain.sumber