🔥 Убиваем процесс по порту в один клик
Когда нужно быстро освободить занятый порт, но неохота копаться в
Теперь можно просто вызвать:
💡 Этот алиас использует
⚠️ Убедись, что
🚀 Удобно для Dev-серверов, где постоянно перезапускаешь сервисы и ловишь ошибку "Address already in use".
👉@bash_srv
Когда нужно быстро освободить занятый порт, но неохота копаться в
lsof и kill, вот простой и мощный однострочник:
fport() { fuser -k "$1"/tcp; }
Теперь можно просто вызвать:
fport 8080
💡 Этот алиас использует
fuser, чтобы найти и завершить все процессы, прослушивающие указанный TCP-порт.⚠️ Убедись, что
fuser установлен (обычно он входит в пакет psmisc):
sudo apt install psmisc # для Debian/Ubuntu
sudo yum install psmisc # для RHEL/CentOS
🚀 Удобно для Dev-серверов, где постоянно перезапускаешь сервисы и ловишь ошибку "Address already in use".
👉@bash_srv
👍5🤔2
📌 Регулярки — Ищем email-адреса в тексте
Надо быстро вытащить email-адреса из логов или текстов? Лови универсальное регулярное выражение:
📦 Примеры использования:
🎯 Оно находит валидные email'ы вроде:
- support@domain.com
- test.user+admin@sub.domain.co
⚙️ Флаг
📥 Используй для анализа логов, дампов или выгрузок из баз.
👉@bash_srv
Надо быстро вытащить email-адреса из логов или текстов? Лови универсальное регулярное выражение:
grep -Eo '[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}'
📦 Примеры использования:
cat файл.txt | grep -Eo '[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}'
🎯 Оно находит валидные email'ы вроде:
- support@domain.com
- test.user+admin@sub.domain.co
⚙️ Флаг
-o в grep выводит только совпадения, без строк целиком.📥 Используй для анализа логов, дампов или выгрузок из баз.
👉@bash_srv
👍9
🧠 Логи — Самые частые IP-адреса в access.log
Когда нужно быстро понять, кто чаще всего лупит по серверу — вот простой однострочник:
🔍 Что делает:
1.
2.
3.
📊 Вывод будет примерно такой:
🔥 Подходит для NGINX, Apache и других web-логов с классическим форматом.
👉@bash_srv
Когда нужно быстро понять, кто чаще всего лупит по серверу — вот простой однострочник:
awk '{print $1}' /var/log/nginx/access.log | sort | uniq -c | sort -nr | head
🔍 Что делает:
1.
awk '{print $1}' — вытаскивает IP из первой колонки.2.
sort и uniq -c — считает повторы.3.
sort -nr | head — выводит топ-10 по частоте.📊 Вывод будет примерно такой:
152 192.168.1.10
103 203.0.113.45
87 172.16.0.5
🔥 Подходит для NGINX, Apache и других web-логов с классическим форматом.
👉@bash_srv
👍12🔥2
🚀 Полезный Bash-скрипт: Уведомление о перезагрузке сервера 🔔
Иногда нужно предупредить пользователей, что сервер будет перезагружен, особенно если они работают в терминале. Ниже скрипт, который отправит им сообщение и задаст таймер на перезагрузку:
📌
💡Можно обернуть это в cron или systemd-таймер — и будет готовый инструмент для автоматических уведомлений и перезагрузок.
👉@bash_srv
Иногда нужно предупредить пользователей, что сервер будет перезагружен, особенно если они работают в терминале. Ниже скрипт, который отправит им сообщение и задаст таймер на перезагрузку:
#!/bin/bash
TIMEOUT=5 # Через сколько минут будет перезагрузка
MESSAGE="⚠️ Внимание! Сервер будет перезагружен через $TIMEOUT минут. Пожалуйста, сохраните свою работу."
# Оповестим всех пользователей
wall "$MESSAGE"
# Поставим таймер на перезагрузку
shutdown -r +$TIMEOUT "Плановая перезагрузка сервера через $TIMEOUT минут"
📌
wall рассылает сообщение всем, у кого открыт терминал, а shutdown -r запланирует перезагрузку. Всё просто и эффективно.💡Можно обернуть это в cron или systemd-таймер — и будет готовый инструмент для автоматических уведомлений и перезагрузок.
👉@bash_srv
👍7🔥3🤔1
🚀 Полезный Bash-скрипт: Очистка кэша пакетного менеджера APT 🧹
Иногда кэш пакетов APT разрастается и занимает лишнее место. Ниже написал простой скрипт, который поможет автоматизировать очистку и освободить дисковое пространство 💾
📌 Как использовать:
1. Сохрани как
2. Сделай исполняемым:
3. Запускай по необходимости или добавь в
Полезно для серверов с ограниченным дисковым пространством или если хочется держать систему в чистоте 😎
👉@bash_srv
Иногда кэш пакетов APT разрастается и занимает лишнее место. Ниже написал простой скрипт, который поможет автоматизировать очистку и освободить дисковое пространство 💾
#!/bin/bash
# Очищаем кэш APT
echo "🧼 Очистка кэша APT..."
sudo apt clean
sudo apt autoclean
# Удаляем неиспользуемые пакеты
echo "🗑 Удаление неиспользуемых пакетов..."
sudo apt autoremove -y
# Отчёт о свободном месте
echo "📊 Свободное место после очистки:"
df -h /
📌 Как использовать:
1. Сохрани как
clean_apt.sh2. Сделай исполняемым:
chmod +x clean_apt.sh3. Запускай по необходимости или добавь в
cronПолезно для серверов с ограниченным дисковым пространством или если хочется держать систему в чистоте 😎
👉@bash_srv
👍12🥴2
🚀 Bash-совет дня: Быстрый мониторинг TCP/UDP портов
Иногда нужно оперативно узнать, какие порты слушает сервер и какие подключения активны. Вот простой однострочник, который поможет:
📌 Пояснение ключей:
-
-
-
-
-
🔍 Хочешь отсортировать по порту или найти конкретный? Добавь
🎯 Альтернатива на случай, если нет
Полезно для отладки фаервола, проверки работы сервисов или просто для уверенности, что сервер не слушает ничего лишнего 😉
👉@bash_srv
Иногда нужно оперативно узнать, какие порты слушает сервер и какие подключения активны. Вот простой однострочник, который поможет:
sudo ss -tunlp
📌 Пояснение ключей:
-
-t — TCP -
-u — UDP -
-n — не разрешать имена хостов и портов (быстрее) -
-l — только слушающие сокеты -
-p — показать PID и имя процесса 🔍 Хочешь отсортировать по порту или найти конкретный? Добавь
grep:
sudo ss -tunlp | grep 8080
🎯 Альтернатива на случай, если нет
ss:
sudo netstat -tunlp
Полезно для отладки фаервола, проверки работы сервисов или просто для уверенности, что сервер не слушает ничего лишнего 😉
👉@bash_srv
👍13
🧹 Автоматическая очистка логов старше N дней
Если логи разрастаются, а места становится всё меньше — пора автоматизировать их очистку! Вот простой способ удалить файлы старше, скажем, 14 дней:
🔧 Объяснение:
-
-
-
-
-
🛡️ Сухой запуск перед удалением:
Так ты увидишь, что будет удалено, прежде чем запускать
📌 Добавь в cron, чтобы забыть о рутине навсегда.
👉@bash_srv
Если логи разрастаются, а места становится всё меньше — пора автоматизировать их очистку! Вот простой способ удалить файлы старше, скажем, 14 дней:
find /var/log -type f -name "*.log" -mtime +14 -exec rm -f {} \;
🔧 Объяснение:
-
/var/log — каталог с логами (можно заменить на нужный путь);-
-type f — только файлы;-
-name "*.log" — ищем только .log-файлы;-
-mtime +14 — которым больше 14 дней;-
-exec rm -f {} — удаляем.🛡️ Сухой запуск перед удалением:
find /var/log -type f -name "*.log" -mtime +14
Так ты увидишь, что будет удалено, прежде чем запускать
rm.📌 Добавь в cron, чтобы забыть о рутине навсегда.
👉@bash_srv
👍8👎1
В чем разница между объявлением переменной export VAR="VALUE" и VAR="VALUE" в bash?
В
1.
- Это обычное объявление переменной в текущей оболочке (сессии).
- Переменная
- Например, если вы запустите новую команду или скрипт из текущей оболочки,
2.
- Команда
- То есть,
- Это полезно, когда необходимо передать значение переменной в другие программы или скрипты, запущенные из текущей оболочки.
Для примера
Таким образом,
👉@bash_srv
В
bash (и других оболочках Unix) разница между командами export VAR="VALUE" и VAR="VALUE" связана с областью видимости переменной:1.
VAR="VALUE": - Это обычное объявление переменной в текущей оболочке (сессии).
- Переменная
VAR будет доступна только внутри текущей сессии, и не будет передаваться дочерним процессам, запущенным этой сессией.- Например, если вы запустите новую команду или скрипт из текущей оболочки,
VAR не будет доступна в этом дочернем процессе.2.
export VAR="VALUE": - Команда
export делает переменную VAR доступной для всех дочерних процессов текущей оболочки.- То есть,
VAR будет установлена и доступна не только в текущей сессии, но и во всех процессах, запущенных из этой сессии.- Это полезно, когда необходимо передать значение переменной в другие программы или скрипты, запущенные из текущей оболочки.
Для примера
# Присвоение переменной без export
VAR="Hello"
bash -c 'echo $VAR' # Ничего не выведет, так как VAR не экспортирована
# Присвоение переменной с export
export VAR="Hello"
bash -c 'echo $VAR' # Выведет "Hello", так как VAR экспортирована
Таким образом,
export используется для того, чтобы переменная была доступна в дочерних процессах, тогда как обычное присвоение без export ограничивает переменную только текущей сессией.👉@bash_srv
👍12
#!/bin/bash
#=====================================
# скрипт изменения кодировки файлов.
#=====================================
# суть для одного файла: iconv -f Исходная_кодировка -t В_какую_кодировку > выходной_файл
# CONFIG:
TYPES="*.txt"; # на случай поиска по расширению. напр. "*.log"
FROM='cp1251'; # из какой кодировки.
TO='utf8'; # в какую кодировку.
FILEPREFIX='.utf8'; # к названию перекодированного файла добавится.
# START:
if [ -z $1 ]
then
echo "Encoding all $TYPES in directory From $FROM To $TO";
echo "use $0 /Path_to_recoding_directory/"; echo;
exit 1;
else
echo "Encoding all $TYPES in directory $1 From $FROM To $TO";
echo;
find $1 -name "$TYPES" -type f -print0|while read -d '' SOURCE; do
echo "========== SOURCE: $SOURCE FROM: $FROM TO: $TO ==========";
cat "$SOURCE"|iconv -f $FROM -t $TO > "$SOURCE$FILEPREFIX";
wait;
done;
exit 0;
fi
# end
👉@bash_srv
Please open Telegram to view this post
VIEW IN TELEGRAM
👍6🔥3
Проверка существования файла:
?
if ! [ -f /path/to/file ]; then
echo 'No file'
fi
Проверка существования директории:
if ! [ -d /path/directory/ ]; then
echo 'No directory'
fi
Проверка существования пользователя:
grep "username:" /etc/passwd >/dev/null
if [ $? -ne 0 ]; then
echo 'No username found'
fi
👉@bash_srv
Please open Telegram to view this post
VIEW IN TELEGRAM
👍10
#!/bin/bash
# This script monitors CPU and memory usage
while :
do
# Get the current usage of CPU and memory
cpuUsage=$(top -bn1 | awk '/Cpu/ { print $2}')
memUsage=$(free -m | awk '/Mem/{print $3}')
# Print the usage
echo "CPU Usage: $cpuUsage%"
echo "Memory Usage: $memUsage MB"
# Sleep for 1 second
sleep 1
done
👉@bash_srv
Please open Telegram to view this post
VIEW IN TELEGRAM
👍12
🎯 Bash-совет дня: быстрое сравнение файлов по хэшу
Иногда нужно убедиться, что два файла идентичны. Вместо
Вот удобная однострочная команда:
📌 Пояснение:
-
-
-
🔥 Подходит для проверки резервных копий, дистрибутивов и любых бинарников.
👉@bash_srv
Иногда нужно убедиться, что два файла идентичны. Вместо
diff, который сравнивает содержимое построчно, проще сравнить их контрольные суммы.Вот удобная однострочная команда:
[ "$(sha256sum file1 | awk '{print $1}')" = "$(sha256sum file2 | awk '{print $1}')" ] && echo "✅ Файлы одинаковые" || echo "❌ Файлы разные"
📌 Пояснение:
-
sha256sum — создаёт SHA-256 хэш от файла. -
awk '{print $1}' — достаёт только сам хэш (без имени файла). -
[...] && ... || ... — условие в стиле bash: если хэши совпадают — выводим "файлы одинаковые", иначе — "разные".🔥 Подходит для проверки резервных копий, дистрибутивов и любых бинарников.
👉@bash_srv
🔥11👍2❤1
🔍 Поиск строк с IP-адресами в логах
Иногда нужно быстро найти все IP-адреса в лог-файле, например, чтобы отследить активность пользователей или подозрительную активность. Вот как это можно сделать с помощью
🔧 Разбор команды:
-
-
-
-
📊 Это простой способ быстро узнать, кто чаще всего стучится к вашему серверу.
👉@bash_srv
Иногда нужно быстро найти все IP-адреса в лог-файле, например, чтобы отследить активность пользователей или подозрительную активность. Вот как это можно сделать с помощью
grep и регулярки:
grep -Eo '([0-9]{1,3}\.){3}[0-9]{1,3}' /var/log/nginx/access.log | sort | uniq -c | sort -nr | head
🔧 Разбор команды:
-
-Eo — используем расширенные регулярные выражения и выводим только совпадения-
([0-9]{1,3}\.){3}[0-9]{1,3} — регулярка для IPv4-адресов-
sort | uniq -c — считаем, сколько раз встречается каждый IP-
sort -nr | head — выводим топ 10 по количеству📊 Это простой способ быстро узнать, кто чаще всего стучится к вашему серверу.
👉@bash_srv
👍6❤1
🎯 Bash-совет: Найти и удалить все
Файлы
Вот простой скрипт для их поиска и удаления:
📌 Можно адаптировать под удаление
✅ Используй как утилиту перед деплоем или в CI/CD.
👉@bash_srv
.DS_Store файлы на сервере (или любые другие "мусорные" файлы)Файлы
.DS_Store автоматически создаются macOS и часто попадают на серверы при деплое. Они бесполезны и могут мешать.Вот простой скрипт для их поиска и удаления:
#!/bin/bash
# Каталог, в котором ищем (по умолчанию текущий)
DIR="${1:-.}"
echo "🔍 Ищу .DS_Store файлы в: $DIR"
find "$DIR" -name '.DS_Store' -type f -print -delete
echo "🧹 Удаление завершено."
📌 Можно адаптировать под удаление
Thumbs.db, __MACOSX или других ненужных артефактов.✅ Используй как утилиту перед деплоем или в CI/CD.
👉@bash_srv
👍5🤔1
🔍 Регулярки на каждый день: как найти строки, содержащие IP-адреса
Иногда нужно выцепить IP-адреса из логов или текста. Ниже я написал регулярку, которая найдёт IPv4 -адреса:
💡 Пример использования с
🎯 Что делает эта регулярка:
-
-
-
- Вся конструкция — это "что-то вроде 192.168.1.1".
🧠 Минус: она не валидирует значения (например, 999.999.999.999 тоже пройдёт). Но для быстрой фильтрации из логов — идеально.
💪 А ата уже фильтрует только реальные IP!
👉@bash_srv
Иногда нужно выцепить IP-адреса из логов или текста. Ниже я написал регулярку, которая найдёт IPv4 -адреса:
\b(?:[0-9]{1,3}\.){3}[0-9]{1,3}\b
💡 Пример использования с
grep:
grep -Eo '\b(?:[0-9]{1,3}\.){3}[0-9]{1,3}\b' access.log
🎯 Что делает эта регулярка:
-
\b — граница слова (чтобы не цеплять лишнее);-
(?:[0-9]{1,3}\.){3} — три группы чисел от 0 до 999, за которыми идёт точка;-
[0-9]{1,3} — последняя четвёртая группа;- Вся конструкция — это "что-то вроде 192.168.1.1".
🧠 Минус: она не валидирует значения (например, 999.999.999.999 тоже пройдёт). Но для быстрой фильтрации из логов — идеально.
💪 А ата уже фильтрует только реальные IP!
\b((25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.){3}
(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\b
👉@bash_srv
👍9❤1
📦 Онлайн-мониторинг логов с выделением ошибок
Следить за логами в реальном времени — это круто, но ещё круче, когда ошибки выделяются цветом! Вот как это сделать:
🔍 Разбор:
-
-
-
-
🎨 Удобно для быстрого визуального анализа, особенно когда логов много!
💡 Можно адаптировать под свои ключевые слова и логи.
👉@bash_srv
Следить за логами в реальном времени — это круто, но ещё круче, когда ошибки выделяются цветом! Вот как это сделать:
tail -f /var/log/syslog | grep --color=always -Ei "error|fail|critical|warning"
🔍 Разбор:
-
tail -f — следим за логом в реальном времени-
grep --color=always — подсвечиваем совпадения-
-Ei — игнорируем регистр и используем расширенные регулярки-
"error|fail|critical|warning" — ключевые слова для ловли проблем🎨 Удобно для быстрого визуального анализа, особенно когда логов много!
💡 Можно адаптировать под свои ключевые слова и логи.
👉@bash_srv
👍7
🚀 Bash совет дня: Удаление старых логов по дате 🧹
Если логи со временем забивают диск, пора автоматизировать их очистку! Вот простой однострочник на Bash, который удалит все файлы старше 7 дней в указанной директории:
🔍 Разбор:
-
-
-
-
-
📅 Можно добавить в cron и забыть о ручной чистке логов навсегда!
Пример строки в crontab, чтобы запускалось каждый день в 2:00 ночи:
💡 Совет: замените
👉@bash_srv
Если логи со временем забивают диск, пора автоматизировать их очистку! Вот простой однострочник на Bash, который удалит все файлы старше 7 дней в указанной директории:
find /var/log/myapp/ -type f -mtime +7 -name "*.log" -exec rm -f {} \;
🔍 Разбор:
-
/var/log/myapp/ — путь к директории с логами -
-type f — только файлы -
-mtime +7 — старше 7 дней -
-name "*.log" — только .log файлы -
-exec rm -f {} \; — удаляем файлы📅 Можно добавить в cron и забыть о ручной чистке логов навсегда!
Пример строки в crontab, чтобы запускалось каждый день в 2:00 ночи:
0 2 * * * find /var/log/myapp/ -type f -mtime +7 -name "*.log" -exec rm -f {} \;
💡 Совет: замените
/var/log/myapp/ на свою директорию.👉@bash_srv
👍4❤1
🚀 Bash-скрипт для автоматического обновления всех пакетов на сервере с уведомлением на почту
Иногда важно не только обновить все пакеты, но и быть в курсе, что именно произошло. Пойдем на шаг дальше! 👨💻
✅ Скрипт:
- Обновляет пакеты через
- Сохраняет лог в
- Отправляет лог на указанный e-mail.
- Очищает за собой мусор.
⚙️ Чтобы отправка писем работала, убедись, что установлен пакет
💬 Используй
👉@bash_srv
Иногда важно не только обновить все пакеты, но и быть в курсе, что именно произошло. Пойдем на шаг дальше! 👨💻
#!/bin/bash
# Настройки
EMAIL="admin@example.com"
HOSTNAME=$(hostname)
# Обновляем пакеты
apt update && apt upgrade -y > /tmp/update-log.txt
# Отправляем лог на почту
mail -s "[$HOSTNAME] Отчет об обновлении пакетов" "$EMAIL" < /tmp/update-log.txt
# Убираем временный файл
rm -f /tmp/update-log.txt
✅ Скрипт:
- Обновляет пакеты через
apt.- Сохраняет лог в
/tmp/update-log.txt.- Отправляет лог на указанный e-mail.
- Очищает за собой мусор.
⚙️ Чтобы отправка писем работала, убедись, что установлен пакет
mailutils:
sudo apt install mailutils
💬 Используй
cron, чтобы выполнять этот скрипт автоматически каждую неделю или каждый день:
0 3 * * 1 /path/to/update_script.sh
👉@bash_srv
👍8
📂 Быстрое создание структуры директорий в Linux
Иногда нужно быстро создать целую структуру папок. Вручную - долго. На помощь приходит
✅ Этот однострочник создаст папки
Фишка: можно создавать вложенные структуры сразу:
Это создаст:
-
-
-
-
Полезно, если нужно быстро подготовить окружение для проекта 🚀
👉@bash_srv
Иногда нужно быстро создать целую структуру папок. Вручную - долго. На помощь приходит
mkdir с флагом -p:
mkdir -p /var/www/project/{css,js,images,fonts}
✅ Этот однострочник создаст папки
css, js, images, fonts внутри /var/www/project, даже если родительские директории ещё не существуют.Фишка: можно создавать вложенные структуры сразу:
mkdir -p /opt/data/{logs/{nginx,mysql},backups/{daily,weekly}}
Это создаст:
-
/opt/data/logs/nginx-
/opt/data/logs/mysql-
/opt/data/backups/daily-
/opt/data/backups/weeklyПолезно, если нужно быстро подготовить окружение для проекта 🚀
👉@bash_srv
👍21
⚡Ускоряем работу с логами через Bash
Часто приходится искать ошибки в огромных логах?
Вот удобный однострочник, который найдёт все строки с ошибками за последние N минут:
🔹 Замените
🔹 Работает для логов, где стандартный формат даты (
🔹 Ключ
✅ Теперь вы всегда увидите самые свежие ошибки без пролистывания тысяч строк!
👉@bash_srv
Часто приходится искать ошибки в огромных логах?
Вот удобный однострочник, который найдёт все строки с ошибками за последние N минут:
grep "$(date --date='5 min ago' '+%b %_d %H:%M')" /var/log/syslog | grep -i "error"
🔹 Замените
5 на нужное количество минут. 🔹 Работает для логов, где стандартный формат даты (
%b %_d %H:%M), например /var/log/syslog, /var/log/auth.log. 🔹 Ключ
-i делает поиск нечувствительным к регистру.✅ Теперь вы всегда увидите самые свежие ошибки без пролистывания тысяч строк!
👉@bash_srv
👍12👎1