PostgreSQL9.1 upgrade to PostgreSQL9.5rc1

PostgreSQL9.1.0 upgrade to PostgreSQL9.5rc1

安装PG9.1端口为5432

[pgup@minion1 pg]$ ls

postgresql-9.1.0.tar.bz2  postgresql-9.5rc1.tar.bz2

[pgup@minion1 pg]$ tar jxvf postgresql-9.1.0.tar.bz2

[pgup@minion1 pg]$ cd postgresql-9.1.0

[pgup@minion1 postgresql-9.1.0]$ ./configure --prefix=/usr/local/pg91/

[pgup@minion1 postgresql-9.1.0]$ gmake world

[pgup@minion1 postgresql-9.1.0]$ gmake install-world

初始化并启动PG9.1

[pgup@minion1 postgresql-9.1.0]$ cd /usr/local/pg91/

[pgup@minion1 pg91]$ mkdir data

[pgup@minion1 pg91]$ cd bin/

[pgup@minion1 bin]$ ./initdb -D ../data/

[pgup@minion1 bin]$ ./pg_ctl -D ../data/ start

生成测试数据

[pgup@minion1 bin]$ ./psql -U pgup -d postgres

psql (9.1.0)

Type "help" for help.

postgres=# CREATE USER benchmarksql with superuser password '123456';

CREATE ROLE

postgres=# CREATE DATABASE  benchmarksql owner benchmarksql;

CREATE DATABASE

postgres=# q

[pgup@minion1 bin]$ ./pgbench -i -F 100 -s 714 -h 127.0.0.1 -p 5432 -U benchmarksql benchmarksql

[pgup@minion1 bin]$ ./psql -U pgup -d benchmarksql

psql (9.1.0)

Type "help" for help.

benchmarksql=# d+

                            List of relations

 Schema |       Name       | Type  |    Owner     |  Size   | Description

--------+------------------+-------+--------------+---------+-------------

 public | pgbench_accounts | table | benchmarksql | 9147 MB |

 public | pgbench_branches | table | benchmarksql | 64 kB   |

 public | pgbench_history  | table | benchmarksql | 0 bytes |

 public | pgbench_tellers  | table | benchmarksql | 344 kB  |

(4 rows)

benchmarksql=# c postgres

You are now connected to database "postgres" as user "pgup".

postgres=# d

No relations found.

postgres=# l+

                                                                     List of databases

     Name     |    Owner     | Encoding |   Collate   |    Ctype    | Access privileges |  Size   | Tablespace |        

       Description                

--------------+--------------+----------+-------------+-------------+-------------------+---------+------------+---------

-----------------------------------

 benchmarksql | benchmarksql | UTF8     | en_US.UTF-8 | en_US.UTF-8 |                   | 10 GB   | pg_default |

 postgres     | pgup         | UTF8     | en_US.UTF-8 | en_US.UTF-8 |                   | 6153 kB | pg_default | default

administrative connection database

 template0    | pgup         | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/pgup          +| 6049 kB | pg_default | unmodifi

able empty database

              |              |          |             |             | pgup=CTc/pgup     |         |            |

 template1    | pgup         | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/pgup          +| 6049 kB | pg_default | default

template for new databases

              |              |          |             |             | pgup=CTc/pgup     |         |            |

(4 rows)

关闭PG9.1

[pgup@minion1 bin]$ cd /usr/local/pg91/bin/

[pgup@minion1 bin]$ ./pg_ctl -D ../data/ stop

waiting for server to shut down.... done

server stopped

 

安装PG9.5rc端口为5432

[pgup@minion1 bin]$ cd /opt/soft_bak/pg

[pgup@minion1 pg]$ tar jxvf postgresql-9.5rc1.tar.bz2

[pgup@minion1 postgresql-9.5rc1]$ ./configure --prefix=/usr/local/pg95rc/

[pgup@minion1 postgresql-9.5rc1]$ gmake world

[pgup@minion1 postgresql-9.5rc1]$ gmake install-world

初始化并启动PG9.5rc确保PG9.5rc正常运行

[pgup@minion1 postgresql-9.5rc1]$ cd /usr/local/pg95rc/

[pgup@minion1 pg95rc]$ mkdir data

[pgup@minion1 pg95rc]$ cd bin/

[pgup@minion1 bin]$ ./initdb -D ../data/

[pgup@minion1 bin]$ vim ../data/postgresql.conf

[pgup@minion1 bin]$ ./pg_ctl -D ../data/ start

server starting

[pgup@minion1 bin]$ LOG:  database system was shut down at 2016-01-05 10:13:44 CST

LOG:  MultiXact member wraparound protections are now enabled

LOG:  database system is ready to accept connections

LOG:  autovacuum launcher started

[pgup@minion1 bin]$ ./psql -U pgup -d postgres -p 6432

psql (9.5rc1)

Type "help" for help.

 

postgres=# l

                              List of databases

   Name    | Owner | Encoding |   Collate   |    Ctype    | Access privileges

-----------+-------+----------+-------------+-------------+-------------------

 postgres  | pgup  | UTF8     | en_US.UTF-8 | en_US.UTF-8 |

 template0 | pgup  | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/pgup          +

           |       |          |             |             | pgup=CTc/pgup

 template1 | pgup  | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/pgup          +

           |       |          |             |             | pgup=CTc/pgup

(3 rows)

关闭PG9.5rc

postgres=# q

[pgup@minion1 bin]$ ./pg_ctl -D ../data/ stop

waiting for server to shut down....LOG:  received fast shutdown request

LOG:  aborting any active transactions

LOG:  autovacuum launcher shutting down

LOG:  shutting down

LOG:  database system is shut down

 done

server stopped

 

升级PG9.1到PG9.5rc

[pgup@minion1 bin]$ pwd

/usr/local/pg95rc/bin

[pgup@minion1 bin]$ ./pg_upgrade -d /usr/local/pg91/data/ -D /usr/local/pg95rc/data/ -b /usr/local/pg91/bin/ -B /usr/local/pg95rc/bin/ -v

升级过程中输出如下信息,并生成两个脚本

Running in verbose mode

Performing Consistency Checks

-----------------------------

Checking cluster versions                                   ok

pg_control values:

 

First log file ID after reset:        0

First log file segment after reset:   2

pg_control version number:            903

Catalog version number:               201105231

Database system identifier:           6236111615516434429

Latest checkpoint's TimeLineID:       1

Latest checkpoint's NextXID:          0/1821

Latest checkpoint's NextOID:          16405

Latest checkpoint's NextMultiXactId:  1

Latest checkpoint's NextMultiOffset:  0

Latest checkpoint's oldestXID:        1795

Latest checkpoint's oldestXID's DB:   1

Latest checkpoint's oldestActiveXID:  0

Maximum data alignment:               8

Database block size:                  8192

Blocks per segment of large relation: 131072

WAL block size:                       8192

Bytes per WAL segment:                16777216

Maximum length of identifiers:        64

Maximum columns in an index:          32

Maximum size of a TOAST chunk:        1996

Date/time type storage:               64-bit integers

Float4 argument passing:              by value

Float8 argument passing:              by value

Current pg_control values:

 

pg_control version number:            942

Catalog version number:               201510051

Database system identifier:           6236120816756050287

Latest checkpoint's TimeLineID:       1

Latest checkpoint's full_page_writes: on

Latest checkpoint's NextXID:          0/1750

Latest checkpoint's NextOID:          13242

Latest checkpoint's NextMultiXactId:  1

Latest checkpoint's NextMultiOffset:  0

Latest checkpoint's oldestXID:        1741

Latest checkpoint's oldestXID's DB:   1

Latest checkpoint's oldestActiveXID:  0

Latest checkpoint's oldestMultiXid:   1

Latest checkpoint's oldestMulti's DB: 1

Latest checkpoint's oldestCommitTs:   0

Latest checkpoint's newestCommitTs:   0

Maximum data alignment:               8

Database block size:                  8192

Blocks per segment of large relation: 131072

WAL block size:                       8192

Bytes per WAL segment:                16777216

Maximum length of identifiers:        64

Maximum columns in an index:          32

Maximum size of a TOAST chunk:        1996

Size of a large-object chunk:         2048

Date/time type storage:               64-bit integers

Float4 argument passing:              by value

Float8 argument passing:              by value

Data page checksum version:           0

Values to be changed:

