83

I have used pg_dump on one machine and copied result file to another, where I tried to restore it. I believe schema is the same. However, I get:

pg_restore: [archiver] input file does not appear to be a valid archive

I have done following operations:

pg_dump -a -f db.txt dbname

and:

pg_restore -a -d dbname db.txt

What might be wrong?

gruszczy
  • 933
  • 1
  • 7
  • 7
  • Try importing the dump on the same machine that generated it. Also, check the Postgres versions. – Hank Gay Jun 14 '10 at 16:18
  • I can't try importing it on the same machine, because it's a production machine. Any idea, what else I can do? – gruszczy Jun 14 '10 at 16:19
  • This solution may also be relevant to some people: http://stackoverflow.com/questions/42433414/heroku-database-restore-issue/42435490#42435490 – Nah Feb 24 '17 at 09:56

9 Answers9

107

You are dumping in plain SQL format which was designed to feed to psql. This is not recognized by pg_restore.

cat db.txt | psql dbname

Should do the trick

Yuri
  • 208
  • 1
  • 6
Peter Tillemans
  • 1,246
  • 1
  • 9
  • 7
32

pg_dump by default creates the sql commmands necessary to recreate the data. To recover it, you just need to invoke psql (not pg_restore ) with the file as input . pg_restore is only to be used for the binary (not default, and less usual not recommended) format of pg_dump. Read the docs.

Update: The pg_dump binary formats (-Fc -Ft) that are to be used with pg_restore are ok, and offer some extra flexibility. But they are less standard (non SQL), less apt for importing from some tools (eg. a php frontend) or manipulate with a text editor, and a little less portable to other versions and even other databases. For backups, I'd stick with the default plain format. For other scenarios, the binary + pg_restore option can be equally or more apt.

The point to keep is that in Postgresql, in the typical scenario, the backup normally is done by pg_dump (plain) and the restore with the standard command line client (psql).

leonbloy
  • 2,028
  • 17
  • 23
  • 2
    [OT] I beg to differ regarding the "not recommended" status of the custom output format - the sentence "This is the most flexible format in that it allows reordering of loading data as well as object definitions..." from the manual seems to me as quite an endorsement. – Milen A. Radev Jun 14 '10 at 17:09
  • "not recommended" was an overstatement, I agree. But "most flexible" does not necessarily means "most recommended". Clarified. – leonbloy Jun 14 '10 at 17:25
17

Try passing the --format=c option to pg_dump. This will allow pg_restore to restore it.

psmears
  • 330
  • 1
  • 6
  • Would whoever modded this down like to explain why? The accepted answer explains that this will work :-) –  Sep 25 '10 at 09:28
  • @skrafi: What is your point? – psmears Apr 20 '16 at 08:57
  • 2
    sorry, copy-pasted wrong output, the right one is `pg_restore: [archiver] did not find magic string in file header` so this doesn't work for simple sql dump – skrafi Apr 20 '16 at 09:05
  • @skrafi: I'm not sure what you mean. If you use `pg_dump --format=c ...> archivefile`, and then use `pg_restore` on `archivefile`, then (at least when I tested it just now) it works fine. Maybe your file is corrupt somehow? Or you have hit a particular bug? – psmears Apr 20 '16 at 09:35
9

This is what I would do to backup my old database and restore

To back up your database

pg_dump --format=c olddb_name > db_dump_file.dump

To restore that backup

pg_restore -v -d newdb_name db_dump_file.dump

Read more on pg_dump and pg_restore

Techie
  • 191
  • 1
  • 5
6

For windows users try

type db.txt | psql --username="YOURNAME" dbname

Works like a charm

2

You can do something to MySQL's SOURCE command:

psql dbname

Then, in postgresql terminal:

\i filename
greg0ire
  • 316
  • 1
  • 6
  • 26
2

cat dumpFileName | psql -h ip -d dbName -U userName -W

1

If you're on Windows, call the psql client of Postgres, in the shell, with the parameters as below:

psql -h <your_host_name> -p <postgres_port_number> -U <your_user_name_in_postgres> -f "<your_sql_script>.sql" <your_database_name>

Example:

psql -h localhost -p 5432 -U postgres -f "C:\Users\Mx\Downloads\northwind.postgre.sql" northwind
maximus
  • 11
  • 2
1

This error message could also mean that there's actually something wrong with the backup file (or your assumptions about it).

In one case, I had mounted a backup file in a Docker container and tried to restore, but it failed with does not appear to be a valid archive. And in fact, the file was empty, because the mount was not performed correctly.

Dag Høidahl
  • 133
  • 6