![Применить фильтрацию multitail ко многим файлам, переданным через подстановочный знак](https://rvso.com/image/164737/%D0%9F%D1%80%D0%B8%D0%BC%D0%B5%D0%BD%D0%B8%D1%82%D1%8C%20%D1%84%D0%B8%D0%BB%D1%8C%D1%82%D1%80%D0%B0%D1%86%D0%B8%D1%8E%20multitail%20%D0%BA%D0%BE%20%D0%BC%D0%BD%D0%BE%D0%B3%D0%B8%D0%BC%20%D1%84%D0%B0%D0%B9%D0%BB%D0%B0%D0%BC%2C%20%D0%BF%D0%B5%D1%80%D0%B5%D0%B4%D0%B0%D0%BD%D0%BD%D1%8B%D0%BC%20%D1%87%D0%B5%D1%80%D0%B5%D0%B7%20%D0%BF%D0%BE%D0%B4%D1%81%D1%82%D0%B0%D0%BD%D0%BE%D0%B2%D0%BE%D1%87%D0%BD%D1%8B%D0%B9%20%D0%B7%D0%BD%D0%B0%D0%BA.png)
multitail
имеет хороший механизм фильтрации на основе регулярных выражений, который описан в man-странице и онлайн-руководстве. Оба источника утверждают, что строки журнала, соответствующие заданному регулярному выражению, могут быть исключены из вывода с помощью переключателя -ev
:
multitail -ev "ignorelinescontainingthis" /var/log/whatever.log -ev "alsoignorethis" /var/log/another.log
Однако это, по-видимому, не работает для фильтрации многих файлов журналов, которые передаются с использованием подстановочных знаков:
multitail -ev "thisdoesntwork" /var/log/myservice*.log
Есть ли способ заставить это работать?
Для анализа я попробовал -ec
переключатель (который выделяет совпадения с регулярными выражениями), и оказалось, что фильтр применяется только к первому файлу в списке подстановочных знаков, но ни к одному из остальных.
решение1
Превращаю свой комментарий в ответ.
Страница руководства дляmultitail
определяет -e
опцию следующим образом:
-e
Используйте следующее регулярное выражение для следующегофайл.
Поэтому фильтр регулярного выражения применяется только к следующему файлу. При использовании shell globs это приведет к тому, что фильтр будет применен только к первому файлу в расширенном списке файлов.
Чтобы применить фильтр регулярных выражений ко всем файлам, -E
необходимо использовать следующую опцию:
-E
Используйте следующее регулярное выражение для следующегофайлы.
Параметр -v
, который отрицает указанное регулярное выражение, должен работать одинаково для любого из этих параметров.