First log segment after reset:        000000010000000000000002

"/usr/local/pg91/bin/pg_ctl" -w -l "pg_upgrade_server.log" -D "/usr/local/pg91/data/" -o "-p 50432 -b  -c listen_addresses='' -c unix_socket_permissions=0700 -c unix_socket_directory='/usr/local/pg95rc/bin'" start >> "pg_upgrade_server.log" 2>&1

executing: SELECT c.relname, c.relfilenode FROM pg_catalog.pg_class c,            pg_catalog.pg_namespace n WHERE         c.relnamespace = n.oid AND           n.nspname = 'pg_catalog' AND               c.relname = 'pg_database' ORDER BY c.relname

executing: SELECT d.oid, d.datname, d.encoding, d.datcollate, d.datctype, t.spclocation AS spclocation FROM pg_catalog.pg_database d  LEFT OUTER JOIN pg_catalog.pg_tablespace t  ON d.dattablespace = t.oid WHERE d.datallowconn = true ORDER BY 2

executing: WITH regular_heap (reloid) AS (   SELECT c.oid   FROM pg_catalog.pg_class c JOIN pg_catalog.pg_namespace n                       ON c.relnamespace = n.oid      LEFT OUTER JOIN pg_catalog.pg_index i                    ON c.oid = i.indexrelid          WHERE relkind IN ('r', 'm', 'i', 'S') AND             i.indisvalid IS DISTINCT FROM false AND                 i.indisready IS DISTINCT FROM false AND       ((n.nspname !~ '^pg_temp_' AND          n.nspname !~ '^pg_toast_temp_' AND              n.nspname NOT IN ('pg_catalog', 'information_schema',                                                                'binary_upgrade', 'pg_toast') AND                     c.oid >= 16384) OR            (n.nspname = 'pg_catalog' AND     relname IN ('pg_largeobject', 'pg_largeobject_loid_pn_index', 'pg_largeobject_metadata', 'pg_largeobject_metadata_oid_index') ))),          toast_heap (reloid) AS (     SELECT reltoastrelid       FROM regular_heap JOIN pg_catalog.pg_class c           ON regular_heap.reloid = c.oid                    AND c.reltoastrelid != 0),       all_index (reloid) AS (      SELECT indexrelid   FROM pg_index      WHERE indisvalid     AND indrelid IN (SELECT reltoastrelid         FROM (SELECT reloid FROM regular_heap          UNION ALL                              SELECT reloid FROM toast_heap) all_heap             JOIN pg_catalog.pg_class c             ON all_heap.reloid = c.oid             AND c.reltoastrelid != 0)) SELECT c.oid, n.nspname, c.relname,         c.relfilenode, c.reltablespace, t.spclocation FROM (SELECT reloid FROM regular_heap          UNION ALL           SELECT reloid FROM toast_heap       UNION ALL         SELECT reloid FROM all_index) all_rels   JOIN pg_catalog.pg_class c           ON all_rels.reloid = c.oid   JOIN pg_catalog.pg_namespace n            ON c.relnamespace = n.oid   LEFT OUTER JOIN pg_catalog.pg_tablespace t         ON c.reltablespace = t.oid ORDER BY 1;

executing: WITH regular_heap (reloid) AS (   SELECT c.oid   FROM pg_catalog.pg_class c JOIN pg_catalog.pg_namespace n                       ON c.relnamespace = n.oid      LEFT OUTER JOIN pg_catalog.pg_index i                    ON c.oid = i.indexrelid          WHERE relkind IN ('r', 'm', 'i', 'S') AND             i.indisvalid IS DISTINCT FROM false AND                 i.indisready IS DISTINCT FROM false AND       ((n.nspname !~ '^pg_temp_' AND          n.nspname !~ '^pg_toast_temp_' AND              n.nspname NOT IN ('pg_catalog', 'information_schema',                                                                'binary_upgrade', 'pg_toast') AND                     c.oid >= 16384) OR            (n.nspname = 'pg_catalog' AND     relname IN ('pg_largeobject', 'pg_largeobject_loid_pn_index', 'pg_largeobject_metadata', 'pg_largeobject_metadata_oid_index') ))),          toast_heap (reloid) AS (     SELECT reltoastrelid       FROM regular_heap JOIN pg_catalog.pg_class c           ON regular_heap.reloid = c.oid                    AND c.reltoastrelid != 0),       all_index (reloid) AS (      SELECT indexrelid   FROM pg_index      WHERE indisvalid     AND indrelid IN (SELECT reltoastrelid         FROM (SELECT reloid FROM regular_heap          UNION ALL                              SELECT reloid FROM toast_heap) all_heap             JOIN pg_catalog.pg_class c             ON all_heap.reloid = c.oid             AND c.reltoastrelid != 0)) SELECT c.oid, n.nspname, c.relname,         c.relfilenode, c.reltablespace, t.spclocation FROM (SELECT reloid FROM regular_heap          UNION ALL           SELECT reloid FROM toast_heap       UNION ALL         SELECT reloid FROM all_index) all_rels   JOIN pg_catalog.pg_class c           ON all_rels.reloid = c.oid   JOIN pg_catalog.pg_namespace n            ON c.relnamespace = n.oid   LEFT OUTER JOIN pg_catalog.pg_tablespace t         ON c.reltablespace = t.oid ORDER BY 1;

executing: WITH regular_heap (reloid) AS (   SELECT c.oid   FROM pg_catalog.pg_class c JOIN pg_catalog.pg_namespace n                       ON c.relnamespace = n.oid      LEFT OUTER JOIN pg_catalog.pg_index i                    ON c.oid = i.indexrelid          WHERE relkind IN ('r', 'm', 'i', 'S') AND             i.indisvalid IS DISTINCT FROM false AND                 i.indisready IS DISTINCT FROM false AND       ((n.nspname !~ '^pg_temp_' AND          n.nspname !~ '^pg_toast_temp_' AND              n.nspname NOT IN ('pg_catalog', 'information_schema',                                                                'binary_upgrade', 'pg_toast') AND                     c.oid >= 16384) OR            (n.nspname = 'pg_catalog' AND     relname IN ('pg_largeobject', 'pg_largeobject_loid_pn_index', 'pg_largeobject_metadata', 'pg_largeobject_metadata_oid_index') ))),          toast_heap (reloid) AS (     SELECT reltoastrelid       FROM regular_heap JOIN pg_catalog.pg_class c           ON regular_heap.reloid = c.oid                    AND c.reltoastrelid != 0),       all_index (reloid) AS (      SELECT indexrelid   FROM pg_index      WHERE indisvalid     AND indrelid IN (SELECT reltoastrelid         FROM (SELECT reloid FROM regular_heap          UNION ALL                              SELECT reloid FROM toast_heap) all_heap             JOIN pg_catalog.pg_class c             ON all_heap.reloid = c.oid             AND c.reltoastrelid != 0)) SELECT c.oid, n.nspname, c.relname,         c.relfilenode, c.reltablespace, t.spclocation FROM (SELECT reloid FROM regular_heap          UNION ALL           SELECT reloid FROM toast_heap       UNION ALL         SELECT reloid FROM all_index) all_rels   JOIN pg_catalog.pg_class c           ON all_rels.reloid = c.oid   JOIN pg_catalog.pg_namespace n            ON c.relnamespace = n.oid   LEFT OUTER JOIN pg_catalog.pg_tablespace t         ON c.reltablespace = t.oid ORDER BY 1;

 

old databases:

Database: benchmarksql

relname: pg_catalog.pg_largeobject: reloid: 2613 reltblspace:

relname: pg_catalog.pg_largeobject_loid_pn_index: reloid: 2683 reltblspace:

relname: pg_catalog.pg_largeobject_metadata: reloid: 2995 reltblspace:

relname: pg_catalog.pg_largeobject_metadata_oid_index: reloid: 2996 reltblspace:

relname: public.pgbench_branches: reloid: 16386 reltblspace:

relname: public.pgbench_tellers: reloid: 16389 reltblspace:

relname: public.pgbench_accounts: reloid: 16392 reltblspace:

relname: public.pgbench_history: reloid: 16395 reltblspace:

relname: public.pgbench_branches_pkey: reloid: 16399 reltblspace:

relname: public.pgbench_tellers_pkey: reloid: 16401 reltblspace:

relname: public.pgbench_accounts_pkey: reloid: 16403 reltblspace:

 

