Для работы с дампами БД следует пользоваться специальным скриптом dump.sh
, который, как правило, располагается в /opt/hydra/oracle/scripts/dump.sh
. Скрипт обязательно следует вызвать под пользователем oracle с инициализированным окружением. Инициализацию окружения для пользователя oracle с помощью sudo можно выполнить с помощью следующей команды:
$ su - oracle |
У данного скрипта для работы с БД существуют следующие варианты запуска:
/var/oradata/dumps
)./var/oradata/dumps
). После импортирования флаг "Признак промышленной базы данных" сбрасывается.Параметры вызова скрипта, которые предотвращают интерактивный ввод:
Пример вызова скрипта для переноса дампа БД с hydra на hydra2:
Снятие дампа с hydra:
$ ./dump.sh -i hydra -p ais_net -f hydra_dump export |
Очистка hydra2:
$ ./dump.sh -i hydra2 -p ais_net -s drop |
Поднятие дампа на hydra2:
$ ./dump.sh -i hydra2 -p ais_net -f hydra_dump import |
Во время импорта дампа в новую базу возможны ошибки следующего вида:
Failing sql is:
GRANT SELECT ON "AIS_NET"."SR_V_GOOD_SERVS" TO "NET_GOODS"
ORA-39083: Object type OBJECT_GRANT failed to create with error:
ORA-01917: user or role 'NET_GOODS' does not exist
Эти ошибки не являются критичными, т.к. скрипт экспорта выгружает только схему AIS_NET. Отсутствующие роли создаются в БД отдельным скриптом по окончании процедуры импорта.
Так как процедура снятия резервных копий с помощью утилиты expdp (скрипт |
Отмена незавешенного процесса дампа осуществляется с помощью CTRL-c и команды kill_job:
... . . exported "AIS_NET"."SS_JOB_LOGS" 635.2 MB 1550063 rows . . exported "AIS_NET"."SD_PROCESSING_REQUESTS_T" 563.8 MB 7204 rows . . exported "AIS_NET"."SD_MV_DOCUMENTS" 479.7 MB 3247473 rows ^C Export> kill_job Are you sure you wish to stop this job ([yes]/no): yes |