LinuxCamp | DevOps
14K subscribers
263 photos
12 videos
374 links
Обо мне: C/C++/Linux эксперт. Говорим про разработку, Linux, DevOps, сети и администрирование.

Админ (реклама): @XoDefender
Чат: @linuxcamp_chat

Менеджер: @Spiral_Yuri
Биржа: https://telega.in/c/linuxcamp_tg

РКН: https://clck.ru/3RWA3C
Download Telegram
hackingtool: большая подборка hacking security-утилит в одном меню 👻

hackingtool — это Python/TUI-оболочка для установки и запуска инструментов по security-тестированию. Внутри собраны утилиты для OSINT, web security, reverse engineering, forensics, cloud security, mobile security, Active Directory и других задач. В версии 2.0 авторы заявляют 185+ инструментов и поиск по меню.

Что умеет

Главная идея простая: не держать в голове десятки репозиториев и команд установки, а искать нужный инструмент из одного интерфейса. Например, в списке есть:


nmap
theHarvester
ffuf
OWASP ZAP
Trivy


Самое интересное


Репозиторий содержит не только защитные инструменты, но и спорные категории: phishing, RAT, DDoS, payload creation и post-exploitation.
🤔Использовать только в защитных целях!!!

Вывод

hackingtool полезен как каталог и быстрый лаунчер security!-инструментов. Детям не игрушка 😁

LinuxCamp | #utils
Please open Telegram to view this post
VIEW IN TELEGRAM
👍223😁2🔥1
This media is not supported in your browser
VIEW IN TELEGRAM
Как вам такое DE, братва?

LinuxCamp
👍32🔥1110
This media is not supported in your browser
VIEW IN TELEGRAM
Linux впервые в истории взял 5% в Steam

Доля пользователей Linux на Steam достигла 5% по данным опроса Valve за март 2026 года.

Для контекста, как Linux рос:

ноябрь 2024 — 2%
ноябрь 2025 — 3%
март 2026 — 5.33%

При ~132 млн пользователей Steam в месяц это около 7 млн геймеров на Linux.

Расклад по платформам в марте:

Windows — 92.33% (-4.28%)
Linux — 5.33% (+3.10%)
macOS — 2.35%

LinuxCamp | #news
🔥57👍10🦄5🥱32🤣2
Shellfirm: защита от опасных команд в терминале

Shellfirm — это предохранитель для shell-команд. Он перехватывает рискованные команды перед выполнением и просит дополнительное подтверждение. Например, если ты случайно запускаешь что-то вроде:


rm -rf /
git reset --hard
kubectl delete namespace prod


Shellfirm может остановить выполнение и показать предупреждение.

Как работает

Утилита встраивается в shell через hook и проверяет команду перед запуском. Установка:


cargo install shellfirm


Инициализация:


shellfirm init


После перезапуска shell можно проверить:


git reset --hard


Команда не выполнится молча: Shellfirm должен показать предупреждение.

Вывод

Shellfirm — простой предохранитель для терминала. Можно использовать как дополнительный слой проверки перед выполнением опасных действий.

LinuxCamp | #utils
👍267🙈1
Forwarded from ITCamp | AI & Code
Полный курс по вайбкодингу с Claude Code (за 1.5 часа) 😁

По полочкам разложил весь багаж знаний по работе с Claude Code:

— Установка, оплата, настройка

— MCP, субагенты, скиллы, команды

— git/github, x100 к скорости работы через "Git Worktrees"

— Деплой на выделенный сервер (как делают взрослые дяди):

покупка домена, аренда сервера, настройка DNS, сборка через dokploy


Рассказываю, что сам использую в работе и почему. Ценю ваше время, поэтому сжал 7 часов лайва в 1.5 😊

Видео забирай бесплатно по ссылке
Please open Telegram to view this post
VIEW IN TELEGRAM
🤣27👍6🥴4🔥1🌚1
socktop: удаленный мониторинг сервера по WebSockets

socktop — это TUI-мониторинг для удалённых Linux-машин. На сервере запускается лёгкий агент, а ты со своей машины подключаешься к нему через WebSocket и смотришь метрики в терминале. По стилю похоже на top/btop, но с удалённым подключением.

Что показывает

В интерфейсе есть CPU, память, swap, диски, сеть, температуры и список процессов. Агент не крутит постоянный сборщик метрик в фоне: он собирает данные по запросу клиента. Когда никто не подключён, нагрузка почти нулевая.

Как запустить

Установка через cargo:


cargo install socktop
cargo install socktop_agent


На сервере:


socktop_agent --port 3000


На своей машине:


socktop ws://SERVER_IP:3000/ws