Database: postgres

relname: pg_catalog.pg_largeobject: reloid: 2613 reltblspace:

relname: pg_catalog.pg_largeobject_loid_pn_index: reloid: 2683 reltblspace:

relname: pg_catalog.pg_largeobject_metadata: reloid: 2995 reltblspace:

relname: pg_catalog.pg_largeobject_metadata_oid_index: reloid: 2996 reltblspace:

 

Database: template1

relname: pg_catalog.pg_largeobject: reloid: 2613 reltblspace:

relname: pg_catalog.pg_largeobject_loid_pn_index: reloid: 2683 reltblspace:

relname: pg_catalog.pg_largeobject_metadata: reloid: 2995 reltblspace:

relname: pg_catalog.pg_largeobject_metadata_oid_index: reloid: 2996 reltblspace:

 

executing: SELECT   spclocation FROM   pg_catalog.pg_tablespace WHERE         spcname != 'pg_default' AND                  spcname != 'pg_global'

executing: SELECT DISTINCT probin FROM     pg_catalog.pg_proc WHERE   prolang = 13 /* C */ AND probin IS NOT NULL AND oid >= 16384;

executing: SELECT DISTINCT probin FROM     pg_catalog.pg_proc WHERE   prolang = 13 /* C */ AND probin IS NOT NULL AND oid >= 16384;

executing: SELECT DISTINCT probin FROM     pg_catalog.pg_proc WHERE   prolang = 13 /* C */ AND probin IS NOT NULL AND oid >= 16384;

Checking database user is the install user                  executing: SELECT rolsuper, oid FROM pg_catalog.pg_roles WHERE rolname = current_user

executing: SELECT COUNT(*) FROM pg_catalog.pg_roles

ok

Checking database connection settings                       executing: SELECT      datname, datallowconn FROM         pg_catalog.pg_database

ok

Checking for prepared transactions                          executing: SELECT * FROM pg_catalog.pg_prepared_xacts

ok

Checking for reg* system OID user data types                executing: SELECT n.nspname, c.relname, a.attname FROM       pg_catalog.pg_class c,            pg_catalog.pg_namespace n,                  pg_catalog.pg_attribute a WHERE c.oid = a.attrelid AND                  NOT a.attisdropped AND                 a.atttypid IN (                            'pg_catalog.regproc'::pg_catalog.regtype,                     'pg_catalog.regprocedure'::pg_catalog.regtype,                             'pg_catalog.regoper'::pg_catalog.regtype,                     'pg_catalog.regoperator'::pg_catalog.regtype,                      'pg_catalog.regconfig'::pg_catalog.regtype,                            'pg_catalog.regdictionary'::pg_catalog.regtype) AND          c.relnamespace = n.oid AND           n.nspname NOT IN ('pg_catalog', 'information_schema')

executing: SELECT n.nspname, c.relname, a.attname FROM         pg_catalog.pg_class c,            pg_catalog.pg_namespace n,          pg_catalog.pg_attribute a WHERE c.oid = a.attrelid AND              NOT a.attisdropped AND                 a.atttypid IN (          'pg_catalog.regproc'::pg_catalog.regtype,                     'pg_catalog.regprocedure'::pg_catalog.regtype,                   'pg_catalog.regoper'::pg_catalog.regtype,                     'pg_catalog.regoperator'::pg_catalog.regtype,             'pg_catalog.regconfig'::pg_catalog.regtype,                            'pg_catalog.regdictionary'::pg_catalog.regtype) AND          c.relnamespace = n.oid AND           n.nspname NOT IN ('pg_catalog', 'information_schema')

executing: SELECT n.nspname, c.relname, a.attname FROM         pg_catalog.pg_class c,            pg_catalog.pg_namespace n,          pg_catalog.pg_attribute a WHERE c.oid = a.attrelid AND              NOT a.attisdropped AND                 a.atttypid IN (          'pg_catalog.regproc'::pg_catalog.regtype,                     'pg_catalog.regprocedure'::pg_catalog.regtype,                   'pg_catalog.regoper'::pg_catalog.regtype,                     'pg_catalog.regoperator'::pg_catalog.regtype,             'pg_catalog.regconfig'::pg_catalog.regtype,                            'pg_catalog.regdictionary'::pg_catalog.regtype) AND          c.relnamespace = n.oid AND           n.nspname NOT IN ('pg_catalog', 'information_schema')

ok

Checking for contrib/isn with bigint-passing mismatch       ok

Checking for invalid "line" user columns                    executing: SELECT n.nspname, c.relname, a.attname FROM         pg_catalog.pg_class c,            pg_catalog.pg_namespace n,                  pg_catalog.pg_attribute a WHERE c.oid = a.attrelid AND                  NOT a.attisdropped AND                 a.atttypid = 'pg_catalog.line'::pg_catalog.regtype AND                c.relnamespace = n.oid AND           n.nspname !~ '^pg_temp_' AND             n.nspname !~ '^pg_toast_temp_' AND                   n.nspname NOT IN ('pg_catalog', 'information_schema')

executing: SELECT n.nspname, c.relname, a.attname FROM         pg_catalog.pg_class c,            pg_catalog.pg_namespace n,          pg_catalog.pg_attribute a WHERE c.oid = a.attrelid AND              NOT a.attisdropped AND                 a.atttypid = 'pg_catalog.line'::pg_catalog.regtype AND            c.relnamespace = n.oid AND           n.nspname !~ '^pg_temp_' AND             n.nspname !~ '^pg_toast_temp_' AND                   n.nspname NOT IN ('pg_catalog', 'information_schema')

executing: SELECT n.nspname, c.relname, a.attname FROM         pg_catalog.pg_class c,            pg_catalog.pg_namespace n,          pg_catalog.pg_attribute a WHERE c.oid = a.attrelid AND              NOT a.attisdropped AND                 a.atttypid = 'pg_catalog.line'::pg_catalog.regtype AND            c.relnamespace = n.oid AND           n.nspname !~ '^pg_temp_' AND             n.nspname !~ '^pg_toast_temp_' AND                   n.nspname NOT IN ('pg_catalog', 'information_schema')

ok

Creating dump of global objects                             "/usr/local/pg95rc/bin/pg_dumpall" --host "/usr/local/pg95rc/bin" --port 50432 --username "pgup" --globals-only --quote-all-identifiers --binary-upgrade --verbose -f pg_upgrade_dump_globals.sql >> "pg_upgrade_utility.log" 2>&1

ok

Creating dump of database schemas

"/usr/local/pg95rc/bin/pg_dump" --host "/usr/local/pg95rc/bin" --port 50432 --username "pgup" --schema-only --quote-all-identifiers --binary-upgrade --format=custom --verbose --file="pg_upgrade_dump_16385.custom" "benchmarksql" >> "pg_upgrade_dump_16385.log" 2>&1

"/usr/local/pg95rc/bin/pg_dump" --host "/usr/local/pg95rc/bin" --port 50432 --username "pgup" --schema-only --quote-all-identifiers --binary-upgrade --format=custom --verbose --file="pg_upgrade_dump_12780.custom" "postgres" >> "pg_upgrade_dump_12780.log" 2>&1

"/usr/local/pg95rc/bin/pg_dump" --host "/usr/local/pg95rc/bin" --port 50432 --username "pgup" --schema-only --quote-all-identifiers --binary-upgrade --format=custom --verbose --file="pg_upgrade_dump_1.custom" "template1" >> "pg_upgrade_dump_1.log" 2>&1

                                                            ok

"/usr/local/pg91/bin/pg_ctl" -w -D "/usr/local/pg91/data/" -o ""  stop >> "pg_upgrade_server.log" 2>&1

"/usr/local/pg95rc/bin/pg_ctl" -w -l "pg_upgrade_server.log" -D "/usr/local/pg95rc/data/" -o "-p 50432 -b -c synchronous_commit=off -c fsync=off -c full_page_writes=off  -c listen_addresses='' -c unix_socket_permissions=0700 -c unix_socket_directories='/usr/local/pg95rc/bin'" start >> "pg_upgrade_server.log" 2>&1

executing: SELECT d.oid, d.datname, d.encoding, d.datcollate, d.datctype, pg_catalog.pg_tablespace_location(t.oid) AS spclocation FROM pg_catalog.pg_database d  LEFT OUTER JOIN pg_catalog.pg_tablespace t  ON d.dattablespace = t.oid WHERE d.datallowconn = true ORDER BY 2

