Шпаргалка по работе в консоли PostgreSQL

Решил написать небольшую шпаргалку по работе в консоли с PostgreSQL. Последнее время всё чаще и чаще приходится иметь с ней дело по двум причинам:

Углубленный онлайн-курс по MikroTik

Научиться настраивать MikroTik с нуля или систематизировать уже имеющиеся знания можно на углубленном онлайн-курcе по администрированию MikroTik. Автор курcа – сертифицированный тренер MikroTik Дмитрий Скоромнов. Более 40 лабораторных работ по которым дается обратная связь. В три раза больше информации, чем в MTCNA.
Реклама ИП Скоромнов Д.А. ИНН 331403723315
  1. Все новые установки Zabbix Server делаю на postgresql.
  2. Намного чаще стали использовать postgresql в связке с 1С.

PostgreSQL создаёт отдельного пользователя Linux postgres, так что все команды буду делать с указанием этого пользователя. Я обычно работаю так, хотя никто не мешает сразу авторизоваться под ним и запускать команды напрямую. Второй момент - в зависимости от дистрибутива и пакета установки, бинарники postgresql могут находиться в разных местах и не всегда переменная path будет применена. Так что может понадобиться полный путь к исполняемому файлу (pg_dump, psql и т.д.).

Просмотр списка баз:

# sudo -u postgres psql -U postgres -l

Создание текстового дампа базы данных:

# sudo -u postgres pg_dump -U postgres basa01 > ~/basa01.sql

Сжимаем дамп на лету с помощью pigz (умеет жать всеми ядрами):

# sudo -u postgres pg_dump -U postgres basa01 | pigz > ~/basa01.sql.gz

Восстановление базы данных в новую базу (сначала создаём её):

# sudo -u postgres createdb -U postgres -T template0 basa02
# sudo -u postgres psql -U postgres basa02 < ~/basa01.sql

Для автоматических бэкапов могу порекомендовать бесплатную программу SQLBackupAndFTP.

Выход из консоли psql (часто забываю):

$ \q

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

# sudo -u postgres createuser -U postgres zabbix

Задать пароль:

# sudo -u postgres psql -U postgres -c "ALTER USER zabbix PASSWORD 'secpasswd'"

Посмотреть список пользователей:

# sudo -u postgres psql -U postgres -c "select * from pg_user"

Дать полные права на базу:

# sudo -u postgres psql -U postgres -c "GRANT ALL PRIVILEGES ON DATABASE zabbixdb to zabbix"

Назначить пользователя владельцем базы:

# sudo -u postgres psql -U postgres -c "ALTER DATABASE zabbixdb OWNER TO zabbix"

Выполнить очистку (-f) и анализ (-z) базы данных Postgres Pro:

# sudo -u postgres vacuumdb -U postgres -f -z -d basa01

Переиндексировать базу:

# sudo -u postgres reindexdb -U postgres -d basa01

Удалить базу данных:

# sudo -u postgres psql -U postgres -c "DROP DATABASE basa01"

Автор Zerox

Владимир, системный администратор, автор сайта. Люблю настраивать сервера, изучать что-то новое, делиться знаниями, писать интересные и полезные статьи. Открыт к диалогу и сотрудничеству. Если вам интересно узнать обо мне побольше, то можете послушать интервью. Запись на моем канале - https://t.me/srv_admin/425 или на сайте в контактах.

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *

Нажимая кнопку "Отправить комментарий" Я даю согласие на обработку персональных данных.
Используешь Telegram? Подпишись на канал автора →
This is default text for notification bar