Для локального демо без отдельного сервера:


socktop --demo


Важный нюанс

Если открываешь агент не только в локальной сети, лучше включить TLS и токен.


SOCKTOP_TOKEN=changeme socktop_agent --enableSSL --port 8443


Подключение:


socktop --tls-ca /path/to/cert.pem \
"wss://SERVER_IP:8443/ws?token=changeme"


Без этого получится удобный, но лишний открытый вход к системным метрикам.

Вывод

socktop полезен, когда хочется смотреть состояние удалённого сервера без SSH-сессии с htop, iotop и кучей отдельных команд.
Для домашней лаборатории, Raspberry Pi, dev-серверов и небольших стендов очень приятный вариант.

LinuxCamp | #utils
👍237
Бэкапы БД отдельным контейнером

container-db-backup — Docker-образ для регулярных бэкапов баз данных. Поддерживает PostgreSQL, MySQL/MariaDB, MongoDB, Redis, SQLite, MSSQL, CouchDB и InfluxDB. Бэкапы можно складывать в локальную папку, S3-compatible storage, MinIO, Wasabi или Azure.

Как работает

Ты добавляешь отдельный контейнер рядом с базой, задаёшь параметры через env-переменные, а он по расписанию делает dump. Пример для PostgreSQL:


services:
db-backup:
image: docker.io/tiredofit/db-backup:latest
volumes:
- ./backups:/backup
environment:
- DB01_TYPE=pgsql
- DB01_HOST=postgres
- DB01_NAME=app
- DB01_USER=app
- DB01_PASS=secret
- DEFAULT_BACKUP_INTERVAL=1440
- DEFAULT_COMPRESSION=ZSTD


DB01, DB02, DB03 — это разные backup job’ы. Так можно одним контейнером бэкапить несколько баз.

Что умеет

Можно настроить расписание, сжатие, checksum, шифрование, очистку старых архивов, pre/post hooks и уведомления при ошибках в email, Matrix, Mattermost или Rocket.Chat. Ручной запуск тоже есть:


docker exec -it db-backup backup-now


А для отдельной задачи:


docker exec -it db-backup backup01-now


Важный нюанс

Бэкап это не только файл в папке. Его нужно периодически проверять восстановлением. У образа есть restore-скрипт, но поддержка восстановления заявлена только для MariaDB, Postgres и MongoDB. Для остальных лучше заранее проверить свой сценарий руками.

Вывод

container-db-backup — удобный вариант, если хочется быстро добавить scheduled backups в Docker Compose без отдельного cron-скрипта. Но после настройки обязательно проверь restore, иначе это не бэкап, а просто архив с надеждой.

LinuxCamp | #utils
🔥186👍4🤯1
Ядро Linux уже чисто ИИ пишет

За последние пару недель количество новых коммитов, помеченных как “Assisted-by” ИИ-ассистентом (например, Claude), буквально взлетело.

Каждый день отправляются пачки изменений, написанных в режиме вайб-кодинга 🫶

LinuxCamp | #news
Please open Telegram to view this post
VIEW IN TELEGRAM
😱41🤔14💊6👍2
Не все любят AI

Пока Linux ядро стремительно превращается в вайбкод проект, многие другие опенсорс тулзы запрещают любые AI-контрибьюции

- QEMU — "Политика проекта – отклонять любые контрибьюции, если есть основания полагать, что они включают в себя AI-сгенерированный контент или основаны на нём».

- NetBSD — код, сгенерированный AI, «считается потенциально заражённым кодом и не должен попадать в коммит».

- Zig — полный запрет на использование AI в любом виде:

«Никакого LLM-сгенерированного контента», «Никаких LLM для перевода», «Никаких LLM для поиска багов»

- OBS Studio — «Код должен быть написан человеком».

LinuxCamp | #news
1👍6712🔥7💊5❤‍🔥1
🔥 Большая раздача материалов для поиска работы DevOps-инженеру

Если ты DevOps-инженер и планируешь искать новую работу в ближайшие месяцы — забирай бесплатно наши материалы.

📄 Шпаргалка по HR-скринингу — как отвечать на самые частые вопросы рекрутеров и не отлететь на первом этапе.

📄 Готовая структура самопрезентации на интервью — что говорить о себе, чтобы твой опыт выглядел сильнее.

📄 5 практических советов по подготовке к собеседованию — что реально влияет на прохождение интервью.

📄 Список из 30 компаний с валютной удалёнкой — международные компании, которые нанимают удалённых специалистов и платят в $ или €.

Мы сами используем эти материалы при подготовке кандидатов.

Напишите в личку для получения:
@careerpilot_club

