aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorMagnus Hagander <magnus@hagander.net>2013-01-25 09:44:14 +0100
committerMagnus Hagander <magnus@hagander.net>2013-01-25 09:47:22 +0100
commit1cc43979cf44db0b3da77e34493689fe13484fa0 (patch)
tree81acf95bdc9d6f5c0c432b2d6aed487035acb1f2 /src
parent49e0ea5991bf00a68e753583738a6759b7b29f2d (diff)
downloadpostgresql-1cc43979cf44db0b3da77e34493689fe13484fa0.tar.gz
postgresql-1cc43979cf44db0b3da77e34493689fe13484fa0.zip
Make pg_dump exclude unlogged table data on hot standby slaves
Noted by Joe Van Dyk
Diffstat (limited to 'src')
-rw-r--r--src/bin/pg_dump/pg_dump.c18
1 files changed, 18 insertions, 0 deletions
diff --git a/src/bin/pg_dump/pg_dump.c b/src/bin/pg_dump/pg_dump.c
index d6e4220ad5a..bef2b430fe7 100644
--- a/src/bin/pg_dump/pg_dump.c
+++ b/src/bin/pg_dump/pg_dump.c
@@ -653,6 +653,24 @@ main(int argc, char **argv)
no_security_labels = 1;
/*
+ * When running against 9.0 or later, check if we are in recovery mode,
+ * which means we are on a hot standby.
+ */
+ if (fout->remoteVersion >= 90000)
+ {
+ PGresult *res = ExecuteSqlQueryForSingleRow(fout, "SELECT pg_catalog.pg_is_in_recovery()");
+ if (strcmp(PQgetvalue(res, 0, 0), "t") == 0)
+ {
+ /*
+ * On hot standby slaves, never try to dump unlogged table data,
+ * since it will just throw an error.
+ */
+ no_unlogged_table_data = true;
+ }
+ PQclear(res);
+ }
+
+ /*
* Start transaction-snapshot mode transaction to dump consistent data.
*/
do_sql_command(g_conn, "BEGIN");