Назад | Перейти на главную страницу

Системное время Windows Server 2008 R2 случайным образом сбрасывается на 4 часа в прошлом

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

Например, если фактическое время - 16:00 по восточному стандартному времени, системные часы будут показывать 12:00. Если вы снова сбросите системные часы вперед на правильное время, они снова случайным образом вернутся на 4 часа назад.

Я проверил программу просмотра событий и увидел некоторые события «Общее ядро», связанные с изменениями времени. Вот пример:

<?xml version="1.0" encoding="UTF-8"?>
<Event xmlns="http://schemas.microsoft.com/win/2004/08/events/event">
  <System>
    <Provider Name="Microsoft-Windows-Kernel-General" Guid="{A68CA8B7-004F-D7B6-A698-07E2DE0F1F5D}" />
    <EventID>1</EventID>
    <Version>0</Version>
    <Level>4</Level>
    <Task>0</Task>
    <Opcode>0</Opcode>
    <Keywords>0x8000000000000010</Keywords>
    <TimeCreated SystemTime="2014-05-09T17:04:34.500000000Z" />
    <EventRecordID>39254</EventRecordID>
    <Correlation />
    <Execution ProcessID="4" ThreadID="68" />
    <Channel>System</Channel>
    <Computer>SERVER</Computer>
    <Security UserID="S-1-5-18" />
  </System>
  <EventData>
    <Data Name="NewTime">2014-05-09T17:04:34.500000000Z</Data>
    <Data Name="OldTime">2014-05-09T21:05:19.806811800Z</Data>
  </EventData>
</Event>

Это событие было создано около 17:00. После этого события системное время показывало 13:00, что на 4 часа отставало от текущего времени.

Установка и запуск службы времени Windows и настройка ее для внешней синхронизации времени не решают проблему. Синхронизация времени в Интернете установит время правильно, а затем время снова будет сброшено в случайном порядке.

Эта проблема также возникает каждый раз при перезагрузке компьютера.

Кто-нибудь когда-нибудь слышал об этой проблеме или знает решение?

По умолчанию Windows ожидает, что часы BIOS будут установлены на местное время, не УНИВЕРСАЛЬНОЕ ГЛОБАЛЬНОЕ ВРЕМЯ. Это не так под Linux и друзьями. (Что приносит удовольствие в системе с двойной загрузкой.)

Windows в последнее время добавлен параметр реестра что позволяет установить часы BIOS на UTC. Однако этот параметр официально не поддерживается и, как известно, вызывает проблемы. http://blogs.technet.com/b/askds/archive/2012/03/09/unresponsive-servers-due-to-dst-and-an-unsupported-registry-key.aspx

С чисто технической точки зрения «лучше» сохранять часы BIOS в формате UTC. Тем не менее, в Windows есть много исторического багажа, который ожидает, что часы BIOS будут соответствовать местному времени, поэтому вам не следует связываться с этой настройкой, если у вас нет конкретной причины для этого.

Итак, мои рекомендации заключаются в том, чтобы настроить часы BIOS на местный часовой пояс, убедиться, что ваш часовой пояс установлен правильно в Windows, и убедитесь, что у вас есть служба времени Windows, настроенная для использования внешнего источника NTP (поскольку вы не находитесь в домен, используйте для этого w32tm из командной строки).