Часовые пояса в платформе 1С

05.04.15

База данных - Инструменты администратора БД

Речь пойдёт о крупных организациях, сводящих в единую информационную систему данные из источников, находящихся в разных часовых поясах. В процессе обработки, скорее всего, будут использоваться вызовы СмещениеСтандартногоВремени(), УниверсальноеВремя() и т.п., которые работают неправильно во многих релизах без явного указания часовых поясов.

Историческая справка.

https://ru.wikipedia.org/wiki/%C2%F0%E5%EC%FF_%E2_%D0%EE%F1%F1%E8%E8#.D0.98.D0.B7.D0.BC.D0.B5.D0.BD.D0.B5.D0.BD.D0.B8.D1.8F_2014_.D0.B3.D0.BE.D0.B4.D0.B0

И хотя Microsoft выпустил обновление 2998527 для учёта этих изменений в Windows ещё в сентябре 2014-го, это мало помогло 1С-ным учётным системам. 1C использует для работы с часовыми поясами стороннюю библиотеку ICU, слегка допиленную 1Совцами под свои нужды, а база часовых поясов вшита внутрь библиотеки ICU. 1С привела базу поясов в соответствие законодательству с выпуском релизов 8.2.19.116 и 8.3.5.1231 от 21 октября 2014 года.


Реализация.

Не секрет, что крупные организации обладают большой инерцией в вопросах обновления ПО, связанной с техническими или политическими особенностями работы внутренних служб сопровождения. Поэтому, обычно, решение данного вопроса сводится к костылям вроде ведения собственной базы часовых поясов филиалов, или выбора в ОС таких часовых поясов, которым в базе платформы соответствуют правильные смещения времени.

Здесь я хочу показать правильное решение данного вопроса для тех, кто не готов обновить платформу.

Как раз для таких ситуаций, ICU позволяет читать обновлённую базу часовых поясов из внешних файлов. Для обозначения расположения файлов нужно определить системную переменную окружения ICU_DATA, которой нужно присвоить путь к папке. Внутри следует разместить папку с именем вида icudtXXl, где XX – версия ICU, используемая платформой. Свою версию вы можете определить по имени файла icudtXX.dll в папке bin установленной платформы 1С. Внутри папки для соответствующей версии следует расположить файлы обновлённой базы часовых поясов – четыре файла, которые можно скачать по ссылке http://source.icu-project.org/repos/icu/data/trunk/tzdata/icunew/2015b/44/le/

Пример для 8.3.4.496:

  1. Создаём папку C:\ICU_DATA\icudt46l

  2. Скачиваем в неё все файлы по указанной ссылке.

  3. Устанавливаем переменную окружения ICU_DATA= C:\ICU_DATA\

  4. Перезапускаем 1С.

  5. profit Smile

Для серверных вызовов эти шаги нужно выполнить на сервере приложений, для клиентских – на клиентских компьютерах с помощью групповых политик.


Для linux не проверял, но, если сервер приложений умеет читать глобальные переменные окружения, должно работать аналогично:

  1. Создаём /opt/icu/icudt46l/

  2. Размещаем файлы

  3. В /etc/environment указываем ICU_DATA=/opt/icu/

часовой пояс филиал

См. также

Автоподбор ролей для профилей и групп доступа в любых типовых базах 1С УТ 11, КА 2, ERP2, Розница 2/3, УНФ 16/3, БП 3, ЗУП 3 и подобных (УФ, Платформа 8.3.14+)

Инструменты администратора БД Роли и права 8.3.14 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:Документооборот 1С:Зарплата и кадры государственного учреждения 3 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Зарплата и Управление Персоналом 3.x 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Платные (руб)

Роли… Вы тратите много времени и сил на подбор ролей среди около 2400 в ERP или 1500 в Рознице 2, пытаясь понять какими правами они обладают? Вы все время смотрите права в конфигураторе или отчетах чтоб создать нормальные профили доступа? Вы хотите наглядно видеть какие права дает профиль и редактировать все в простом виде? А может хотите просто указать подсистему и дать права на просмотр и добавление на объекты и не лезть в дебри прав и чтоб обработка сама подобрала нужные роли? Все это теперь стало возможно! Обновление от 15.12.2023, версия 1.1.

12000 руб.

06.12.2023    2961    12    1    

34

SALE! 20%

Infostart УДиФ: Управление данными и формами

Инструменты администратора БД Инструментарий разработчика Роли и права Платформа 1С v8.3 Конфигурации 1cv8 Россия Платные (руб)

Расширение позволяет без изменения кода конфигурации выполнять проверки при вводе данных, скрывать от пользователя недоступные ему данные, выполнять код в обработчиках. Не изменяет данные конфигурации, легко устанавливается практически на любую конфигурацию на управляемых формах.

10000 8000 руб.

10.11.2023    3492    11    1    

33

SALE! 30%

PowerTools

Инструментарий разработчика Инструменты администратора БД Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Россия Платные (руб)

