Резервное копирование и восстановление базы 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 .