🧹 Bash совет дня: удаляем пустые директории рекурсивно 🧹
Когда на сервере скапливаются лишние пустые папки — это не только мусор, но и потенциальная головная боль при навигации и поиске. Вот простой способ зачистить их:
🔍 Как это работает:
• find ищет все папки (-type d), которые пусты (-empty) и удаляет их (-delete).
• Работает рекурсивно, удаляя даже вложенные пустые директории.
📅 Можно запускать из cron раз в неделю, например:
👌 Удобно, когда на сервере регулярно создаются временные папки, которые потом остаются без содержимого.
📲 Мы в MAX
👉@bash_srv
Когда на сервере скапливаются лишние пустые папки — это не только мусор, но и потенциальная головная боль при навигации и поиске. Вот простой способ зачистить их:
#!/bin/bash
# Путь, в котором нужно очистить пустые папки
TARGET_DIR="/var/www/html"
# Удаляем все пустые директории, включая вложенные
find "$TARGET_DIR" -type d -empty -delete
echo "✅ Все пустые директории удалены из $TARGET_DIR"
🔍 Как это работает:
• find ищет все папки (-type d), которые пусты (-empty) и удаляет их (-delete).
• Работает рекурсивно, удаляя даже вложенные пустые директории.
📅 Можно запускать из cron раз в неделю, например:
0 3 * * 0 /opt/noscripts/clean_empty_dirs.sh
👌 Удобно, когда на сервере регулярно создаются временные папки, которые потом остаются без содержимого.
📲 Мы в MAX
👉@bash_srv
👍6🔥1
🔥 Bash: выводим самые «тяжёлые» директории в системе 🧱
Когда место на диске заканчивается, надо быстро найти, кто его ест. Вот однострочник, который покажет 10 самых тяжёлых директорий в
📌 Пояснение:
•
•
•
💡 Хочешь только директории без файлов? Замени
🎯 Быстро, просто, эффективно!
📲 Мы в MAX
👉@bash_srv
Когда место на диске заканчивается, надо быстро найти, кто его ест. Вот однострочник, который покажет 10 самых тяжёлых директорий в
/:
du -ahx / | sort -rh | head -n 10
📌 Пояснение:
•
du -ahx / - оценивает размер всех файлов и директорий, игнорируя другие файловые системы (важно, если есть монтирования);•
sort -rh - сортирует по размеру, от большего к меньшему;•
head -n 10 - берёт топ-10.💡 Хочешь только директории без файлов? Замени
-ahx на -h --max-depth=1:
du -h --max-depth=1 / | sort -rh
🎯 Быстро, просто, эффективно!
📲 Мы в MAX
👉@bash_srv
👍4💩1
🧠 Регулярки на практике: как вытащить IP-адреса из логов
Когда нужно быстро достать все IP-адреса из логов — тебе на помощь приходит
Пример:
🔍 Что делает:
📌 Пример вывода:
🛡️ Хочешь избавиться от дубликатов?
📁 Подходит для Apache, Nginx, sshd и других логов, где есть IP.
📲 Мы в MAX
👉@bash_srv
Когда нужно быстро достать все IP-адреса из логов — тебе на помощь приходит
grep + регулярные выражения 💪Пример:
grep -oE '\b([0-9]{1,3}\.){3}[0-9]{1,3}\b' /var/log/nginx/access.log
🔍 Что делает:
-o — выводит только совпадения, без строки целиком-E — расширенные регулярки\b([0-9]{1,3}\.){3}[0-9]{1,3}\b — паттерн для IPv4📌 Пример вывода:
192.168.0.1
10.0.0.55
172.16.100.7
🛡️ Хочешь избавиться от дубликатов?
grep -oE '\b([0-9]{1,3}\.){3}[0-9]{1,3}\b' /var/log/nginx/access.log | sort -u
📁 Подходит для Apache, Nginx, sshd и других логов, где есть IP.
📲 Мы в MAX
👉@bash_srv
👍8
🔍 Поиск текста во множестве файлов — быстро и точно!
Если нужно найти, где в проекте встречается определённая строка (например,
📌 Пояснение:
*
*
*
*
💡 Хочешь исключить определённые директории, например
Незаменимо при отладке конфигов и аудите секрета в коде! 😉
📲 Мы в MAX
👉@bash_srv
Если нужно найти, где в проекте встречается определённая строка (например,
DB_PASSWORD), не лезь в каждый файл руками! Используй мощную связку grep:
grep -rnw '/путь/к/папке' -e 'DB_PASSWORD'
📌 Пояснение:
*
-r — рекурсивный поиск по подкаталогам.*
-n — показать номер строки.*
-w — искать точное слово (не подстроку).*
-e — указывает, что дальше идёт выражение для поиска.💡 Хочешь исключить определённые директории, например
.git?
grep -rnw --exclude-dir={.git,node_modules} '/путь/к/папке' -e 'DB_PASSWORD'
Незаменимо при отладке конфигов и аудите секрета в коде! 😉
📲 Мы в MAX
👉@bash_srv
👍7🔥5
🔐 Проверка пароля на сложность 🧪
Когда нужно быстро проверить, достаточно ли сложный пароль (длина, буквы, цифры, спецсимволы) — используйте вот такой bash-однострочник:
📋 Проверка включает:
- минимум 8 символов
- заглавные буквы
- строчные буквы
- цифры
- спецсимволы
🛡 Удобно использовать в скриптах или при создании новых пользователей вручную.
👀 Если хотите использовать это в скрипте без отображения ввода —
📲 Мы в MAX
👉@bash_srv
Когда нужно быстро проверить, достаточно ли сложный пароль (длина, буквы, цифры, спецсимволы) — используйте вот такой bash-однострочник:
read -s -p "Введите пароль: " pass; echo; [[ ${#pass} -ge 8 && "$pass" =~ [A-Z] && "$pass" =~ [a-z] && "$pass" =~ [0-9] && "$pass" =~ [^a-zA-Z0-9] ]] && echo "✅ Надёжный пароль" || echo "❌ Слабый пароль"
📋 Проверка включает:
- минимум 8 символов
- заглавные буквы
- строчные буквы
- цифры
- спецсимволы
🛡 Удобно использовать в скриптах или при создании новых пользователей вручную.
👀 Если хотите использовать это в скрипте без отображения ввода —
read -s уже всё делает за вас.📲 Мы в MAX
👉@bash_srv
👍6
🚀 Подборка полезных IT каналов в Max
Системное администрирование, DevOps 📌
https://max.ru/i_odmin Все для системного администратора
https://max.ru/bash_srv Bash Советы
https://max.ru/sysadminof Книги для админов, полезные материалы
https://max.ru/i_odmin_book Библиотека Системного Администратора
https://max.ru/i_devops DevOps: Пишем о Docker, Kubernetes и др.
1C разработка 📌
https://max.ru/odin1c_rus Cтатьи, курсы, советы, шаблоны кода 1С
Программирование C++📌
https://max.ru/cpp_lib Библиотека C/C++ разработчика
Программирование Python 📌
https://max.ru/python_of Python академия.
https://max.ru/BookPython Библиотека Python разработчика
Java разработка 📌
https://max.ru/bookjava Библиотека Java разработчика
GitHub Сообщество 📌
https://max.ru/githublib Интересное из GitHub
Базы данных (Data Base) 📌
https://max.ru/database_info Все про базы данных
Фронтенд разработка 📌
https://max.ru/frontend_1 Подборки для frontend разработчиков
Библиотеки 📌
https://max.ru/programmist_of Книги по программированию
https://max.ru/proglb Библиотека программиста
https://max.ru/bfbook Книги для программистов
Программирование 📌
https://max.ru/bookflow Лекции, видеоуроки, доклады с IT конференций
https://max.ru/itmozg Программисты, дизайнеры, новости из мира IT
https://max.ru/php_lib Библиотека PHP программиста 👨🏼💻👩💻
Шутки программистов 📌
https://max.ru/itumor Шутки программистов
Защита, взлом, безопасность 📌
https://max.ru/thehaking Канал о кибербезопасности
https://max.ru/xakkep_1 Хакер Free
Книги, статьи для дизайнеров 📌
https://max.ru/odesigners Статьи, книги для дизайнеров
Математика 📌
https://max.ru/Pomatematike Канал по математике
https://max.ru/phismat_1 Обучающие видео, книги по Физике и Математике
Вакансии 📌
https://max.ru/progjob Вакансии в IT
Мир технологий 📌
https://max.ru/mir_teh Канал для любознательных
Бонус 📌
https://max.ru/piterspb_78 Свежие новости Санкт-Петербурга
https://max.ru/mockva_life Свежие новости Москвы
Системное администрирование, DevOps 📌
https://max.ru/i_odmin Все для системного администратора
https://max.ru/bash_srv Bash Советы
https://max.ru/sysadminof Книги для админов, полезные материалы
https://max.ru/i_odmin_book Библиотека Системного Администратора
https://max.ru/i_devops DevOps: Пишем о Docker, Kubernetes и др.
1C разработка 📌
https://max.ru/odin1c_rus Cтатьи, курсы, советы, шаблоны кода 1С
Программирование C++📌
https://max.ru/cpp_lib Библиотека C/C++ разработчика
Программирование Python 📌
https://max.ru/python_of Python академия.
https://max.ru/BookPython Библиотека Python разработчика
Java разработка 📌
https://max.ru/bookjava Библиотека Java разработчика
GitHub Сообщество 📌
https://max.ru/githublib Интересное из GitHub
Базы данных (Data Base) 📌
https://max.ru/database_info Все про базы данных
Фронтенд разработка 📌
https://max.ru/frontend_1 Подборки для frontend разработчиков
Библиотеки 📌
https://max.ru/programmist_of Книги по программированию
https://max.ru/proglb Библиотека программиста
https://max.ru/bfbook Книги для программистов
Программирование 📌
https://max.ru/bookflow Лекции, видеоуроки, доклады с IT конференций
https://max.ru/itmozg Программисты, дизайнеры, новости из мира IT
https://max.ru/php_lib Библиотека PHP программиста 👨🏼💻👩💻
Шутки программистов 📌
https://max.ru/itumor Шутки программистов
Защита, взлом, безопасность 📌
https://max.ru/thehaking Канал о кибербезопасности
https://max.ru/xakkep_1 Хакер Free
Книги, статьи для дизайнеров 📌
https://max.ru/odesigners Статьи, книги для дизайнеров
Математика 📌
https://max.ru/Pomatematike Канал по математике
https://max.ru/phismat_1 Обучающие видео, книги по Физике и Математике
Вакансии 📌
https://max.ru/progjob Вакансии в IT
Мир технологий 📌
https://max.ru/mir_teh Канал для любознательных
Бонус 📌
https://max.ru/piterspb_78 Свежие новости Санкт-Петербурга
https://max.ru/mockva_life Свежие новости Москвы
MAX
Системный Администратор | Sysadmin Windows & Linux Server. Настройка Сети, ПК и Железа. IT Уроки для Сисадмина: Безопасность, Софт…
Блог практикующего админа. Настройка Windows Server, Active Directory (AD), GPO и терминальных серверов (RDP). Работа с Linux: Ubuntu, CentOS, Debian. Сетевое оборудование: Cisco, MikroTik, VPN, DNS, DHCP. Виртуализация (Hyper-V, VMware, Proxmox) и резервное…
🤡9💩4
🔐 Проверяем, у кого есть root-доступ через sudo
Иногда нужно быстро выяснить, какие пользователи могут выполнять команды от имени root через
📋 Что делает скрипт:
*
*
*
*
💡 Работает в Debian/Ubuntu - для других систем группу
🔥 Быстрый аудит - особенно полезно при подозрении на несанкционированный доступ.
📲 Мы в MAX
👉@bash_srv
Иногда нужно быстро выяснить, какие пользователи могут выполнять команды от имени root через
sudo. Вот простой способ это сделать:
getent group sudo | cut -d: -f4 | tr ',' '\n' | sort
📋 Что делает скрипт:
*
getent group sudo - вытаскивает строку группы sudo;*
cut -d: -f4 - берёт список пользователей;*
tr ',' '\n' - превращает список в столбик;*
sort — сортирует результат.💡 Работает в Debian/Ubuntu - для других систем группу
sudo нужно заменить на wheel, например:
getent group wheel | cut -d: -f4 | tr ',' '\n' | sort
🔥 Быстрый аудит - особенно полезно при подозрении на несанкционированный доступ.
📲 Мы в MAX
👉@bash_srv
👍5
🔄 Как узнать, какой процесс держит порт в Linux?
Часто бывает, что нужный порт уже занят, и надо быстро найти, кто его "захватил". Используем
📌 Вариант 1 — через
🔹 Пример:
📌 Вариант 2 — через
🔹 Пример:
🧠 А чтобы сразу получить PID:
🔹 Пример:
🔥 Идеально подходит, чтобы выяснить, что мешает стартовать nginx, apache, sshd и т.д.
📲 Мы в MAX
👉@bash_srv
Часто бывает, что нужный порт уже занят, и надо быстро найти, кто его "захватил". Используем
lsof и ss.📌 Вариант 1 — через
lsof:
lsof -i :<порт>
🔹 Пример:
lsof -i :80
📌 Вариант 2 — через
ss:
ss -tuln | grep :<порт>
🔹 Пример:
ss -tuln | grep :443
🧠 А чтобы сразу получить PID:
fuser <порт>/tcp
🔹 Пример:
fuser 22/tcp
🔥 Идеально подходит, чтобы выяснить, что мешает стартовать nginx, apache, sshd и т.д.
📲 Мы в MAX
👉@bash_srv
👍11
📌 Мониторинг процессов с высоким потреблением CPU
Скрипт, который покажет топ-5 процессов по загрузке CPU.
🔍 Что делает этот скрипт:
⚫️
⚫️
⚫️
💡 Можно повесить это на cron или закинуть в
📲 Мы в MAX
👉@bash_srv
Скрипт, который покажет топ-5 процессов по загрузке CPU.
ps -eo pid,comm,%cpu --sort=-%cpu | head -n 6
🔍 Что делает этот скрипт:
ps -eo pid,comm,%cpu — выводит PID, команду и использование CPU.--sort=-%cpu — сортирует по убыванию загрузки CPU.head -n 6 — берёт первые 5 процессов + строка заголовков.💡 Можно повесить это на cron или закинуть в
watch, чтобы отслеживать в реальном времени:
watch -n 5 'ps -eo pid,comm,%cpu --sort=-%cpu | head -n 6'
📲 Мы в MAX
👉@bash_srv
Please open Telegram to view this post
VIEW IN TELEGRAM
👍5❤1
🧠 Проверка, запущен ли процесс
Иногда нужно быстро проверить, работает ли нужный процесс — например,
📌 Как использовать:
Добавь это в свой
💡 Работает для процессов с точным именем. Хочешь более гибкий поиск — используй
📲 Мы в MAX
👉@bash_srv
Иногда нужно быстро проверить, работает ли нужный процесс — например,
nginx, postgres или любой другой. Вот удобная bash-функция:
check_proc() {
local PROC_NAME="$1"
if pgrep -x "$PROC_NAME" > /dev/null; then
echo "✅ Процесс '$PROC_NAME' запущен"
else
echo "❌ Процесс '$PROC_NAME' не найден"
fi
}
📌 Как использовать:
check_proc nginx
check_proc sshd
Добавь это в свой
~/.bashrc или ~/.bash_profile, чтобы всегда иметь под рукой 🔧💡 Работает для процессов с точным именем. Хочешь более гибкий поиск — используй
pgrep "$PROC_NAME" без -x.📲 Мы в MAX
👉@bash_srv
👍6
💥 Автоматическая блокировка IP при большом количестве запросов 🛡️👮♂️
Если на сервере замечена подозрительная активность (например, слишком много запросов от одного IP), можно автоматически блокировать таких «шумных» клиентов с помощью
📌 Что делает скрипт:
- Анализирует access.log
- Находит IP с количеством запросов > LIMIT
- Блокирует их через
🧠 Советы:
- Запускай раз в 5 минут через cron
- Убедись, что
📲 Мы в MAX
👉@bash_srv
Если на сервере замечена подозрительная активность (например, слишком много запросов от одного IP), можно автоматически блокировать таких «шумных» клиентов с помощью
iptables и awk:
#!/bin/bash
# автор: https://news.1rj.ru/str/bash_srv
# Лимит запросов за минуту
LIMIT=100
# Лог файл nginx или apache
LOG_FILE="/var/log/nginx/access.log"
# Найдём IP, превысившие лимит
awk '{print $1}' "$LOG_FILE" | sort | uniq -c | sort -nr | awk -v limit="$LIMIT" '$1 > limit {print $2}' | while read ip; do
# Проверим, не заблокирован ли уже
if ! iptables -L INPUT -v -n | grep -q "$ip"; then
iptables -A INPUT -s "$ip" -j DROP
echo "$(date): Заблокирован IP $ip" >> /var/log/ip_block.log
fi
done
📌 Что делает скрипт:
- Анализирует access.log
- Находит IP с количеством запросов > LIMIT
- Блокирует их через
iptables🧠 Советы:
- Запускай раз в 5 минут через cron
- Убедись, что
iptables доступен и ты не блокируешь свой IP 📲 Мы в MAX
👉@bash_srv
👍4❤1