executing: WITH regular_heap (reloid) AS (   SELECT c.oid   FROM pg_catalog.pg_class c JOIN pg_catalog.pg_namespace n                       ON c.relnamespace = n.oid      LEFT OUTER JOIN pg_catalog.pg_index i                    ON c.oid = i.indexrelid          WHERE relkind IN ('r', 'm', 'i', 'S') AND             i.indisvalid IS DISTINCT FROM false AND                 i.indisready IS DISTINCT FROM false AND       ((n.nspname !~ '^pg_temp_' AND          n.nspname !~ '^pg_toast_temp_' AND              n.nspname NOT IN ('pg_catalog', 'information_schema',                                                                'binary_upgrade', 'pg_toast') AND                     c.oid >= 16384) OR            (n.nspname = 'pg_catalog' AND     relname IN ('pg_largeobject', 'pg_largeobject_loid_pn_index', 'pg_largeobject_metadata', 'pg_largeobject_metadata_oid_index') ))),          toast_heap (reloid) AS (     SELECT reltoastrelid       FROM regular_heap JOIN pg_catalog.pg_class c           ON regular_heap.reloid = c.oid                    AND c.reltoastrelid != 0),       all_index (reloid) AS (      SELECT indexrelid   FROM pg_index      WHERE indisvalid     AND indrelid IN (SELECT reltoastrelid         FROM (SELECT reloid FROM regular_heap          UNION ALL                              SELECT reloid FROM toast_heap) all_heap             JOIN pg_catalog.pg_class c             ON all_heap.reloid = c.oid             AND c.reltoastrelid != 0)) SELECT c.oid, n.nspname, c.relname,         c.relfilenode, c.reltablespace, pg_catalog.pg_tablespace_location(t.oid) AS spclocation FROM (SELECT reloid FROM regular_heap            UNION ALL           SELECT reloid FROM toast_heap              UNION ALL           SELECT reloid FROM all_index) all_rels   JOIN pg_catalog.pg_class c             ON all_rels.reloid = c.oid   JOIN pg_catalog.pg_namespace n      ON c.relnamespace = n.oid   LEFT OUTER JOIN pg_catalog.pg_tablespace t        ON c.reltablespace = t.oid ORDER BY 1;

executing: WITH regular_heap (reloid) AS (   SELECT c.oid   FROM pg_catalog.pg_class c JOIN pg_catalog.pg_namespace n                       ON c.relnamespace = n.oid      LEFT OUTER JOIN pg_catalog.pg_index i                    ON c.oid = i.indexrelid          WHERE relkind IN ('r', 'm', 'i', 'S') AND             i.indisvalid IS DISTINCT FROM false AND                 i.indisready IS DISTINCT FROM false AND       ((n.nspname !~ '^pg_temp_' AND          n.nspname !~ '^pg_toast_temp_' AND              n.nspname NOT IN ('pg_catalog', 'information_schema',                                                                'binary_upgrade', 'pg_toast') AND                     c.oid >= 16384) OR            (n.nspname = 'pg_catalog' AND     relname IN ('pg_largeobject', 'pg_largeobject_loid_pn_index', 'pg_largeobject_metadata', 'pg_largeobject_metadata_oid_index') ))),          toast_heap (reloid) AS (     SELECT reltoastrelid       FROM regular_heap JOIN pg_catalog.pg_class c           ON regular_heap.reloid = c.oid                    AND c.reltoastrelid != 0),       all_index (reloid) AS (      SELECT indexrelid   FROM pg_index      WHERE indisvalid     AND indrelid IN (SELECT reltoastrelid         FROM (SELECT reloid FROM regular_heap          UNION ALL                              SELECT reloid FROM toast_heap) all_heap             JOIN pg_catalog.pg_class c             ON all_heap.reloid = c.oid             AND c.reltoastrelid != 0)) SELECT c.oid, n.nspname, c.relname,         c.relfilenode, c.reltablespace, pg_catalog.pg_tablespace_location(t.oid) AS spclocation FROM (SELECT reloid FROM regular_heap            UNION ALL           SELECT reloid FROM toast_heap              UNION ALL           SELECT reloid FROM all_index) all_rels   JOIN pg_catalog.pg_class c             ON all_rels.reloid = c.oid   JOIN pg_catalog.pg_namespace n      ON c.relnamespace = n.oid   LEFT OUTER JOIN pg_catalog.pg_tablespace t        ON c.reltablespace = t.oid ORDER BY 1;

 

new databases:

Database: postgres

relname: pg_catalog.pg_largeobject: reloid: 2613 reltblspace:

relname: pg_catalog.pg_largeobject_loid_pn_index: reloid: 2683 reltblspace:

relname: pg_catalog.pg_largeobject_metadata: reloid: 2995 reltblspace:

relname: pg_catalog.pg_largeobject_metadata_oid_index: reloid: 2996 reltblspace:

 

Database: template1

relname: pg_catalog.pg_largeobject: reloid: 2613 reltblspace:

relname: pg_catalog.pg_largeobject_loid_pn_index: reloid: 2683 reltblspace:

relname: pg_catalog.pg_largeobject_metadata: reloid: 2995 reltblspace:

relname: pg_catalog.pg_largeobject_metadata_oid_index: reloid: 2996 reltblspace:

 

Checking for presence of required libraries                 ok

Checking database user is the install user                  executing: SELECT rolsuper, oid FROM pg_catalog.pg_roles WHERE rolname = current_user

executing: SELECT COUNT(*) FROM pg_catalog.pg_roles

ok

Checking for prepared transactions                          executing: SELECT * FROM pg_catalog.pg_prepared_xacts

ok

If pg_upgrade fails after this point, you must re-initdb the

new cluster before continuing.

 

Performing Upgrade

------------------

Analyzing all rows in the new cluster                       "/usr/local/pg95rc/bin/vacuumdb" --host "/usr/local/pg95rc/bin" --port 50432 --username "pgup" --all --analyze --verbose >> "pg_upgrade_utility.log" 2>&1

ok

Freezing all rows on the new cluster                        "/usr/local/pg95rc/bin/vacuumdb" --host "/usr/local/pg95rc/bin" --port 50432 --username "pgup" --all --freeze --verbose >> "pg_upgrade_utility.log" 2>&1

ok

executing: SELECT c.relname, c.relfilenode FROM pg_catalog.pg_class c,            pg_catalog.pg_namespace n WHERE         c.relnamespace = n.oid AND           n.nspname = 'pg_catalog' AND               c.relname = 'pg_database' ORDER BY c.relname

"/usr/local/pg95rc/bin/pg_ctl" -w -D "/usr/local/pg95rc/data/" -o ""  stop >> "pg_upgrade_server.log" 2>&1

Deleting files from new pg_clog                             ok

Copying old pg_clog to new server                           cp -Rf "/usr/local/pg91/data/pg_clog" "/usr/local/pg95rc/data/pg_clog" >> "pg_upgrade_utility.log" 2>&1

ok

Setting next transaction ID and epoch for new cluster       "/usr/local/pg95rc/bin/pg_resetxlog" -f -x 1821 "/usr/local/pg95rc/data" >> "pg_upgrade_utility.log" 2>&1

"/usr/local/pg95rc/bin/pg_resetxlog" -f -e 0 "/usr/local/pg95rc/data" >> "pg_upgrade_utility.log" 2>&1

"/usr/local/pg95rc/bin/pg_resetxlog" -f -c 1821,1821 "/usr/local/pg95rc/data" >> "pg_upgrade_utility.log" 2>&1

ok

Deleting files from new pg_multixact/offsets                ok

Setting oldest multixact ID on new cluster                  "/usr/local/pg95rc/bin/pg_resetxlog" -m 2,1 "/usr/local/pg95rc/data" >> "pg_upgrade_utility.log" 2>&1

ok

Resetting WAL archives                                      "/usr/local/pg95rc/bin/pg_resetxlog" -l 000000010000000000000002 "/usr/local/pg95rc/data" >> "pg_upgrade_utility.log" 2>&1

ok

"/usr/local/pg95rc/bin/pg_ctl" -w -l "pg_upgrade_server.log" -D "/usr/local/pg95rc/data/" -o "-p 50432 -b -c synchronous_commit=off -c fsync=off -c full_page_writes=off  -c listen_addresses='' -c unix_socket_permissions=0700 -c unix_socket_directories='/usr/local/pg95rc/bin'" start >> "pg_upgrade_server.log" 2>&1