Универсальный инструмент программиста для администрирования конфигураций. Сборник наиболее часто используемых обработок под единым интерфейсом.

3600 2520 руб.

14.01.2013    177719    1073    0    

849

Ускоренное проведение документов (x4), устранение ошибок 60/62 счетов и зачет авансов (Бухгалтерия 3.0)

Закрытие периода Инструменты администратора БД Корректировка данных Бухгалтерский учет 1С:Бухгалтерия 3.0 Россия Бухгалтерский учет Платные (руб)

Расширение «Оперативное проведение» в 4 раза уменьшает время проведения документов и закрытия месяца. Является комплексным решением проблем 62 и 60 счетов. Оптимизирует проведение при включенной функциональной опции «Раздельный учет НДС». Используется в более 10 организациях уже 2 года. Совместимо с конфигурацией Бухгалтерия 3.0 (+КОРП).

14400 руб.

29.04.2020    27367    79    146    

59

Система хранения присоединенных файлов в томах на диске

Инструменты администратора БД Платформа 1С v8.3 1С:Комплексная автоматизация 1.х 1С:Управление производственным предприятием Платные (руб)

Конфигурация Комплексная автоматизация 1.1 (и УПП 1.3 тоже) хранит файлы и изображения в справочнике Хранилище дополнительной информации в реквизите Хранилище типа ХранилищеЗначений. Та же история с ВложениямиЭлектроннойПочты. Но при этом присоединенные файлы в Электронном документообороте хранит в томах на диске. Эта доработка позволяет использовать стандартный механизм хранения файлов, изображений и вложений электронных писем в томах на диске. При этом можно разделить тома хранения по объектам конфигурации.

4200 руб.

10.11.2015    61307    88    59    

73

"Менеджер потоков 2.1": УПП: "Восстановление партий"

Инструменты администратора БД Платформа 1С v8.3 1С:Управление производственным предприятием Россия Бухгалтерский учет Управленческий учет Платные (руб)

Как оптимизировать то, что, считалось, не поддается оптимизации? Как повысить доступность базы данных? Как проводить самую «времяемкую» операцию не по паре раз в неделю, а по несколько раз в день*? Ответ есть!

20000 руб.

12.09.2019    11742    5    9    

7

Брандмауэр для сервера 1С Предприятие 8 - внешнее управление сеансами

Инструменты администратора БД Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

Управление возможностью начала и возобновления сеансов пользователей по различным условиям, ограничение общего числа возможных сеансов для работы с информационной базой, резервирование возможности работы с информационной базой определенных польззователей, запрет запуска нескольких сеансов для пользователя, журнализация событий начала (возобновления) и завершения (гибернации) сеансов, ведение списка активных сеансов для информационных баз кластера серверов

3600 руб.

06.02.2017    31104    31    18    

47

Хранилище файлов на SQL

Инструменты администратора БД Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Управленческий учет Платные (руб)

Привязка файлов / сканов к объектам 1С с сохранением их на SQL-сервере

12000 руб.

09.10.2019    10973    5    8    

9
Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. pumbaE 05.04.15 13:27 Сейчас в теме
Хабр подал идею, вы надеюсь проверили у себя.
Но на вопрос как проводить оперативно на одном сервере с клиентов с различными часовыми поясами вы ответ и не дали.
При открытии списка документов, как понять что этот документ с временем 13:00 проведен из другого часового пояса, не понятно.
2. berezdetsky 620 05.04.15 15:28 Сейчас в теме
(1) Проверил. :)

Вопрос немного в другом. Наверно, я не очень понятно описал сценарий использования. Оператору в центре мало интересно, был данный документ проведён из другого часового пояса. Суть в том, чтобы правильно разместить во времени события, возникающие в других системах и в других часовых поясах. И в том, чтобы, передавая данные в такие системы, можно было бы указать правильное локальное время.

И даже если высокая точность здесь не нужна, обычно вызывают много вопросов документы из будущего, возникающие просто потому, что СмещениеСтандартногоВремени() для московского часового пояса возвращает четыре часа вместо трёх.
3. palagutin.as 19.07.16 04:17 Сейчас в теме
Всем привет! Подскажите кто сможет или знает про оперативное проведение в разных часовых поясах…
Сервер 1с (8.3.7.2008, УПП 1.3.79.2) запущен во Владивостоке, пользователи работают через РДП (Srv2008r2, толстый клиент 1с) в Москве, оперативное проведение документов работает отлично!
Но переустановив Терминальный Сервер на 2012r2 (политику проброса часового пояса настроил), оперативное проведение стало выдавать ошибку - «Дата документа не соответствует текущей дате или дате последнего оперативно проведенного документа! Документ не может быть проведен оперативно.» в тот момент, когда в Москве пробило 17:00 а во Владивостоке настал новый день!
Какая зависимость может быть в сервере, если на старом терминальном сервере оперативное проведение работает до сих пор а заходим на новый сервер терминалов, 1с выдает ошибку, именно после 17:00?
4. berezdetsky 620 19.07.16 13:05 Сейчас в теме
Оставьте свое сообщение