Поддержка абонентов: support@thehost.ua
Ваши отзывы и предложения: #feedback

8.10. Поиск с помощью find

В командной строке очень удобно выполнять поиск файлов и папок с помощью команды find

Поиск файлов по имени
find /var/www/ -name "file.conf" find /var/www/ -name "*.conf"

Поиск без учёта регистра:
find /var/www/ -iname file.conf

Поиск по размеру файлов
find /home/user -size +10M

Поиск по маске прав
find ./ -perm 700

Поиск по дате
Файлы созданные или изменённые в течении последних 5 дней
find /home/user -type f -mtime -5

Файлы созданные или изменённые в течении последних 5 минут
find /home/user -type f -mmin -5

Найти файлы созданные или изменённые старше 30 дней (ака поиск устаревших файлов):
find /path -type f -mtime +30

Удалить файлы созданные или изменённые старше 30 дней:
find /path -type f -mtime +30 -delete

Время последнего обращения к которым более 5 дней
find /usr/bin -type f -atime +5

Дополнительный возможности использования
Поиск строки в файлах
find ./ -type f -exec grep -i -H "STRING" {} \;

Найти все файлы php в который встречается строка STRING:
find ./ -type f -name "*.php" -exec grep -i -H "STRING" {} \;

Так же можно использовать команду grep с опцией -R для поиска файлов по содержимому:
grep "STRING" -R /path/for/find

Замена текста в файлах
find ./ -type f -name "*.conf" -exec sed -i s/OLDTEXT/NEWTEXT/g {} \;

Массовое изменения прав доступа
Установка прав доступа 644 на все файлы в текущей директории и всех поддиректориях:
find ./ -type f -exec chmod 644 {} \;

Установка прав доступа 755 на все папки в текущей директории и всех поддиректориях:
find ./ -type d -exec chmod 755 {} \;

Поиск всех файлов html, содержащих код "0;URL=http" и установка для них всех прав 000 (полезно для поиска вредоносного кода):
find /var/www/tofikime/data/ -type f -name "*.html" -exec grep -i -H "0;URL=http" {} \; -exec chmod -R 000 {} \;

Поиск всех php файлов в указанном каталоге wp-content/uploads до 3-х вложений всех пользователей всех сайтов сервера и установка им всем прав 000

find /var/www/*/data/www/*/wp-content/uploads/*/*/*.php -exec chmod -R 000 {} \;