Setting frozenxid and minmxid counters in new cluster       executing: UPDATE pg_catalog.pg_database SET         datfrozenxid = '1821'

executing: UPDATE pg_catalog.pg_database SET  datminmxid = '1'

executing: SELECT   datname, datallowconn FROM        pg_catalog.pg_database

executing: UPDATE pg_catalog.pg_class SET relfrozenxid = '1821' WHERE   relkind IN ('r', 'm', 't')

executing: UPDATE pg_catalog.pg_class SET relminmxid = '1' WHERE  relkind IN ('r', 'm', 't')

executing: ALTER DATABASE "template0" ALLOW_CONNECTIONS = true

executing: UPDATE pg_catalog.pg_class SET relfrozenxid = '1821' WHERE   relkind IN ('r', 'm', 't')

executing: UPDATE pg_catalog.pg_class SET relminmxid = '1' WHERE  relkind IN ('r', 'm', 't')

executing: ALTER DATABASE "template0" ALLOW_CONNECTIONS = false

executing: UPDATE pg_catalog.pg_class SET relfrozenxid = '1821' WHERE   relkind IN ('r', 'm', 't')

executing: UPDATE pg_catalog.pg_class SET relminmxid = '1' WHERE  relkind IN ('r', 'm', 't')

ok

Restoring global objects in the new cluster                 "/usr/local/pg95rc/bin/psql" --echo-queries --set ON_ERROR_STOP=on --no-psqlrc --dbname=template1 --host "/usr/local/pg95rc/bin" --port 50432 --username "pgup" -f "pg_upgrade_dump_globals.sql" >> "pg_upgrade_utility.log" 2>&1

ok

executing: SELECT d.oid, d.datname, d.encoding, d.datcollate, d.datctype, pg_catalog.pg_tablespace_location(t.oid) AS spclocation FROM pg_catalog.pg_database d  LEFT OUTER JOIN pg_catalog.pg_tablespace t  ON d.dattablespace = t.oid WHERE d.datallowconn = true ORDER BY 2

executing: WITH regular_heap (reloid) AS (   SELECT c.oid   FROM pg_catalog.pg_class c JOIN pg_catalog.pg_namespace n                       ON c.relnamespace = n.oid      LEFT OUTER JOIN pg_catalog.pg_index i                    ON c.oid = i.indexrelid          WHERE relkind IN ('r', 'm', 'i', 'S') AND             i.indisvalid IS DISTINCT FROM false AND                 i.indisready IS DISTINCT FROM false AND       ((n.nspname !~ '^pg_temp_' AND          n.nspname !~ '^pg_toast_temp_' AND              n.nspname NOT IN ('pg_catalog', 'information_schema',                                                                'binary_upgrade', 'pg_toast') AND                     c.oid >= 16384) OR            (n.nspname = 'pg_catalog' AND     relname IN ('pg_largeobject', 'pg_largeobject_loid_pn_index', 'pg_largeobject_metadata', 'pg_largeobject_metadata_oid_index') ))),          toast_heap (reloid) AS (     SELECT reltoastrelid       FROM regular_heap JOIN pg_catalog.pg_class c           ON regular_heap.reloid = c.oid                    AND c.reltoastrelid != 0),       all_index (reloid) AS (      SELECT indexrelid   FROM pg_index      WHERE indisvalid     AND indrelid IN (SELECT reltoastrelid         FROM (SELECT reloid FROM regular_heap          UNION ALL                              SELECT reloid FROM toast_heap) all_heap             JOIN pg_catalog.pg_class c             ON all_heap.reloid = c.oid             AND c.reltoastrelid != 0)) SELECT c.oid, n.nspname, c.relname,         c.relfilenode, c.reltablespace, pg_catalog.pg_tablespace_location(t.oid) AS spclocation FROM (SELECT reloid FROM regular_heap            UNION ALL           SELECT reloid FROM toast_heap              UNION ALL           SELECT reloid FROM all_index) all_rels   JOIN pg_catalog.pg_class c             ON all_rels.reloid = c.oid   JOIN pg_catalog.pg_namespace n      ON c.relnamespace = n.oid   LEFT OUTER JOIN pg_catalog.pg_tablespace t        ON c.reltablespace = t.oid ORDER BY 1;

executing: WITH regular_heap (reloid) AS (   SELECT c.oid   FROM pg_catalog.pg_class c JOIN pg_catalog.pg_namespace n                       ON c.relnamespace = n.oid      LEFT OUTER JOIN pg_catalog.pg_index i                    ON c.oid = i.indexrelid          WHERE relkind IN ('r', 'm', 'i', 'S') AND             i.indisvalid IS DISTINCT FROM false AND                 i.indisready IS DISTINCT FROM false AND       ((n.nspname !~ '^pg_temp_' AND          n.nspname !~ '^pg_toast_temp_' AND              n.nspname NOT IN ('pg_catalog', 'information_schema',                                                                'binary_upgrade', 'pg_toast') AND                     c.oid >= 16384) OR            (n.nspname = 'pg_catalog' AND     relname IN ('pg_largeobject', 'pg_largeobject_loid_pn_index', 'pg_largeobject_metadata', 'pg_largeobject_metadata_oid_index') ))),          toast_heap (reloid) AS (     SELECT reltoastrelid       FROM regular_heap JOIN pg_catalog.pg_class c           ON regular_heap.reloid = c.oid                    AND c.reltoastrelid != 0),       all_index (reloid) AS (      SELECT indexrelid   FROM pg_index      WHERE indisvalid     AND indrelid IN (SELECT reltoastrelid         FROM (SELECT reloid FROM regular_heap          UNION ALL                              SELECT reloid FROM toast_heap) all_heap             JOIN pg_catalog.pg_class c             ON all_heap.reloid = c.oid             AND c.reltoastrelid != 0)) SELECT c.oid, n.nspname, c.relname,         c.relfilenode, c.reltablespace, pg_catalog.pg_tablespace_location(t.oid) AS spclocation FROM (SELECT reloid FROM regular_heap            UNION ALL           SELECT reloid FROM toast_heap              UNION ALL           SELECT reloid FROM all_index) all_rels   JOIN pg_catalog.pg_class c             ON all_rels.reloid = c.oid   JOIN pg_catalog.pg_namespace n      ON c.relnamespace = n.oid   LEFT OUTER JOIN pg_catalog.pg_tablespace t        ON c.reltablespace = t.oid ORDER BY 1;

executing: WITH regular_heap (reloid) AS (   SELECT c.oid   FROM pg_catalog.pg_class c JOIN pg_catalog.pg_namespace n                       ON c.relnamespace = n.oid      LEFT OUTER JOIN pg_catalog.pg_index i                    ON c.oid = i.indexrelid          WHERE relkind IN ('r', 'm', 'i', 'S') AND             i.indisvalid IS DISTINCT FROM false AND                 i.indisready IS DISTINCT FROM false AND       ((n.nspname !~ '^pg_temp_' AND          n.nspname !~ '^pg_toast_temp_' AND              n.nspname NOT IN ('pg_catalog', 'information_schema',                                                                'binary_upgrade', 'pg_toast') AND                     c.oid >= 16384) OR            (n.nspname = 'pg_catalog' AND     relname IN ('pg_largeobject', 'pg_largeobject_loid_pn_index', 'pg_largeobject_metadata', 'pg_largeobject_metadata_oid_index') ))),          toast_heap (reloid) AS (     SELECT reltoastrelid       FROM regular_heap JOIN pg_catalog.pg_class c           ON regular_heap.reloid = c.oid                    AND c.reltoastrelid != 0),       all_index (reloid) AS (      SELECT indexrelid   FROM pg_index      WHERE indisvalid     AND indrelid IN (SELECT reltoastrelid         FROM (SELECT reloid FROM regular_heap          UNION ALL                              SELECT reloid FROM toast_heap) all_heap             JOIN pg_catalog.pg_class c             ON all_heap.reloid = c.oid             AND c.reltoastrelid != 0)) SELECT c.oid, n.nspname, c.relname,         c.relfilenode, c.reltablespace, pg_catalog.pg_tablespace_location(t.oid) AS spclocation FROM (SELECT reloid FROM regular_heap            UNION ALL           SELECT reloid FROM toast_heap              UNION ALL           SELECT reloid FROM all_index) all_rels   JOIN pg_catalog.pg_class c             ON all_rels.reloid = c.oid   JOIN pg_catalog.pg_namespace n      ON c.relnamespace = n.oid   LEFT OUTER JOIN pg_catalog.pg_tablespace t        ON c.reltablespace = t.oid ORDER BY 1;

 

