В ночь с 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. В PHP может использоваться собственная база часовых поясов, в этом случае требуется обновить пакет http://pecl.php.net/package/timezonedb
Дополнительно стоит обратить внимание на логику вычисления отрезков времени в биллинговых системах и прочих службах. С 2011 года, когда был отменён переход на зимнее/летнее время, успели появиться приложения, не учитывающие сдвиг на час, что чревато списанием/начислением лишнего часа и прочими неприятными эффектами, проявляющимися при запуске программ в "исчезнувший" час.
URL:
Обсуждается: https://www.opennet.ru/tips/info/2861.shtml