таблицы plugin_flowview_schedules и host были повреждены, и mysqlcheck этого не обнаружил. Найдено при преобразовании каждой таблицы по одному в InnoDB и получило ошибку 1033. Я сделал mysql экспорт только таблиц, а затем импортировал .sql в CentOS 6 машину, и ошибка прошла, и графики выскочили прямо вверх. Обратите внимание, что я rsync'ed миграции /var/lib/mysql/* и, вероятно, должен был сделать традиционный mysql экспорт и избавил бы себя от головной боли.
С Perl
:
$ perl -MTime::Piece -anle '
$F[2] = Time::Piece->strptime($F[2],"%r")->strftime("%H:%M:%S");
push @out, [$F[2]."-".join("-", reverse(split("-",$F[0]))), join(" ",@F)];
END {
print for map { $_->[1] }
sort { $a->[0] cmp $b->[0] } @out;
}' file
11-12-2014 - 00:08:03 lat = 41.937911; lon = -93.369249<br>
11-12-2014 - 00:11:29 lat = 41.949656; lon = -93.329133<br>
11-12-2014 - 00:23:02 lat = 42.025385; lon = -93.347026<br>
11-12-2014 - 00:29:10 lat = 41.033341; lon = -93.380586<br>
11-12-2014 - 00:38:08 lat = 41.036720; lon = -93.436851<br>
11-12-2014 - 00:45:20 lat = 41.998129; lon = -93.400943<br>
11-12-2014 - 00:53:36 lat = 41.961489; lon = -93.414624<br>
11-12-2014 - 03:03:59 lat = 41.990516; lon = -93.430704<br>
11-12-2014 - 03:05:15 lat = 41.001546; lon = -93.443352<br>
11-12-2014 - 03:11:50 lat = 42.039054; lon = -93.442001<br>
Как вы указали, существует ограниченный набор веб-сайтов, к которым приложения должны получить доступ, предоставить их в/etc/hosts и отключить DNS-поиск. Просто убедитесь, что у вас есть механизм обновления этих файлов хостов (либо удаленный инициированный scp
, либо загрузка на регулярной основе).
Это не запретит людям использовать IP-адреса для подключения к нежелательным сайтам, но сделает весь серфинг гораздо менее приятным.
-121--150742- Для этого используется команда GNU date
. Однако может потребоваться последовательности и распечатать соответствующую дату:
$ date -d "11/11/2014 04:12:03PM"
Tue Nov 11 16:12:03 CET 2014
Обратите внимание, что не нравится DD-MM-YYY
:
$ date -d "11-11-2014"
date: invalid date ‘11-11-2014’
Поэтому сначала запустите sed
в файле, чтобы заменить все -
на /
. Затем пройдите через прочитайте
, чтобы получить каждое поле в отдельную переменную, преобразуйте и сортируйте:
$ sed 's#-#/#g' file | while read date _ hour rest; do
echo "$(date -d "$date $hour" +"%F - %R:%S") $rest"
done | sort -h
2014-11-12 - 00:08:03 lat = 41.937911; lon = /93.369249<br>
2014-11-12 - 00:11:29 lat = 41.949656; lon = /93.329133<br>
2014-11-12 - 00:23:02 lat = 42.025385; lon = /93.347026<br>
2014-11-12 - 00:29:10 lat = 41.033341; lon = /93.380586<br>
2014-11-12 - 00:38:08 lat = 41.036720; lon = /93.436851<br>
2014-11-12 - 00:45:20 lat = 41.998129; lon = /93.400943<br>
2014-11-12 - 00:53:36 lat = 41.961489; lon = /93.414624<br>
2014-11-12 - 03:03:59 lat = 41.990516; lon = /93.430704<br>
2014-11-12 - 03:05:15 lat = 41.001546; lon = /93.443352<br>
Это будет работать над вашим примером, но не удастся, если вам также нужно сортировать февраль ( 02
) до ноября ( 11
). Таким образом, хитрость состоит в том, чтобы напечатать даты как секунд со времени эпохи , сортировать по этому и затем удалить его:
$ sed 's#-#/#g' file | while read date _ hour rest; do
printf "%s\t%s %s\n" "$(date -d "$date $hour" +"%s")" "$date - $hour" "$rest"
done | sort | cut -f 2-
11/12/2014 - 12:08:03AM lat = 41.937911; lon = /93.369249<br>
11/12/2014 - 12:11:29AM lat = 41.949656; lon = /93.329133<br>
11/12/2014 - 12:23:02AM lat = 42.025385; lon = /93.347026<br>
11/12/2014 - 12:29:10AM lat = 41.033341; lon = /93.380586<br>
11/12/2014 - 12:38:08AM lat = 41.036720; lon = /93.436851<br>
11/12/2014 - 12:45:20AM lat = 41.998129; lon = /93.400943<br>
11/12/2014 - 12:53:36AM lat = 41.961489; lon = /93.414624<br>
11/12/2014 - 03:03:59AM lat = 41.990516; lon = /93.430704<br>
11/12/2014 - 03:05:15AM lat = 41.001546; lon = /93.443352<br>
11/12/2014 - 03:11:50AM lat = 42.039054; lon = /93.442001<br>
Или для печати дат в формате 24H:
$ sed 's#-#/#g' file | while read date _ hour rest; do
printf "%s\t%s %s\n" "$(date -d "$date $hour" +"%s")" \
"$(date -d "$date $hour" +"%F - %R:%S")" "$rest"
done | sort | cut -f 2-
2014-11-12 - 00:08:03 lat = 41.937911; lon = /93.369249<br>
2014-11-12 - 00:11:29 lat = 41.949656; lon = /93.329133<br>
2014-11-12 - 00:23:02 lat = 42.025385; lon = /93.347026<br>
2014-11-12 - 00:29:10 lat = 41.033341; lon = /93.380586<br>
2014-11-12 - 00:38:08 lat = 41.036720; lon = /93.436851<br>
2014-11-12 - 00:45:20 lat = 41.998129; lon = /93.400943<br>
2014-11-12 - 00:53:36 lat = 41.961489; lon = /93.414624<br>
2014-11-12 - 03:03:59 lat = 41.990516; lon = /93.430704<br>
2014-11-12 - 03:05:15 lat = 41.001546; lon = /93.443352<br>
2014-11-12 - 03:11:50 lat = 42.039054; lon = /93.442001<br>
-121--196297- я бы использовал awk
с сортировкой
:
awk '{while("date +%T -d" $3|getline x){$3=x}}1' logfile | sort -t- -n -k3 -k1 -k2
Позволяет сначала немного изменить журнал, чтобы иметь другие даты:
11-12-2010 - 03:03:59AM lat = 41.990516; lon = -93.430704
11-12-1998 - 03:05:15AM lat = 41.001546; lon = -93.443352
11-12-2030 - 03:11:50AM lat = 42.039054; lon = -93.442001
11-12-2014 - 12:08:03AM lat = 41.937911; lon = -93.369249
11-12-2014 - 12:11:29AM lat = 41.949656; lon = -93.329133
11-11-2014 - 12:23:02AM lat = 42.025385; lon = -93.347026
11-12-2011 - 12:29:10AM lat = 41.033341; lon = -93.380586
11-12-2011 - 12:38:08AM lat = 41.036720; lon = -93.436851
10-12-2014 - 12:45:20AM lat = 41.998129; lon = -93.400943
11-12-2014 - 12:53:36AM lat = 41.961489; lon = -93.414624
Результат будет:
11-12-1998 - 03:05:15 lat = 41.001546; lon = -93.443352
11-12-2010 - 03:03:59 lat = 41.990516; lon = -93.430704
11-12-2011 - 00:29:10 lat = 41.033341; lon = -93.380586
11-12-2011 - 00:38:08 lat = 41.036720; lon = -93.436851
10-12-2014 - 00:45:20 lat = 41.998129; lon = -93.400943
11-11-2014 - 00:23:02 lat = 42.025385; lon = -93.347026
11-12-2014 - 00:08:03 lat = 41.937911; lon = -93.369249
11-12-2014 - 00:11:29 lat = 41.949656; lon = -93.329133
11-12-2014 - 00:53:36 lat = 41.961489; lon = -93.414624
11-12-2030 - 03:11:50 lat = 42.039054; lon = -93.442001
Хитрость здесь состоит в том, чтобы использовать -
в качестве разделителя полей и сортировать сначала по 3-му полю (год), затем по первому (месяц), затем по второму (день). Все операции сортировки являются числовыми (опция -n
).
С помощью python и модуля dateutil
(pip install dateutil
) можно производить сортировку непосредственно на объектах даты:
#! /usr/bin/env python
import sys
from dateutil.parser import parse
lines = []
for line in open(sys.argv[1]):
d, rest = line[:24], line[24:]
lines.append((parse(d), rest))
for x in sorted(lines):
print x[0], x[1],
начиная с python program.py inputfile
Это можно делать без dateutil
, но преимущество его использования заключается в том, что вам не нужно указывать формат времени ввода, пока он не будет неоднозначным.
Это можно сделать с помощью команды GNU date
. Она может взять строки и распечатать соответствующую дату:
$ date -d "11/11/2014 04:12:03PM"
Tue Nov 11 16:12:03 CET 2014
Обратите внимание, однако, что ей не нравится DD-MM-YYY
:
$ date -d "11-11-2014"
date: invalid date ‘11-11-2014’
Итак, сначала запустите sed
в своем файле, чтобы заменить все -
на /
. Затем пропустите это через -
, чтобы получить каждое поле в отдельную переменную, конвертируйте и сортируйте:
$ sed 's#-#/#g' file | while read date _ hour rest; do
echo "$(date -d "$date $hour" +"%F - %R:%S") $rest"
done | sort -h
2014-11-12 - 00:08:03 lat = 41.937911; lon = /93.369249<br>
2014-11-12 - 00:11:29 lat = 41.949656; lon = /93.329133<br>
2014-11-12 - 00:23:02 lat = 42.025385; lon = /93.347026<br>
2014-11-12 - 00:29:10 lat = 41.033341; lon = /93.380586<br>
2014-11-12 - 00:38:08 lat = 41.036720; lon = /93.436851<br>
2014-11-12 - 00:45:20 lat = 41.998129; lon = /93.400943<br>
2014-11-12 - 00:53:36 lat = 41.961489; lon = /93.414624<br>
2014-11-12 - 03:03:59 lat = 41.990516; lon = /93.430704<br>
2014-11-12 - 03:05:15 lat = 41.001546; lon = /93.443352<br>
Это сработает на вашем примере, но не сработает, если вам также понадобится сортировать февраль (02
) до ноября (11
). Итак, фокус в том, чтобы распечатать даты как секунды с эпохи, отсортировать их и затем удалить:
$ sed 's#-#/#g' file | while read date _ hour rest; do
printf "%s\t%s %s\n" "$(date -d "$date $hour" +"%s")" "$date - $hour" "$rest"
done | sort | cut -f 2-
11/12/2014 - 12:08:03AM lat = 41.937911; lon = /93.369249<br>
11/12/2014 - 12:11:29AM lat = 41.949656; lon = /93.329133<br>
11/12/2014 - 12:23:02AM lat = 42.025385; lon = /93.347026<br>
11/12/2014 - 12:29:10AM lat = 41.033341; lon = /93.380586<br>
11/12/2014 - 12:38:08AM lat = 41.036720; lon = /93.436851<br>
11/12/2014 - 12:45:20AM lat = 41.998129; lon = /93.400943<br>
11/12/2014 - 12:53:36AM lat = 41.961489; lon = /93.414624<br>
11/12/2014 - 03:03:59AM lat = 41.990516; lon = /93.430704<br>
11/12/2014 - 03:05:15AM lat = 41.001546; lon = /93.443352<br>
11/12/2014 - 03:11:50AM lat = 42.039054; lon = /93.442001<br>
Или распечатать даты в формате 24H:
$ sed 's#-#/#g' file | while read date _ hour rest; do
printf "%s\t%s %s\n" "$(date -d "$date $hour" +"%s")" \
"$(date -d "$date $hour" +"%F - %R:%S")" "$rest"
done | sort | cut -f 2-
2014-11-12 - 00:08:03 lat = 41.937911; lon = /93.369249<br>
2014-11-12 - 00:11:29 lat = 41.949656; lon = /93.329133<br>
2014-11-12 - 00:23:02 lat = 42.025385; lon = /93.347026<br>
2014-11-12 - 00:29:10 lat = 41.033341; lon = /93.380586<br>
2014-11-12 - 00:38:08 lat = 41.036720; lon = /93.436851<br>
2014-11-12 - 00:45:20 lat = 41.998129; lon = /93.400943<br>
2014-11-12 - 00:53:36 lat = 41.961489; lon = /93.414624<br>
2014-11-12 - 03:03:59 lat = 41.990516; lon = /93.430704<br>
2014-11-12 - 03:05:15 lat = 41.001546; lon = /93.443352<br>
2014-11-12 - 03:11:50 lat = 42.039054; lon = /93.442001<br>