new databases:

Database: benchmarksql

relname: pg_catalog.pg_largeobject: reloid: 2613 reltblspace:

relname: pg_catalog.pg_largeobject_loid_pn_index: reloid: 2683 reltblspace:

relname: pg_catalog.pg_largeobject_metadata: reloid: 2995 reltblspace:

relname: pg_catalog.pg_largeobject_metadata_oid_index: reloid: 2996 reltblspace:

 

Database: postgres

relname: pg_catalog.pg_largeobject: reloid: 2613 reltblspace:

relname: pg_catalog.pg_largeobject_loid_pn_index: reloid: 2683 reltblspace:

relname: pg_catalog.pg_largeobject_metadata: reloid: 2995 reltblspace:

relname: pg_catalog.pg_largeobject_metadata_oid_index: reloid: 2996 reltblspace:

 

Database: template1

relname: pg_catalog.pg_largeobject: reloid: 2613 reltblspace:

relname: pg_catalog.pg_largeobject_loid_pn_index: reloid: 2683 reltblspace:

relname: pg_catalog.pg_largeobject_metadata: reloid: 2995 reltblspace:

relname: pg_catalog.pg_largeobject_metadata_oid_index: reloid: 2996 reltblspace:

 

Restoring database schemas in the new cluster

"/usr/local/pg95rc/bin/pg_restore" --host "/usr/local/pg95rc/bin" --port 50432 --username "pgup" --exit-on-error --verbose --dbname "benchmarksql" "pg_upgrade_dump_16385.custom" >> "pg_upgrade_dump_16385.log" 2>&1

"/usr/local/pg95rc/bin/pg_restore" --host "/usr/local/pg95rc/bin" --port 50432 --username "pgup" --exit-on-error --verbose --dbname "postgres" "pg_upgrade_dump_12780.custom" >> "pg_upgrade_dump_12780.log" 2>&1

"/usr/local/pg95rc/bin/pg_restore" --host "/usr/local/pg95rc/bin" --port 50432 --username "pgup" --exit-on-error --verbose --dbname "template1" "pg_upgrade_dump_1.custom" >> "pg_upgrade_dump_1.log" 2>&1

                                                            ok

Setting minmxid counter in new cluster                      executing: UPDATE pg_catalog.pg_database SET         datminmxid = '1'

executing: SELECT   datname, datallowconn FROM        pg_catalog.pg_database

executing: ALTER DATABASE "template0" ALLOW_CONNECTIONS = true

executing: UPDATE pg_catalog.pg_class SET relminmxid = '1' WHERE  relkind IN ('r', 'm', 't')

executing: ALTER DATABASE "template0" ALLOW_CONNECTIONS = false

executing: UPDATE pg_catalog.pg_class SET relminmxid = '1' WHERE  relkind IN ('r', 'm', 't')

executing: UPDATE pg_catalog.pg_class SET relminmxid = '1' WHERE  relkind IN ('r', 'm', 't')

executing: UPDATE pg_catalog.pg_class SET relminmxid = '1' WHERE  relkind IN ('r', 'm', 't')

ok

Creating newly-required TOAST tables                        executing: SELECT n.nspname, c.relname FROM         pg_catalog.pg_class c,            pg_catalog.pg_namespace n WHERE     c.relnamespace = n.oid AND           n.nspname NOT IN ('pg_catalog', 'information_schema') AND c.relkind IN ('r', 'm') AND c.reltoastrelid = 0

executing: SELECT pg_catalog.binary_upgrade_set_next_toast_pg_class_oid('10'::pg_catalog.oid);

executing: ALTER TABLE "public"."pgbench_tellers" RESET (binary_upgrade_dummy_option);

executing: SELECT pg_catalog.binary_upgrade_set_next_toast_pg_class_oid('10'::pg_catalog.oid);

executing: ALTER TABLE "public"."pgbench_accounts" RESET (binary_upgrade_dummy_option);

executing: SELECT pg_catalog.binary_upgrade_set_next_toast_pg_class_oid('10'::pg_catalog.oid);

executing: ALTER TABLE "public"."pgbench_branches" RESET (binary_upgrade_dummy_option);

executing: SELECT pg_catalog.binary_upgrade_set_next_toast_pg_class_oid('10'::pg_catalog.oid);

executing: ALTER TABLE "public"."pgbench_history" RESET (binary_upgrade_dummy_option);

executing: SELECT n.nspname, c.relname FROM   pg_catalog.pg_class c,            pg_catalog.pg_namespace n WHERE         c.relnamespace = n.oid AND           n.nspname NOT IN ('pg_catalog', 'information_schema') AND c.relkind IN ('r', 'm') AND c.reltoastrelid = 0

executing: SELECT n.nspname, c.relname FROM   pg_catalog.pg_class c,            pg_catalog.pg_namespace n WHERE         c.relnamespace = n.oid AND           n.nspname NOT IN ('pg_catalog', 'information_schema') AND c.relkind IN ('r', 'm') AND c.reltoastrelid = 0

ok

executing: SELECT d.oid, d.datname, d.encoding, d.datcollate, d.datctype, pg_catalog.pg_tablespace_location(t.oid) AS spclocation FROM pg_catalog.pg_database d  LEFT OUTER JOIN pg_catalog.pg_tablespace t  ON d.dattablespace = t.oid WHERE d.datallowconn = true ORDER BY 2

executing: WITH regular_heap (reloid) AS (   SELECT c.oid   FROM pg_catalog.pg_class c JOIN pg_catalog.pg_namespace n                       ON c.relnamespace = n.oid      LEFT OUTER JOIN pg_catalog.pg_index i                    ON c.oid = i.indexrelid          WHERE relkind IN ('r', 'm', 'i', 'S') AND             i.indisvalid IS DISTINCT FROM false AND                 i.indisready IS DISTINCT FROM false AND       ((n.nspname !~ '^pg_temp_' AND          n.nspname !~ '^pg_toast_temp_' AND              n.nspname NOT IN ('pg_catalog', 'information_schema',                                                                'binary_upgrade', 'pg_toast') AND                     c.oid >= 16384) OR            (n.nspname = 'pg_catalog' AND     relname IN ('pg_largeobject', 'pg_largeobject_loid_pn_index', 'pg_largeobject_metadata', 'pg_largeobject_metadata_oid_index') ))),          toast_heap (reloid) AS (     SELECT reltoastrelid       FROM regular_heap JOIN pg_catalog.pg_class c           ON regular_heap.reloid = c.oid                    AND c.reltoastrelid != 0),       all_index (reloid) AS (      SELECT indexrelid   FROM pg_index      WHERE indisvalid     AND indrelid IN (SELECT reltoastrelid         FROM (SELECT reloid FROM regular_heap          UNION ALL                              SELECT reloid FROM toast_heap) all_heap             JOIN pg_catalog.pg_class c             ON all_heap.reloid = c.oid             AND c.reltoastrelid != 0)) SELECT c.oid, n.nspname, c.relname,         c.relfilenode, c.reltablespace, pg_catalog.pg_tablespace_location(t.oid) AS spclocation FROM (SELECT reloid FROM regular_heap            UNION ALL           SELECT reloid FROM toast_heap              UNION ALL           SELECT reloid FROM all_index) all_rels   JOIN pg_catalog.pg_class c             ON all_rels.reloid = c.oid   JOIN pg_catalog.pg_namespace n      ON c.relnamespace = n.oid   LEFT OUTER JOIN pg_catalog.pg_tablespace t        ON c.reltablespace = t.oid ORDER BY 1;

