Отказано в доступе при попытке 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 над родительским каталогом, который является владельцем этих каталогов? Мне кажется, что что-то не так с разрешениями где-то вниз по линии.