Я использую timeout
для тайм-аута tail
и использую некоторый файл сохранения для сохранения позиции строки, которую мы проанализировали:
# statefile where we save the number of parsed already lines
statefile=/tmp/statefile.txt
# initialize count variable - to zero, or from statefile
if [ -e "$statefile" ]; then
count=$(<"$statefile")
else
count=0
fi
# we timeout for 1 seconds outputting the lines
# the better timeout would be like 10 seconds for big file
# the `tail` command needs to jump `$count` lines inside the input file
timeout 1 tail -n +$count input_log_file |
# tee is used to pass the input to the updating part
tee >(
# read number of parsed lines with `wc -l`
# increment the count of parsed lines and save to statefile
echo $(( count + $(wc -l) )) >"$statefile"
) |
# grep for the searched string
grep --line-buffered string_to_search |
# do the action if string_to_search is found
do_some_action_example_send_mail
может быть это тогда (из AuditReader docs)
AuditReader reader = AuditReaderFactory.get(entityManager);
User user_rev1 = reader.find(User.class, user.getId(), 1);
List<Number> revNumbers = reader.getRevisions(User.class, user_rev1);
User user_previous = reader.find(User.class, user_rev1.getId(),
revNumbers.get(revNumbers.size()-1));
(Я новичок в этом, не уверен, что у меня все синтаксис правильный, может быть, размер ( ) -1 должно быть size () - 2?)
Из документов:
AuditReader reader = AuditReaderFactory.get(entityManager);
User user_rev1 = reader.find(User.class, user.getId(), 1);
Думаю, это будет так:
final AuditReader reader = AuditReaderFactory.get( entityManagerOrSession );
// This could probably be declared as Long instead of Object
final Object pk = userCurrent.getId();
final List<Number> userRevisions = reader.getRevisions( User.class, pk );
final int revisionCount = userRevision.size();
final Number previousRevision = userRevisions.get( revisionCount - 2 );
final User userPrevious = reader.find( User.class, pk, previousRevision );