executing: WITH regular_heap (reloid) AS (   SELECT c.oid   FROM pg_catalog.pg_class c JOIN pg_catalog.pg_namespace n                       ON c.relnamespace = n.oid      LEFT OUTER JOIN pg_catalog.pg_index i                    ON c.oid = i.indexrelid          WHERE relkind IN ('r', 'm', 'i', 'S') AND             i.indisvalid IS DISTINCT FROM false AND                 i.indisready IS DISTINCT FROM false AND       ((n.nspname !~ '^pg_temp_' AND          n.nspname !~ '^pg_toast_temp_' AND              n.nspname NOT IN ('pg_catalog', 'information_schema',                                                                'binary_upgrade', 'pg_toast') AND                     c.oid >= 16384) OR            (n.nspname = 'pg_catalog' AND     relname IN ('pg_largeobject', 'pg_largeobject_loid_pn_index', 'pg_largeobject_metadata', 'pg_largeobject_metadata_oid_index') ))),          toast_heap (reloid) AS (     SELECT reltoastrelid       FROM regular_heap JOIN pg_catalog.pg_class c           ON regular_heap.reloid = c.oid                    AND c.reltoastrelid != 0),       all_index (reloid) AS (      SELECT indexrelid   FROM pg_index      WHERE indisvalid     AND indrelid IN (SELECT reltoastrelid         FROM (SELECT reloid FROM regular_heap          UNION ALL                              SELECT reloid FROM toast_heap) all_heap             JOIN pg_catalog.pg_class c             ON all_heap.reloid = c.oid             AND c.reltoastrelid != 0)) SELECT c.oid, n.nspname, c.relname,         c.relfilenode, c.reltablespace, pg_catalog.pg_tablespace_location(t.oid) AS spclocation FROM (SELECT reloid FROM regular_heap            UNION ALL           SELECT reloid FROM toast_heap              UNION ALL           SELECT reloid FROM all_index) all_rels   JOIN pg_catalog.pg_class c             ON all_rels.reloid = c.oid   JOIN pg_catalog.pg_namespace n      ON c.relnamespace = n.oid   LEFT OUTER JOIN pg_catalog.pg_tablespace t        ON c.reltablespace = t.oid ORDER BY 1;

executing: WITH regular_heap (reloid) AS (   SELECT c.oid   FROM pg_catalog.pg_class c JOIN pg_catalog.pg_namespace n                       ON c.relnamespace = n.oid      LEFT OUTER JOIN pg_catalog.pg_index i                    ON c.oid = i.indexrelid          WHERE relkind IN ('r', 'm', 'i', 'S') AND             i.indisvalid IS DISTINCT FROM false AND                 i.indisready IS DISTINCT FROM false AND       ((n.nspname !~ '^pg_temp_' AND          n.nspname !~ '^pg_toast_temp_' AND              n.nspname NOT IN ('pg_catalog', 'information_schema',                                                                'binary_upgrade', 'pg_toast') AND                     c.oid >= 16384) OR            (n.nspname = 'pg_catalog' AND     relname IN ('pg_largeobject', 'pg_largeobject_loid_pn_index', 'pg_largeobject_metadata', 'pg_largeobject_metadata_oid_index') ))),          toast_heap (reloid) AS (     SELECT reltoastrelid       FROM regular_heap JOIN pg_catalog.pg_class c           ON regular_heap.reloid = c.oid                    AND c.reltoastrelid != 0),       all_index (reloid) AS (      SELECT indexrelid   FROM pg_index      WHERE indisvalid     AND indrelid IN (SELECT reltoastrelid         FROM (SELECT reloid FROM regular_heap          UNION ALL                              SELECT reloid FROM toast_heap) all_heap             JOIN pg_catalog.pg_class c             ON all_heap.reloid = c.oid             AND c.reltoastrelid != 0)) SELECT c.oid, n.nspname, c.relname,         c.relfilenode, c.reltablespace, pg_catalog.pg_tablespace_location(t.oid) AS spclocation FROM (SELECT reloid FROM regular_heap            UNION ALL           SELECT reloid FROM toast_heap              UNION ALL           SELECT reloid FROM all_index) all_rels   JOIN pg_catalog.pg_class c             ON all_rels.reloid = c.oid   JOIN pg_catalog.pg_namespace n      ON c.relnamespace = n.oid   LEFT OUTER JOIN pg_catalog.pg_tablespace t        ON c.reltablespace = t.oid ORDER BY 1;

 

new databases:

Database: benchmarksql

relname: pg_catalog.pg_largeobject: reloid: 2613 reltblspace:

relname: pg_catalog.pg_largeobject_loid_pn_index: reloid: 2683 reltblspace:

relname: pg_catalog.pg_largeobject_metadata: reloid: 2995 reltblspace:

relname: pg_catalog.pg_largeobject_metadata_oid_index: reloid: 2996 reltblspace:

relname: public.pgbench_branches: reloid: 16386 reltblspace:

relname: public.pgbench_tellers: reloid: 16389 reltblspace:

relname: public.pgbench_accounts: reloid: 16392 reltblspace:

relname: public.pgbench_history: reloid: 16395 reltblspace:

relname: public.pgbench_branches_pkey: reloid: 16399 reltblspace:

relname: public.pgbench_tellers_pkey: reloid: 16401 reltblspace:

relname: public.pgbench_accounts_pkey: reloid: 16403 reltblspace:

 

Database: postgres

relname: pg_catalog.pg_largeobject: reloid: 2613 reltblspace:

relname: pg_catalog.pg_largeobject_loid_pn_index: reloid: 2683 reltblspace:

relname: pg_catalog.pg_largeobject_metadata: reloid: 2995 reltblspace:

relname: pg_catalog.pg_largeobject_metadata_oid_index: reloid: 2996 reltblspace:

 

Database: template1

relname: pg_catalog.pg_largeobject: reloid: 2613 reltblspace:

relname: pg_catalog.pg_largeobject_loid_pn_index: reloid: 2683 reltblspace:

relname: pg_catalog.pg_largeobject_metadata: reloid: 2995 reltblspace:

relname: pg_catalog.pg_largeobject_metadata_oid_index: reloid: 2996 reltblspace:

 

"/usr/local/pg95rc/bin/pg_ctl" -w -D "/usr/local/pg95rc/data/" -o ""  stop >> "pg_upgrade_server.log" 2>&1

Copying user relation files

mappings for database "benchmarksql":

pg_catalog.pg_largeobject: 12652 to 2613

pg_catalog.pg_largeobject_loid_pn_index: 12654 to 2683

pg_catalog.pg_largeobject_metadata: 12603 to 2995

pg_catalog.pg_largeobject_metadata_oid_index: 12605 to 2996

public.pgbench_branches: 16386 to 16386

public.pgbench_tellers: 16389 to 16389

public.pgbench_accounts: 16398 to 16392

public.pgbench_history: 16395 to 16395

public.pgbench_branches_pkey: 16399 to 16399

public.pgbench_tellers_pkey: 16401 to 16401

public.pgbench_accounts_pkey: 16403 to 16403

 

copying "/usr/local/pg91/data/base/16385/12652" to "/usr/local/pg95rc/data/base/16400/2613"

copying "/usr/local/pg91/data/base/16385/12654" to "/usr/local/pg95rc/data/base/16400/2683"

copying "/usr/local/pg91/data/base/16385/12603" to "/usr/local/pg95rc/data/base/16400/2995"

copying "/usr/local/pg91/data/base/16385/12605" to "/usr/local/pg95rc/data/base/16400/2996"

copying "/usr/local/pg91/data/base/16385/16386" to "/usr/local/pg95rc/data/base/16400/16386"

copying "/usr/local/pg91/data/base/16385/16386_fsm" to "/usr/local/pg95rc/data/base/16400/16386_fsm"

copying "/usr/local/pg91/data/base/16385/16389" to "/usr/local/pg95rc/data/base/16400/16389"

copying "/usr/local/pg91/data/base/16385/16389_fsm" to "/usr/local/pg95rc/data/base/16400/16389_fsm"

copying "/usr/local/pg91/data/base/16385/16398" to "/usr/local/pg95rc/data/base/16400/16392"

copying "/usr/local/pg91/data/base/16385/16398.1" to "/usr/local/pg95rc/data/base/16400/16392.1"

copying "/usr/local/pg91/data/base/16385/16398.2" to "/usr/local/pg95rc/data/base/16400/16392.2"

copying "/usr/local/pg91/data/base/16385/16398.3" to "/usr/local/pg95rc/data/base/16400/16392.3"

copying "/usr/local/pg91/data/base/16385/16398.4" to "/usr/local/pg95rc/data/base/16400/16392.4"

