Отказано в доступе при попытке mv (sudo su userName)

В настоящее время я работаю над сценарием резервного копирования для входа на рабочий сервер и загрузки последних дампов 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 ответа

Решение

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

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

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

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

Другие вопросы по тегам