Postgres is the gift of timesuck. It’s a great database, especially for spatial data. However, without insider knowledge, simple tasks eat time.
Latest example: pg_upgrade. It shrinks upgrade complexity–if it works! For Windows users, the documentation has useless and incomplete steps.
Here’s a better procedure. I used it for upgrades on Windows. I assume you only have the old version installed and you’re using the default x64 install location of C:\Program Files\PostgreSQL. The steps:
- Install the newer Postgres with the Windows installer. Don’t let it use TCP port 5432 yet; that’s used by your current Postgres install. The installer saw this and recommended 5433. Add needed extensions with the Application Stack Builder. If you use PostGIS, don’t install the sample database. Do nothing else with the new install.
- With the Services control panel, shut down both the old and new databases.
- Create a new account on your PC named postgres. This is a Windows user, not a user inside the Postgres database. This account does not need to have the same password as the Postgres account in your databases. Add it to your PC’s Administrators group. (I didn’t have this account. I don’t know why Postgres or pg_upgrade need it. A better design would permit me to specify database accounts for each install with pg_upgrade command line switches. The
--username switch didn’t appear to do that, plus it would use the same username across both databases, which may not always be proper.)
- With Windows Explorer, give the Windows postgres account Full Control permission on C:\Program Files\PostgreSQL\ and data directories, which are at C:\Program Files\PostgreSQL\version\data. Yes, you must give this permission to both directories. For some reason, the data directories do not inherit permissions. Make sure the permissions are standard, in the sense that they are inherited by children.
- Create new pg_hba.conf files for both servers. Before you do that, back up the current files so you can revert when done. These files are in C:\Program Files\PostgreSQL\version\data. Note that this change puts your database in an insecure state; you may want to take the host off the network or aggressively firewall it while this configuration is active. The new versions of the files should only have these two lines:
host all all 127.0.0.1/32 trust
host all all ::1/128 trust
- Open a command prompt window in administrator mode. Run this: RUNAS /USER:postgres “CMD.EXE” and then:
- Change to the bin directory of the newer install of Postgres. It will be C:\Program Files\PostgreSQL\version\bin.
- Run this: pg_upgrade.exe
--old-datadir “C:/Program Files/PostgreSQL/oldVersion/data”
--new-datadir “C:/Program Files/PostgreSQL/newVersion/data”
--old-bindir “C:/Program Files/PostgreSQL/oldVersion/bin”
--new-bindir “C:/Program Files/PostgreSQL/newVersion/bin” This will take a while to run if you have a lot of data. Wait until this is done before continuing.
- Edit the postgresql.conf file for the new Postgres install and change the listening port to 5432 (from 5433).
- Revert the changes to the pg_hba.conf files for both servers.
- Through the Services control panel, start your new Postgres install back up.
- Vacuum and reanalyze all databases.
- If you created a postgres Windows account above, remove it.
The new Postgres install’s postgres database account (not the Windows account) will now have the same password as in the old Postgres install.
Once you’ve verified that everything works properly, it may be safe to uninstall the old Postgres copy.