copying "/usr/local/pg91/data/base/16385/16398.5" to "/usr/local/pg95rc/data/base/16400/16392.5"

copying "/usr/local/pg91/data/base/16385/16398.6" to "/usr/local/pg95rc/data/base/16400/16392.6"

copying "/usr/local/pg91/data/base/16385/16398.7" to "/usr/local/pg95rc/data/base/16400/16392.7"

copying "/usr/local/pg91/data/base/16385/16398.8" to "/usr/local/pg95rc/data/base/16400/16392.8"

copying "/usr/local/pg91/data/base/16385/16398_fsm" to "/usr/local/pg95rc/data/base/16400/16392_fsm"

copying "/usr/local/pg91/data/base/16385/16395" to "/usr/local/pg95rc/data/base/16400/16395"

copying "/usr/local/pg91/data/base/16385/16399" to "/usr/local/pg95rc/data/base/16400/16399"

copying "/usr/local/pg91/data/base/16385/16401" to "/usr/local/pg95rc/data/base/16400/16401"

copying "/usr/local/pg91/data/base/16385/16403" to "/usr/local/pg95rc/data/base/16400/16403"

copying "/usr/local/pg91/data/base/16385/16403.1" to "/usr/local/pg95rc/data/base/16400/16403.1"

mappings for database "postgres":

pg_catalog.pg_largeobject: 12652 to 2613

pg_catalog.pg_largeobject_loid_pn_index: 12654 to 2683

pg_catalog.pg_largeobject_metadata: 12603 to 2995

pg_catalog.pg_largeobject_metadata_oid_index: 12605 to 2996

 

copying "/usr/local/pg91/data/base/12780/12652" to "/usr/local/pg95rc/data/base/13241/2613"

copying "/usr/local/pg91/data/base/12780/12654" to "/usr/local/pg95rc/data/base/13241/2683"

copying "/usr/local/pg91/data/base/12780/12603" to "/usr/local/pg95rc/data/base/13241/2995"

copying "/usr/local/pg91/data/base/12780/12605" to "/usr/local/pg95rc/data/base/13241/2996"

mappings for database "template1":

pg_catalog.pg_largeobject: 12652 to 2613

pg_catalog.pg_largeobject_loid_pn_index: 12654 to 2683

pg_catalog.pg_largeobject_metadata: 12603 to 2995

pg_catalog.pg_largeobject_metadata_oid_index: 12605 to 2996

 

copying "/usr/local/pg91/data/base/1/12652" to "/usr/local/pg95rc/data/base/1/2613"

copying "/usr/local/pg91/data/base/1/12654" to "/usr/local/pg95rc/data/base/1/2683"

copying "/usr/local/pg91/data/base/1/12603" to "/usr/local/pg95rc/data/base/1/2995"

copying "/usr/local/pg91/data/base/1/12605" to "/usr/local/pg95rc/data/base/1/2996"

                                                            ok

Setting next OID for new cluster                            "/usr/local/pg95rc/bin/pg_resetxlog" -o 16405 "/usr/local/pg95rc/data" >> "pg_upgrade_utility.log" 2>&1

ok

Sync data directory to disk                                 "/usr/local/pg95rc/bin/initdb" --sync-only "/usr/local/pg95rc/data" >> "pg_upgrade_utility.log" 2>&1

ok

Creating script to analyze new cluster                      ok

Creating script to delete old cluster                       ok

Upgrade Complete

----------------

Optimizer statistics are not transferred by pg_upgrade so,

once you start the new server, consider running:

    ./analyze_new_cluster.sh

 

Running this script will delete the old cluster's data files:

./delete_old_cluster.sh

在/user/local/pg95rc/bin目录下生成两个的两个脚本如下:

[pgup@minion1 bin]$ pwd

/usr/local/pg95rc/bin

[pgup@minion1 bin]$ ls

analyze_new_cluster.sh  dropdb    pg_archivecleanup  pg_dump         pg_restore      pg_xlogdump  vacuumlo

clusterdb               droplang  pg_basebackup      pg_dumpall      pg_rewind       postgres

createdb                dropuser  pgbench            pg_isready      pg_standby      postmaster

createlang              ecpg      pg_config          pg_receivexlog  pg_test_fsync   psql

createuser              initdb    pg_controldata     pg_recvlogical  pg_test_timing  reindexdb

delete_old_cluster.sh   oid2name  pg_ctl             pg_resetxlog    pg_upgrade      vacuumdb

启动PG9.5rc 并执行analyze_new_cluster.sh

[pgup@minion1 bin]$ ./pg_ctl -D ../data/ start

server starting

[pgup@minion1 bin]$ LOG:  redirecting log output to logging collector process

HINT:  Future log output will appear in directory "pg_log".

 

[pgup@minion1 bin]$ ./analyze_new_cluster.sh

This script will generate minimal optimizer statistics rapidly

so your system is usable, and then gather statistics twice more

with increasing accuracy.  When it is done, your system will

have the default level of optimizer statistics.

 

If you have used ALTER TABLE to modify the statistics target for

any tables, you might want to remove them and restore them after

running this script because they will delay fast statistics generation.

 

If you would like default statistics as quickly as possible, cancel

this script and run:

"/usr/local/pg95rc/bin/vacuumdb" --all --analyze-only

 

vacuumdb: processing database "benchmarksql": Generating minimal optimizer statistics (1 target)

vacuumdb: processing database "postgres": Generating minimal optimizer statistics (1 target)

vacuumdb: processing database "template1": Generating minimal optimizer statistics (1 target)

vacuumdb: processing database "benchmarksql": Generating medium optimizer statistics (10 targets)

vacuumdb: processing database "postgres": Generating medium optimizer statistics (10 targets)

vacuumdb: processing database "template1": Generating medium optimizer statistics (10 targets)

vacuumdb: processing database "benchmarksql": Generating default (full) optimizer statistics

vacuumdb: processing database "postgres": Generating default (full) optimizer statistics

vacuumdb: processing database "template1": Generating default (full) optimizer statistics

Done

连接PG95rc

[pgup@minion1 bin]$ ./psql -p 5432 -U pgup -d postgres

psql (9.5rc1)

Type "help" for help.

 

postgres=# l+

                                                                     List of databases

     Name     |    Owner     | Encoding |   Collate   |    Ctype    | Access privileges |  Size   | Tablespace |        

       Description                

--------------+--------------+----------+-------------+-------------+-------------------+---------+------------+---------

-----------------------------------

 benchmarksql | benchmarksql | UTF8     | en_US.UTF-8 | en_US.UTF-8 |                   | 10 GB   | pg_default |

 postgres     | pgup         | UTF8     | en_US.UTF-8 | en_US.UTF-8 |                   | 7384 kB | pg_default | default

administrative connection database

 template0    | pgup         | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/pgup          +| 7288 kB | pg_default | unmodifi

able empty database

              |              |          |             |             | pgup=CTc/pgup     |         |            |

 template1    | pgup         | UTF8     | en_US.UTF-8 | en_US.UTF-8 | pgup=CTc/pgup    +| 7384 kB | pg_default | default

template for new databases

              |              |          |             |             | =c/pgup           |         |            |

(4 rows)

postgres=# c benchmarksql

You are now connected to database "benchmarksql" as user "pgup".

benchmarksql=# d+

                            List of relations

 Schema |       Name       | Type  |    Owner     |  Size   | Description

--------+------------------+-------+--------------+---------+-------------

 public | pgbench_accounts | table | benchmarksql | 9147 MB |

 public | pgbench_branches | table | benchmarksql | 56 kB   |

 public | pgbench_history  | table | benchmarksql | 0 bytes |

 public | pgbench_tellers  | table | benchmarksql | 336 kB  |

(4 rows)

benchmarksql=# select * from pgbench_branches limit 5;

 bid | bbalance | filler

-----+----------+--------

   1 |        0 |

   2 |        0 |

   3 |        0 |

   4 |        0 |

   5 |        0 |

(5 rows)

执行delete_old_cluster.sh脚本

[pgup@minion1 bin]$ pwd

/usr/local/pg95rc/bin

删除PG9.1数据目录

[pgup@minion1 bin]$ ./delete_old_cluster.sh

[pgup@minion1 bin]$ cd /usr/local/pg91/

[pgup@minion1 pg91]$ ls

bin  include  lib  share

原文地址:https://www.cnblogs.com/songyuejie/p/5101747.html