В ночь с 25 на 26 октября в РФ будет осуществлён переход на постоянное зимнее
время. Астрономический полдень сдвинется с 14 до 13 часов, темнеть в декабре
будет в 4 часа дня, а светать в 9 утра, в июле темнеть будет в 10 вечера, а
светать в 3 ночи. Для "сов" наступает настоящий кошмар :-)
Для систем, время поддержки которых не истекло параметры перевода часов уже
поступили с очередным обновлением. Для устаревших систем придётся обновлять
данные часовых поясов вручную. Обновления содержимого базы данных часовых
поясов можно получить с сайта ftp://ftp.iana.org/tz/releases/
Для ручного обновления базы часовых поясов загружаем свежую версию архива tzdata:
mkdir tz
cd tz
wget ftp://ftp.iana.org/tz/releases/tzdata2014i.tar.gz
Распаковываем:
tar xzf tzdata2014i.tar.gz
Смотрим . запланированы ли правила перевода часов:
zdump -v Asia/Yekaterinburg |grep 2014
Если команда ничего не выдала, значит в системе установлена старая база часовых
поясов и её нужно обновить.
Ищем нужный город в файлах asia или europe, географически положение может не
совпадать, например, Екатеринбург находится в Азии, но указан в файле europe.
Компилируем часовые пояса из файла europe. Утилита zic читает текстовый файл с
описаниями зон и на выходе формирует бинарные файлы специального формата и
сохраняет их в директорию /usr/share/zoneinfo (изменить директорию можно флагом "-d"):
zic europe
Скомпилированные файлы параметров часовых поясов будут сохранены в файле
/usr/share/zoneinfo/Asia/Yekaterinburg, который нужно скопировать в файл
/etc/localtime, определяющий текущий часовой пояс:
cp /etc/localtime /etc/localtime.old
cp -f /usr/share/zoneinfo/Asia/Yekaterinburg /etc/localtime
После обновления в выводе zdump должно появиться правило перевода часов:
zdump -v Asia/Yekaterinburg |grep 2014
Asia/Yekaterinburg Sat Oct 25 19:59:59 2014 UTC = Sun Oct 26 01:59:59 2014 YEKT isdst=0 gmtoff=21600
Asia/Yekaterinburg Sat Oct 25 20:00:00 2014 UTC = Sun Oct 26 01:00:00 2014 YEKT isdst=0 gmtoff=18000
При использовании PostgreSQL требуется не забыть обновить внутреннюю базу
часовых поясов данной СУБД, которая расположена в директории
/usr/local/pgsql/share/timezone (меняем
/usr/local/pgsql/share/timezone/Asia/Yekaterinburg и перезапускаем PostgreSQL).
В PHP может использоваться собственная база часовых поясов, в этом случае
требуется обновить пакет http://pecl.php.net/package/timezonedb
Дополнительно стоит обратить внимание на логику вычисления отрезков времени в
биллинговых системах и прочих службах. С 2011 года, когда был отменён переход
на зимнее/летнее время, успели появиться приложения, не учитывающие сдвиг на
час, что чревато списанием/начислением лишнего часа и прочими неприятными
эффектами, проявляющимися при запуске программ в "исчезнувший" час.
|