(перенаправлено с «0000100104»)

Вопросы:Перенос БД на ОС отличные от Linux Astra SE

Материал из Юпитер-8

!!!ВНИМАНИЕ!!!
В случае, когда для проверки запуска PostgreSQL, был использован наш скрипт, в дальнейшем команда start/stop/restart для smpo-server будет иметь вид:

service smpo-server start/stop/restart

!!!ВНИМАНИЕ!!
Данный алгоритм так же используется при переносе БД между ОС Astra SE 1.6 и 1.7, так как механизмы мандатных меток в этих версиях обличаются.


  В ПО КРОС уже встроен механизм резервного копирования. Однако иногда возникает необходимость переноса базы данных на ОС отличную от Linux Astra SE или между версиями ОС Astra Linux.
  В связи с тем, что данная ОС выставляет мандатные метки, восстановление базы данных на компьютерах с ОС их не поддерживающих, затруднительно.
  В этом случае необходимо воспользоваться утилитами postgresql из терминала.

На основном компьютере необходимо выполнить:

  1. Необходимо выйти из АРМ и остановить smpo-server : sudo systemctl stop smpo-server, либо sudo service smpo-server stop
  2. Проверяем: завершились ли процессы - ps -aux | grep java
  3. Если процессы не завершились, делаем принудительное завершение: sudo kill -9 <номер процесса>
  4. Перед созданием резервной копии рекомендуется сделать обслуживание БД.
  5. Далее делаем копию базы с отключением мандатных меток: sudo pg_dump -U postgres -h localhost -Fp --disable-macs --no-security-labels jupiter > /home/elesta/jupiter.sql. Каталог назначения для бэкапа определяет пользователь.
     Необходимо будет ввести пароль пользователя СУБД postgres.
  6. Копируем файл jupiter.sql из каталога /home/elesta на внешний носитель и переносим на новый компьютер. Каталог назначения для бэкапа определяет пользователь.
  7. Запустить КРОС для дальнейшей работы, если необходимо: sudo service smpo-server start

Дейстия на целевом компьютере:

  1. Необходимо выйти из АРМ и остановить smpo-server : sudo systemctl stop smpo-server, либо sudo service smpo-server stop
  2. Проверяем: завершились ли процессы - ps -aux | grep java
  3. Если процессы не завершились, делаем принудительное завершение: sudo kill -9 <номер процесса>
  4. Удалить существующую БД: sudo -u postgres psql -c "DROP DATABASE jupiter;"
  5. Создать чистую БД: sudo -u postgres psql -c "CREATE DATABASE jupiter;"
  6. Восстановление базы возможно из утилиты pgAdmin или в командной строке: sudo psql -h localhost -U postgres -d jupiter < /home/elesta/jupiter.sql. 
     Необходимо будет ввести пароль пользователя СУБД postgres.
    Ещё раз напоминаем, что при восстановлении БД база jupiter должна быть создана и пустой.
  7. Для запуска ПО необходимо выполнить: sudo systemctl start smpo-server, либо sudo service smpo-server start


В начало статьи