Минутка просвещения

Читать в телеге. Когда-то там были посты не только от меня.

Список открытых файлов в системе

Как узнать, какой процесс занял порт на локалхосте, чтобы его убить? Сколько файлов открыл и использует пользователь? Для ответа на эти вопросы можно использовать утилиту lsof, которая выводит список открытых файлов:

lsof -w -n -i tcp:8080
lsof -u user | wc -l

Wikipedia

Ссылка

Отправка http-запросов в Intellij Idea

В Ultimate версии intellij есть возможность делать http-запросы прямо из scratch-файла. С шаблонированием и всем таким. Штука вроде как прикольная, но покупать ради этого Ultimate - имхо, оверкилл. Хотя если он и так уже есть - почему бы и нет? Подробнее: https://www.jetbrains.com/help/idea/http-client-in-product-code-editor.html.

А те, кто сидит на community, могут использовать старый добрый curl или какой-нибудь плагин к браузеру - тысячи их.

Ссылка

Обработка json в командной строке

Кто-то (например, эластик) выплюнул в консоль километровый json и надо с ним что-то делать? jq придет на помощь!

Это утилита командной строки для работы с json - фильтрация, извлечение данных и т.п. Порог вхождения высокий, но стоит того, если частый кейс.

Простейший вариант использования - красиво отформатировать json, который выплевывает curl. Для этого надо просто добавить -s в curl, чтобы не писал проценты скачивания, и добавить | jq.

Более сложный кейс - изменение данных. Например, я использовал jq, чтобы среди тонны индексов elasticsearch найти те, у которых неправильный индекс. Выглядело это примерно так:

cat 2.json | jq -r 'keys[] as $k | "\($k) -> \(.[$k] | .mappings.post.properties."availability-feed".properties.attributes.properties."owner-id")"' | grep long

Дока по jq: https://stedolan.github.io/jq/tutorial/.

Ссылка

Боли docker

Докер - это не всегда клево. Когда-то в далеком 2015, мы в ОСУЗ тыкали его палкой… Но получилось не очень. С тех пор много воды утекло, и многие все в kubernetes держат, но боли от контейнеров все равно актуальны: https://habr.com/ru/post/467607/.

Ссылка

Сброс кэша памяти в линуксе

Если на линукс-серваке возникает вопрос - “кто же пожрал всю память?”, а в top все скромно жрут по полмегабайта, то виновник - кэш. Его можно сбросить командой sync; echo 1 > /proc/sys/vm/drop_caches Подробнее - тут.

Ссылка

Чтение тредов твиттера

В твитере люди иногда делают длинный тред с фактами (1 факт - 1 твит). Звучит по-уебански, но таки уж люди, они и в инстаграме статьи-лонгриды пишут. Так вот, есть специальный бот, чтобы из треда с сотней твитов сделать обычную статью: https://threadreaderapp.com/. Типа упоминаешь его твитом и он разворачивает тред.

Ссылка

Сравнение веток в Intellij Idea

Intellij Idea в новых версиях умеет сравнивать между собой ветки - причем как по логу коммитов, так и по файлам. Для этого надо в выборе ветки выбрать compare.

Ссылка

Свободное место на файловой системе

Чтобы не попасть в просак при работе со свободным местом в ФС и всем таким рекомендуется ознакомится со статьей. Можно для разогрева прочесть эту.

Даже если есть место на диске, новый файл может не создаться из-за того, что:

  • кончились свободные inode
  • кончились свободные inode для пользователя (для root есть специальный резерв)
  • может быть коллизия хэша имени в индексе каталога (поэтому много файлов в одной папке хранить плохо)
Ссылка

Значения по умолчанию в dict в питоне

В питоне dict.get(key, default_value) вычисляет все свои аргументы сразу. Вроде мелочь, но конструкция lookup.get(z, int(z)) может поломаться. Ее ожидаемое поведение - попробовать получить что-то из словаря по ключу, а если не получилось - то по преобразованному в число ключу. Но поскольку int(z) вычисляется сразу, то на обычной строке ввод ломается. А если эта конструкция где-то глубоко, и ты хочешь быстро написать скрипт и свалить, то можно начать грешить на скрытые юникод символы и прочую дичь по непривычке. В scala, например, вычисление значения по умолчанию - ленивое.

Ссылка