Результаты наших клиентов:
https://www.youtube.com/@careerpilot-org
👍61🔥1
Системные вызовы и syscall в Linux: как программа стучится в ядро

Каждый раз, когда программа читает файл, открывает сокет или печатает строку в терминал, она не делает это сама. Она просит об этом ядро. Механизм этой просьбы называется системным вызовом syscall.


Что это

Syscall - это запрос программы к ядру на операцию, которую ей не дают сделать напрямую: доступ к диску, сети, памяти, процессам. Это единственный легальный вход из твоего кода внутрь ядра.

Два пространства

Программы работают в user space с урезанными правами. Ядро и железо живут в kernel space. Между ними стену ставит сам процессор: приложения крутятся в кольце защиты ring 3, ядро в ring 0. Дёрнуть драйвер диска из обычного процесса нельзя, можно только попросить ядро.

Сделано это для изоляции и безопасности. Если бы любой процесс мог писать прямо в железо или в чужую память, один баг ронял бы всю систему. Ядро выступает арбитром: проверяет права, валидирует аргументы и только потом выполняет операцию.

Примеры

Базовые сисколы, на которых держится почти всё:


int fd = open("file.txt", O_RDONLY); // открыть файл
read(fd, buf, 1024); // прочитать данные
write(1, "hello\\n", 6); // записать в stdout
close(fd); // закрыть


А ещё fork() порождает новый процесс, execve() запускает программу, mmap() выделяет память. В Linux x86-64 их несколько сотен.

Под капотом

То, что в C выглядит как обычная функция, на деле оказывается переходом в ядро. Номер сисколла кладётся в регистр rax, аргументы в rdi, rsi, rdx, а инструкция syscall передаёт управление ядру:


mov rax, 1 ; номер вызова write
mov rdi, 1 ; fd = stdout
mov rsi, msg ; адрес буфера
mov rdx, 6 ; длина
syscall ; прыжок в kernel space


libc

Руками syscall почти никто не пишет: между тобой и ядром стоит glibc. Функция write() из unistd.h это тонкая обёртка: разложить аргументы по регистрам и вызвать syscall. Поэтому «функция» и «системный вызов» не одно и то же: printf() это функция libc, а write() под ней уже настоящий syscall.

strace

Хочешь увидеть все сисколы программы вживую:


strace ./program # все вызовы подряд
strace -c ls # сводка с подсчётом и таймингами


Вывод покажет каждый open, read и write с аргументами и кодом возврата. Незаменимо для отладки и реверса.

Итог

Syscall это мост между твоим кодом и ядром. Разберёшься в сисколах и будешь видеть, что программа делает на самом деле: где тормозит, куда лезет и почему падает.

LinuxCamp | #utils
👍26🔥54
Кто трогал сервер: ищем следы в Linux

Иногда на сервере что-то сломалось, а вопрос один:


кто заходил, когда заходил и что менял?


В Linux часть ответов можно найти без отдельного мониторинга. Но важно понимать: стандартные логи показывают не всё, а историю команд легко удалить.

Кто заходил на сервер

Посмотреть последние входы пользователей:


last


Неудачные попытки входа:


lastb


Текущие активные сессии:


who
w


Для SSH обычно полезно смотреть auth-логи:


grep "sshd" /var/log/auth.log


На RHEL/CentOS/AlmaLinux путь чаще такой:


grep "sshd" /var/log/secure


Кто выполнял команды

У каждого пользователя есть история shell:


cat ~/.bash_history


Но это слабый источник: команды могут записываться не сразу, часть команд может не попасть в историю, а сам файл можно почистить. Полезнее включить timestamp для истории:


echo 'export HISTTIMEFORMAT="%F %T "' >> ~/.bashrc
source ~/.bashrc


После этого history будет показывать время выполнения команд:


history


Кто менял файлы

Посмотреть время изменения файла:


stat /etc/nginx/nginx.conf


Найти файлы, изменённые за последний день:


find /etc/nginx -type f -mtime -1 -ls


За последние 60 минут:


find /etc/nginx -type f -mmin -60 -ls


Но stat и find покажут время изменения, а не имя пользователя, который это сделал. Если нужно именно кто изменил файл, заранее включают auditd:


apt install auditd


Добавить наблюдение за файлом:


auditctl -w /etc/nginx/nginx.conf -p wa -k nginx_config


Потом искать события:


ausearch -k nginx_config


Вывод

last, auth.log, history, stat и find помогают быстро понять, что происходило на сервере. Но если нужно точно знать, кто менял важные файлы, лучше заранее включить auditd. Без него Linux часто покажет когда файл изменили, но не всегда покажет кем.

LinuxCamp | #utils
👍43🔥116