Как сделать отметку времени для каждого результата ping?
Ping возвращает это по умолчанию:
64 bytes from 203.173.50.132: icmp_seq=0 ttl=244 time=57.746 ms
Есть ли способ заставить его добавить временную метку?
Например,
Mon 21 May 2012 15:15:37 EST | 64 bytes from 203.173.50.132: icmp_seq=0 ttl=244 time=57.746 ms
Я нахожусь в OS X v10.7 (Lion), который, похоже, имеет версию BSD для ping.
Ответы
Ответ 1
Если ваш AWK не имеет strftime()
:
ping host | perl -nle 'print scalar(localtime), " ", $_'
Чтобы перенаправить его в файл, используйте стандартное перенаправление оболочки и отключите буферизацию вывода:
ping host | perl -nle 'BEGIN {$|++} print scalar(localtime), " ", $_' > outputfile
Если вы хотите формат ISO8601 для метки времени:
ping host | perl -nle 'use Time::Piece; BEGIN {$|++} print localtime->datetime, " ", $_' > outputfile
Ответ 2
Я не мог перенаправить решение на основе Perl в файл по какой-то причине, поэтому я продолжал поиск и нашел способ bash
только для этого:
ping www.google.fr | while read pong; do echo "$(date): $pong"; done
Wed Jun 26 13:09:23 CEST 2013: PING www.google.fr (173.194.40.56) 56(84) bytes of data.
Wed Jun 26 13:09:23 CEST 2013: 64 bytes from zrh04s05-in-f24.1e100.net (173.194.40.56): icmp_req=1 ttl=57 time=7.26 ms
Wed Jun 26 13:09:24 CEST 2013: 64 bytes from zrh04s05-in-f24.1e100.net (173.194.40.56): icmp_req=2 ttl=57 time=8.14 ms
Кредит относится к https://askubuntu.com/a/137246
Ответ 3
От man ping
:
-D Print timestamp (unix time + microseconds as in gettimeofday) before each line.
Он произведет что-то вроде этого:
[1337577886.346622] 64 bytes from 4.2.2.2: icmp_req=1 ttl=243 time=47.1 ms
Затем метка времени может быть проанализирована из ответа ping
и преобразована в требуемый формат с помощью date
.
Ответ 4
-
вывод терминала:
ping -i 5 google.com | xargs -L 1 -I '{}' date '+%Y-%m-%d %H:%M:%S: {}'
-
вывод файла:
ping -i 5 google.com | xargs -L 1 -I '{}' date '+%Y-%m-%d %H:%M:%S: {}' > test.txt
-
терминал + вывод файла:
ping -i 5 google.com | xargs -L 1 -I '{}' date '+%Y-%m-%d %H:%M:%S: {}' | tee test.txt
-
Фон вывода файла:
nohup ping -i 5 google.com | xargs -L 1 -I '{}' date '+%Y-%m-%d %H:%M:%S: {}' > test.txt &
Ответ 5
Мое первоначальное представление было неверным, потому что оно не оценивало дату для каждой строки. Были сделаны исправления.
Попробуйте это
ping google.com | xargs -L 1 -I '{}' date '+%+: {}'
выводит следующий вывод
Thu Aug 15 10:13:59 PDT 2013: PING google.com (74.125.239.103): 56 data bytes
Thu Aug 15 10:13:59 PDT 2013: 64 bytes from 74.125.239.103: icmp_seq=0 ttl=55 time=14.983 ms
Thu Aug 15 10:14:00 PDT 2013: 64 bytes from 74.125.239.103: icmp_seq=1 ttl=55 time=17.340 ms
Thu Aug 15 10:14:01 PDT 2013: 64 bytes from 74.125.239.103: icmp_seq=2 ttl=55 time=15.898 ms
Thu Aug 15 10:14:02 PDT 2013: 64 bytes from 74.125.239.103: icmp_seq=3 ttl=55 time=15.720 ms
Thu Aug 15 10:14:03 PDT 2013: 64 bytes from 74.125.239.103: icmp_seq=4 ttl=55 time=16.899 ms
Thu Aug 15 10:14:04 PDT 2013: 64 bytes from 74.125.239.103: icmp_seq=5 ttl=55 time=16.242 ms
Thu Aug 15 10:14:05 PDT 2013: 64 bytes from 74.125.239.103: icmp_seq=6 ttl=55 time=16.574 ms
Параметр -L 1 заставляет xargs обрабатывать одну строку за раз, а не слова.
Ответ 6
В OS X вы можете просто использовать опцию -apple-time:
ping -i 2 --apple-time www.apple.com
Производит такие результаты, как:
10:09:55.691216 64 bytes from 72.246.225.209: icmp_seq=0 ttl=60 time=34.388 ms
10:09:57.687282 64 bytes from 72.246.225.209: icmp_seq=1 ttl=60 time=25.319 ms
10:09:59.729998 64 bytes from 72.246.225.209: icmp_seq=2 ttl=60 time=64.097 ms
Ответ 7
Выведите результат на awk
:
ping host | awk '{if($0 ~ /bytes from/){print strftime()"|"$0}else print}'
Ответ 8
Попробуйте следующее:
ping www.google.com | while read endlooop; do echo "$(date): $endlooop"; done
Он возвращает что-то вроде:
Wednesday 18 January 09:29:20 AEDT 2017: PING www.google.com (216.58.199.36) 56(84) bytes of data.
Wednesday 18 January 09:29:20 AEDT 2017: 64 bytes from syd09s12-in-f36.1e100.net (216.58.199.36): icmp_seq=1 ttl=57 time=2.86 ms
Wednesday 18 January 09:29:21 AEDT 2017: 64 bytes from syd09s12-in-f36.1e100.net (216.58.199.36): icmp_seq=2 ttl=57 time=2.64 ms
Wednesday 18 January 09:29:22 AEDT 2017: 64 bytes from syd09s12-in-f36.1e100.net (216.58.199.36): icmp_seq=3 ttl=57 time=2.76 ms
Wednesday 18 January 09:29:23 AEDT 2017: 64 bytes from syd09s12-in-f36.1e100.net (216.58.199.36): icmp_seq=4 ttl=57 time=1.87 ms
Wednesday 18 January 09:29:24 AEDT 2017: 64 bytes from syd09s12-in-f36.1e100.net (216.58.199.36): icmp_seq=5 ttl=57 time=2.45 ms
Ответ 9
Вы не указали временную метку или интервал времени, в течение которого вам понадобится такой вывод, поэтому я считал его бесконечным циклом. Вы можете изменить его соответственно в соответствии с вашими потребностями.
while true
do
echo -e "`date`|`ping -n -c 1 <IP_TO_PING>|grep 'bytes from'`"
sleep 2
done
Ответ 10
ping -D -n -O -i1 -W1 8.8.8.8
или, возможно,
while true; do \
ping -n -w1 -W1 -c1 8.8.8.8 \
| grep -E "rtt|100%" \
| sed -e "s/^/`date` /g"; \
sleep 1; \
done
Ответ 11
Мне также нужно это, чтобы отслеживать сетевую проблему для моей проблемы с зеркальным отображением базы данных. Я использую код команды, как показано ниже:
ping -t Google.com|cmd /q /v /c "(pause&pause)>nul & for /l %a in () do (set /p "data=" && echo(!date! !time! !data!)&ping -n 2 Google.com>nul" >C:\pingtest.txt
Вам просто нужно изменить Google.com на имя своего сервера. Он отлично работает для меня. и не забудьте остановить это, когда закончите. Файл pingtest.txt увеличится на 1 КБ в секунду (вокруг).
Спасибо за raymond.cc. https://www.raymond.cc/blog/timestamp-ping-with-hrping/
Ответ 12
На macos вы можете сделать
ping --apple-time 127.0.0.1
Выход выглядит как
16:07:11.315419 64 bytes from 127.0.0.1: icmp_seq=0 ttl=64 time=0.064 ms
16:07:12.319933 64 bytes from 127.0.0.1: icmp_seq=1 ttl=64 time=0.157 ms
16:07:13.322766 64 bytes from 127.0.0.1: icmp_seq=2 ttl=64 time=0.066 ms
16:07:14.324649 64 bytes from 127.0.0.1: icmp_seq=3 ttl=64 time=0.148 ms
16:07:15.328743 64 bytes from 127.0.0.1: icmp_seq=4 ttl=64 time=0.092 ms
Ответ 13
Попробуйте эту строку.
while sleep 1;do echo "$(date +%d-%m-%y-%T) $(ping -c 1 whatever.com | gawk 'FNR==2{print "Response from:",$4,$8}')" | tee -a /yourfolder/pingtest.log;done
Вам нужно отменить его с помощью ctrl-c
tho.