2 / 2 / 0
Регистрация: 09.08.2015
Сообщений: 192

Если в конце лога появится "один и тот же текст", но разная дата и время - выполнить команду

21.02.2026, 10:04. Показов 340. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем здравствуйте

Есть длинный лог вида

Feb 21 09:35:45 Test: 1
Feb 21 09:36:45 NoName: 2
Feb 21 09:37:45 NoName: 3
Feb 21 09:38:45 NoName: 4
Feb 21 09:39:45 NoName: 5
Feb 21 09:40:45 NoName: 6
Feb 21 09:41:45 NoName: 7

Feb 22 09:35:45 NoName: 8
Feb 22 09:36:45 NoName: 9
Feb 22 09:37:45 NoName: 10
Feb 22 09:38:45 NoName: 11
Feb 22 09:39:45 NoName: 12
Feb 22 09:40:45 NoName: 13

Feb 28 09:40:50 Super: 1

Feb 28 09:41:45 Test: 1

Feb 28 09:35:45 Super: 1
Feb 28 09:36:45 Super: 1
Feb 28 09:37:45 Super: 1
Feb 28 09:38:45 Super: 1
Feb 28 09:39:45 Super: 1
Feb 28 09:40:45 Super: 1

Feb 28 09:51:45 Test: 1

Feb 28 10:35:45 Super: 1
Feb 28 10:36:45 Super: 1
Feb 28 10:37:45 Super: 1
Feb 28 10:38:45 Super: 1
Feb 28 10:39:45 Super: 1
Feb 28 10:40:45 Super: 1

Периодически запускается скрипт

Строки Test: 1 (разная дата и время) может и никогда не быть в логе

Если в конце лога появится Test: 1, но разная дата и время, Test: 1 будет ниже строки Super: 1 - то в цикле 0 до 10 c паузой 5 секунд между от 0 до 10 выполнить команду

Если в логе в ранее, чем от 0 до 10 появится текст Super: 1 (Super: 1 будет ниже строки Test: 1) - то ДОсрочно завершить цикл от 0 до 10

От 0 до 10 - это количество попыток перезапуска/переподключения/не суть

5 секунд - пауза/задержка, мол, чтобы не рвать волосы, а подождать, может от 0 до 10 с паузой 5 секунд - хватит и от 0 до 5, не ждать оставшиеся 5 попыток

Если от 0 до 10 с паузой 5 секунд НЕ помогло - ничего страшного, буду ждать следующего "Периодически запускается скрипт"

Мой самопал - на пути к лучшему, но все равно не пойму, как правильно

Bash
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#!/bin/sh
 
a=$(tac "/tmp/syslog.log" | grep -m1 "Test: 1" | cut -d ' ' -f 1,2,3)
logger -t $(basename $0) Predydushhij tajmshtamp: $a
 
for i in $(seq 1 10);
do
b=$(tac "/tmp/syslog.log" | grep -m1 "Test: 1" | cut -d ' ' -f 1,2,3)
logger -t $(basename $0) Tekushhij tajmshtamp: $b
if [ "$(tac "/tmp/syslog.log" | grep -m1 "Test: 1" | cut -d ' ' -f 1,2,3)" = "$a" ]; then
logger -t $(basename $0) $i
logger -t $(basename $0) Pauza 5 sec
sleep 5
restart_service
fi
done
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
21.02.2026, 10:04
Ответы с готовыми решениями:

Национальная российская ОС на базе Linux появится в 2011г.
Уже в будущем году в России должна появиться национальная операционная система, которая будет...

Ubuntu появится на смартфонах и планшетах
В сегменте мобильных операционных систем появится еще одна платформа — Ubuntu Linux. В ближайшее...

Одной командой (или контейнером) записать текст в определённую с конца строку в файле
Есть оператор > для добавления в файл, есть >> для перезаписи файла, а как добавить какую-то строку...

2
 Аватар для Pphantom
2319 / 1561 / 721
Регистрация: 17.03.2022
Сообщений: 5,026
21.02.2026, 11:55
Не знаю, возможно, это моя проблема, но я совершенно не понял условие.
Цитата Сообщение от SharkyEXE Посмотреть сообщение
Если в конце лога появится Test: 1, но разная дата и время
Разная с чем?
Цитата Сообщение от SharkyEXE Посмотреть сообщение
Если в логе в ранее, чем от 0 до 10 появится текст Super: 1
От 0 до 10 чего?
Цитата Сообщение от SharkyEXE Посмотреть сообщение
От 0 до 10 - это количество попыток перезапуска/переподключения/не суть
Как это связано с содержимым лога?

Вы явно не дописываете известную вам, но неизвестную всем остальным информацию - как следствие, практически невозможно понять, что именно вам нужно.
0
 Аватар для volodin661
6793 / 2290 / 348
Регистрация: 10.12.2013
Сообщений: 7,901
21.02.2026, 15:31
SharkyEXE, не начинай.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
21.02.2026, 15:31
Помогаю со студенческими работами здесь

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

Проблема с датой-временем в логах
День добрый всем. У меня появилась такая проблема: Установил CentOS-7 сервер и поднял для...

Regex чтобы выделить дату, время и ID из логов
Привет. В общем есть логи в виде ModSecurity: Access denied with code 403 (phase 2). Match...

Сравнение времени выполнения разных команд
С помощью time узнаю сколько выполняется архивация с помощью gzip и rar. Можно ли как-то сравнить...

Как в скрипте запустить консоль и выполнить в ней команду?
Подскажите, как создать скрипт чтобы запускался сначала xterm, а в нем определенная команда. Вот...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Опции темы

Новые блоги и статьи
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это дополнительная запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru