grep multiple values in single pass through log file.
I have a huge binary log file.
There are lets say 4 id's that I want to find in a log file.
I know that those 4 id's will be present in the log file and I also know in what order they will be present.
I want to find 1st id from the log then 2nd id and then third id and so on..
Simple/inefficient solution is: Loop through the id's and then grep in the log file. Problem with this solution is for each id grep will search from the beginning of the file.
Better/efficient solution would be: Sine I know the order in which id's will be present in the log file. Loop through id's, grep 1st id and then move on to grep 2nd id and so on...this way I can grep all id's in one pass.
Is this solution possible ?
I have 500000 + values to find in log files and I have to find efficient solution for it. Thanks in advance
You should look into regular expressions. Something like this might get what you want:
Keep in mind, this will cause grep to display all matching lines in whatever order they occur in the file.
EDIT: My mistake, you do not need the escape character if the grep string is in double quotes
gzip -dc log.gz | grep -e 1234 -e 5678 -e 90ab -e cdef >results.txt
|All times are GMT -5. The time now is 01:33 PM.|