Пост

Резервное копирование и восстановление базы PostgreSQL. Полезные команды

PostgreSQL — свободная объектно-реляционная система управления базами данных. Существует в реализациях для множества UNIX-подобных платформ.

Резервное копирование базы PostgreSQL (Backup)

1
$ pg_dump --host localhost --port 5432 --username "postgres" --role "postgres" --no-password --format tar --blobs --encoding UTF8 --verbose --file /home/backup/postgres.dump "dbname"

или можно так

1
$ pg_dump -U user dbname > /home/backup/postgres.dump

Восстановление базы PostgreSQL (Restore)

1
$ /usr/pgsql-9.6/bin/pg_restore -U postgres -d dbname /home/backup/postgres.dump

или можно так

Переключаемся на пользователя postgres

1
$ sudo su - postgres

Восстанавливаем

1
$ psql -h localhost -U postgres -p 5432 dbname < /home/backup/postgres.dump

Полезные команды при работе с PostgreSQL в консоле

Создать пользователя и базу:

Переключаемся на пользователя postgres и запускаем psql

1
2
$ sudo su - postgres
$ psql

Создаем базу dbname, создаем пользователя dbuser с паролем pass, назначаем привилегии и выходим

1
2
3
4
=# create database dbname with encoding='UNICODE';
=# create user dbuser with password 'pass';
=# grant all privileges on database dbname to dbuser;
=# \q

Ставим пароль на пользователя postgres

Переключаемся на пользователя postgres и запускаем psql

1
2
$ sudo su - postgres
$ psql

Задаем пароль и выходим

1
2
3
4
=# \password
Enter new password: postgres
Enter it again: postgres
=# \q

Либо можно так:

1
2
=# ALTER ROLE postgres WITH PASSWORD 'postgres';
=# \q

Перезагрузить конфиг postgresql без перезапуска службы

Переключаемся на пользователя postgres

1
$ sudo su - postgres

Перезагружаем конфиг

1
$ /usr/pgsql-9.6/bin/pg_ctl reload

Еще команды для работы с PostgreSQL

Выбрать базу dbname

1
$ psql -d dbname

Посмотреть колонки

1
=# \d

Выводит список пользователей базы данных

1
=# \du

Выводит список схем

1
=# \dn

Выводит список баз данных на сервере и показывает их имена, владельцев, кодировку набора символов и права доступа

1
=# \l
Авторский пост защищен лицензией CC BY 4.0 .

© IT Draft. Некоторые права защищены.