1

В настоящее время я работаю над сценарием резервного копирования для входа на рабочий сервер и загрузки последних дампов SQL на промежуточный сервер. У меня нет проблем с извлечением дампов SQL, но у меня есть проблема с перемещением последних файлов резервной копии во временную папку.

Мой скрипт резервного копирования пользователь: mysqlBackupUser

Я использую домашний каталог этого пользователя в качестве места для этого скрипта и для хранения резервных копий. Структура папок:

/home
   |- mysqlBackupUser
       |- .ssh
       |- backups
       |- bin

Мой скрипт находится в bin и резервные копии загружаются в каталог backups

В каталоге backups также есть другие папки для организации сервера и типа резервных копий. IE:

/backups
   |-mysql
       |- production1
       |- production2
   |-misc
       |- production1
       |- production2

Пока все нормально и работает как положено. Проблема в том, когда я нахожусь (не ограничиваясь):

/home/mysqlBackupUser/backups/mysql/production1/

когда я создаю каталог tmp с именем _lastBackUp и пытаюсь переместить в него мои предыдущие резервные копии, я получаю:

find: Failed to change directory: Permission denied

Мой код для этого:

local tmpBackUpDir="${LOCAL_LOCATION_DIR}/_lastBackUp/"

# Ensure the directory exist
mkdir -p "${tmpBackUpDir}"

# move any previous files to bak
find "${LOCAL_LOCATION_DIR}/" -type f -exec mv -t "${LOCAL_BAKUP_DIR}" {} \+;;

Для ясности:

LOCAL_LOCATION_DIR = /home/mysqlBackupUser/backups/mysql/production1
tmpBackUpDir = /home/mysqlBackupUser/backups/mysql/production1/_lastBackUp/

Чтобы понять, как используется скрипт: в настоящее время я являюсь моим пользователем и

sudo su mysqlBackupUser

Быть как пользователь. Я не уверен, что это проблема, и я не могу проверить, войдя в систему как этот пользователь. Сценарий будет запускаться cron, и он будет действовать как этот пользователь (ключи настроены так, чтобы упростить автоматизацию для этого пользователя), чтобы выполнить процесс, поэтому я не уверен, что это действительно проблема.

Я проверил, что владельцем и разрешением всех папок, даже _lastBackUp является mysqlBackupUser . Я даже установил _lastBackUp на 777 для тестирования и все еще получил отказано в разрешениях ...

Моя полная ошибка:

find: Failed to change directory: Permission denied
find: Failed to change directory: Permission denied
find: Failed to change directory: Permission denied
find: Failed to change directory: Permission denied
find: Failed to change directory: Permission denied
find: Failed to change directory: Permission denied
find: Failed to change directory: Permission denied
find: Failed to change directory: Permission denied
find: Failed to change directory: Permission denied
find: failed to restore initial working directory: Permission denied

Каждая find: Failed to change directory: Permission denied в доступе для каждого файла, который я пытаюсь переместить в _lastBackUp

Спасибо за понимание этого.

2 ответа2

2

Похоже, ошибка в том, что у вас нет прав на изменение каталога.

  • убедитесь, что у пользователя есть по крайней мере r-x в каждой папке, ведущей вниз к пути, из которого выполняется скрипт.
  • убедитесь, что у пользователя есть хотя бы rwx в папке + файлы, в которых находятся резервные копии.
  • проверьте, есть ли у пользователя оболочка входа в систему, $HOME и $PATH . Если да, перед началом работы сделайте сценарий cd в каком-либо соответствующем месте. Если нет, определите все команды и местоположения, используя абсолютные пути.

Я не могу придумать какие-либо другие возможные причины.

0

Если mkdir работает, то, как кажется, если вы запускаете ls -al над родительским каталогом, который является владельцем этих каталогов? Мне кажется, что что-то не так с разрешениями где-то вниз по линии.

Всё ещё ищете ответ? Посмотрите другие вопросы с метками .