Вы просматриваете старую версию данной страницы. Смотрите текущую версию.

Сравнить с текущим просмотр истории страницы

« Предыдущий Версия 2 Следующий »

Данная статья применима к:

  • Astra Linux Special Edition РУСБ.10015-01 (очередное обновление 1.7)
  • Astra Linux Special Edition РУСБ.10152-02 (очередное обновление 4.7)
  • Astra Linux Special Edition РУСБ.10015-01 (очередное обновление 1.6)
  • Astra Linux Special Edition РУСБ.10015-16 исп. 1 и исп. 2
  • Astra Linux Special Edition РУСБ.10265-01 (очередное обновление 8.1)
  • Astra Linux Common Edition 2.12

Тестовый пример

При написании статьи использовалась Astra Linux Special Edition РУСБ.10015-01 (очередное обновление 1.7) с установленной СУБД PostgreSQL 11. Установка СУБД выполнялась при установке 1С в соответствии с инструкцией Установка и настройка сервера 1С v8.3.17 на ОС Astra Linux. В качестве базы данных (БД) использовалась предоставляемая разработчиками стандартная тестовая БД dvdrental, описанная в статье PostgreSQL Sample Database.

Для создания тестовой БД в PostgreSQL:

  1. Загрузить архив с тестовой БД командой:

  2. Распаковать архив:

    unzip dvdrental.zip
    В результате распаковки будет создан файл dvdrental.tar;

  3. Опционально, для удобства работы, чтобы не вводить каждый раз пароль, настроить права доступа. Работу с БД без ввода пароля можно обеспечить следующими способами:
    1. Создать файл .pgpass, содержащий сроки, задающие пароли доступа. Каждая стока имеет вид:

      <имя_или_IP-адрес_хоста>:<IP-порт>:<имя_БД>:<имя_пользователя>:<пароль_пользователя>

      Например:

      localhost:5432:dvdrental:postgres:пароль

      Файл должен иметь маску прав доступа 600, иначе он будет игнорироваться. Создать файл можно с помощью любого текстового редактора, или, например, командами:

      touch .pgpass
      chmod 600 ~/.pgpass
      echo "localhost:5432:*:postgres:q2w2e2r2" > .pgpass
      Допускается использование метасимвола "*" для обозначения любого значения;

    2. Использовать команду sudo (sudo -u postgresql) чтобы команды работы с БД выполнялись от имени пользователя postgresql. Например:

      sudo -u postgres psql -c 'CREATE DATABASE dvdrental;'
      При этом для загрузки архива БД в БД PostrgeSQL пользователю postgres должен быть предоставлен доступ на чтение  информации из архива БД.  Для предоставления такого доступа можно использовать следующие команды (предполагается, что все файлы находятся в домашнем каталоге):
      setfacl -m u:postgres:rx $HOME
      setfacl -m u:postgres:r dvdrental.tar
      Подробнее про использование команды setfacl см. Списки управления доступом к файловым объектам (ACL) в Astra Linux.

    3. Использовать явное указание пароля при указании БД (небезопасно), например:

      pg_dump --dbname=postgresql://postgres:пароль@localhost:5432/dvdrental

  4. Создать пустую БД в PostgreSQL командой:

    postgres psql -c 'CREATE DATABASE dvdrental;'

  5. Загрузить архив тестовой БД в БД PostgreSQL. Команда:

    pg_restore -U postgres -d dvdrental dvdrental.tar

    Указанная команда фактически является командой восстановления БД из архива.

Создание резервной копии базы данных

Для сохранения резервных копий БД в основном используются две команды:

  • pg_dump - выгрузка указанной БД;
  • pg_dumpall - выгрузка всех БД.

Сохранение может выполняться в тестовом формате или в формате архива.

Примеры использования:

  1. Сохранение всех БД в текстовом формате:

    pg_dumpall -h localhost -U postgres -f postgresql_dump

  2. Сохранения тестовой БД dvdrental в формате архива:

    pg_dump -h localhost -U postgres -f dvdrental_dump.tar -F tar

Загрузка резервной копии базы данных

Перед загрузкой резервной копии содержимое БД должно быть очищено. Сделать это можно удалив и заново создав БД:

psql -c 'DROP DATABASE dvdrental;'
psql -c 'CREATE DATABASE dvdrental;'

Загрузка БД, сохраненной в текстовом формате:

psql -U postgres dvdrental < dvdrental_dump
Загрузка БД, сохраненной в формате архива:
pg_restore -U postgres -d dvdrental dvdrental_dump
Подробная справка по всем командам доступна в справочной системе MAN.

  • Нет меток