Windows реестр установленные обновления

«Неуловимый» список установленных обновлений Windows

Вы когда-нибудь задумывались, с помощью чего формируется список установленных обновлений Windows? А через какое API его достать? Ответы на эти и другие возникающие вопросы я постараюсь дать в своём небольшом исследовании.

Предыстория или с чего всё началось.

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

Раньше на каждое «ТО» с помощью WSUS подтягивались все выпущенные обновления и распространялись на все машины. Также периодически выходили ТСБ (технические сервисные бюллетени), в которых указывалось, что требуется установить необходимые обновления в виде изолированных пакетов. В итоге у нас накапливаются обновления, которые в WSUS отследить нельзя, а можно было увидеть только через панель управления в разделе «Установленные обновления».

Бывают ситуации, когда АРМ или сервер «падает» и приходится его восстанавливать из образа, созданного некоторое время назад. При восстановлении из образа есть вероятность того, что мы можем потерять нужные нам обновления (которые пришли в виде изолированных пакетов), которые устанавливались до падения машины. Объяснил максимально подробно насколько мог, потому что уточнения будут уже коммерческой тайной.

Вот поэтому и возникла идея создать программу, которая бы могла извлечь этот список обновлений (желательно удаленно по локальной сети), записать в файл/базу, сравнить текущий перечень с неким шаблоном и выдать сообщение на SCADA систему через один из протоколов — SNMP, OPC.

Как вы могли догадаться из названия статьи, уже на выборе метода получения списка у меня возникла непростая задача. Я, как обычно, решил поискать нужное в поисковике, задал вопросы на профильных ресурсах (раз, два, на английском stackoverflow почему-то не понравился мой вопрос и его пришлось удалить), но все ответы не давали нужного результата. Поэтому пришлось разбираться самому, о чем и пойдет речь далее.

Консольные команды

Начнем с простого и воспользуемся тем, что предлагает нам Windows без использования сторонних средств. Это можно сделать с помощью следующих команд:

  • wmic qfe list
  • systeminfo
  • dism /online /get-packages
  • через PowerShell:
  • Get-HotFix
  • Get-SilWindowsUpdate (доступно только в серверных редакциях)
  • Get-WmiObject -Class win32_quickfixengineering — через доступ к WMI классу win32_quickfixengineering (о WMI чуть позже)

Получить список через графический интерфейс можно через стандартный пункт Панели управления «Установка/удаление программ», но скопировать оттуда мы ничего не можем. Каждый инструмент панели управления представлен файлом .cpl в папке Windows\System. Файлы .cpl в системную папку Windows автоматически загружаются при запуске панели управления. За пункт Программы отвечает файл Appwiz.cpl. Его анализ ни к чему не привел.

Вывод консольной команды можно перенаправить в файл и дальше начать его парсить, но это неправильно, плюс вызов программы (по правилам СБ не пройдет) и об удаленном получении списка речь не идёт. Поэтому предлагаю вам просто вызвать команды, сравнить количество обновлений в каждом списке, со списком через Панель управления и продолжить наше расследование дальше.

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

Все методы проверялись на чистых образах систем (Windows 7, 8, Server 2012 R2) с интегрированными обновлениями, после каждого обновления через Центр обновления с официальных серверов Microsoft проводилась дополнительная проверка. Остановимся на каждом из них подробнее.

Примечание: далее для своего удобства все результаты я буду вставлять в List. Это, возможно, не рационально, но тогда мне это казалось хорошей идеей.

Есть и вторая вариация этого метода: Update Session — получение информации с помощью подключения к сессии обновления Windows Update Agent (в данном случае работаем не напрямую с библиотекой).

Microsoft подсказывает об удаленном использовании API.

Главный минусы этих двух методов — не позволяют найти исправления KB, которые не распространяются через Центр обновления Windows. Можно увидеть только то, что прошло через сам агент обновления, то есть данный вариант нас не устраивает.

Система обслуживания образов развертывания и управления ими (Deployment Image Servicing and Management) — это средство командной строки, которое может использоваться для обслуживания образа Windows или для подготовки образа среды предустановки Windows (Windows PE). Является заменой диспетчера пакетов (Pkgmgr.exe), PEimg и Intlcfg.

Данная утилита используется для интеграции обновлений, сервис паков в образ системы. Обновления Windows представляют собой отдельные модули, которые могут быть представлены в нескольких вариантах:

  • .cab-файлы (Cabinet) — архивы. Предназначены для распространения и установки при помощи модулей Центра обновлений Windows в автоматизированном режиме;
  • .msu-файлы (Microsoft Update Standalone Package) — исполняемые файлы. Предназначены для распространения и установки самими пользователями в ручном режиме через каталог обновлений Microsoft. Фактически представляют собой упакованный набор, состоящий из .cab-, .xml, .txt-файлов.

Ранее упомянутая команда dism /online /get-packages отображает основную информацию обо всех пакетах в wim образе/текущей системе. Microsoft позаботилась о нас и предоставляет NuGet packages для удобного использования API.

Количество обновлений совпадало с количеством из списка Панели управления до первого апдейта через центр управления — после него количество обновлений стало меньше (было 214, стало 209), хотя по логике они должны были увеличиться. Примеры вывода До обновления, После обновления.

С чем это связано я могу только предполагать — возможно, какие-то обновления замещали предыдущие, следовательно, и количество стало меньше.

Чуть позже я наткнулся на утилиту от китайцев DISM++, которая основана не на DISM API или DISM Core API, но имеющиеся в ней библиотеки не имеют нужных мне открытых методов, поэтому я забросил эту идею и продолжил поиски дальше.

Windows Server Update Services (WSUS) — сервер обновлений операционных систем и продуктов Microsoft. Сервер обновлений синхронизируется с сайтом Microsoft, скачивая обновления, которые могут быть распространены внутри корпоративной локальной сети. Опять же специальный инструмент, предназначенный для работы с обновлениями.

Распространяется только на серверных редакциях ОС Windows, поэтому был развернут следующий стенд:

  • основная система – Windows Server 2016;
  • а через систему виртуализации Hyper-V были развернуты две клиентские ОС:
    • Windows 8.1
    • Windows 7

Все системы соединены в единую виртуальную локальную сеть, но без выхода в сеть Интернет.

Чтобы не выделять раздел жесткого диска для новой системы я пользуюсь WinNTSetup и устанавливаю систему в VHD диски — загрузчик, начиная с Windows 7 (редакций Professional/Ultimate), прекрасно справляется с загрузкой с образа диска. Полученные таким образом диски можно спокойно использовать и в Hyper-V — убиваете сразу двоих зайцев. Не забудьте только сделать заранее копию хранилища BCD через команду bcdedit /export e:\bcd_backup.bcd.

Настраивать AD для рассылки обновлений я не захотел, поэтому просто прописал в групповых политиках путь к WSUS серверу:

Обязательно уделите внимание на порт, я из-за опечатки (8350 вместо 8530) не мог получить обновления на клиентских машинах, хотя сделано было всё верно. Так же названия пунктов в групповых политиках на Windows 7 и Windows 8 различаются.

Для получения отчета средствами WSUS необходимо дополнительно установить пакет — система уведомит вас об этом.

Так как интернета нет, то ситуация с обновлениями выходит как на скриншоте ниже:

Поведение похоже на WUApi — если обновления не прошли через них, то они не знают об этом. Поэтому данный метод снова не подходит.

Windows Management Instrumentation (WMI) в дословном переводе — инструментарий управления Windows.

WMI — реализованный корпорацией Майкрософт стандарт управления предприятием через Интернет для централизованного администрирования и слежения за работой различных частей компьютерной инфраструктуры под управлением платформы Windows. WMI является открытой унифицированной системой интерфейсов доступа к любым параметрам операционной системы, устройствам и приложениям, которые функционируют в ней.

Данный метод позволяет получить данные как с локальной машины, так и удаленно в пределах локальной сети. Для обращения к объектам WMI используется специфический язык запросов WMI Query Language (WQL), который является одной из разновидностей SQL. Получать список мы будем через WMI класс win32_quickfixengineering.

Количественно всё совпадает (даже после обновлений), поэтому было решено использовать этот метод. Для программного создания WMI запросов советую использовать следующую утилиту — WMI Delphi Code Creator. Благодаря ей я немного по другому взглянул на свой код и решил использовать заготовку из этой программы.

Полученные данные методом WMI меня не остановили, и я решился на „поверхностный реверс-инжиниринг“. Воспользуемся утилитой Process Monitor из сборника программ Sysinternals Suite для выявления файлов и ветвей реестра, которые используются при вызове выше перечисленных консольных команд и обращению к пункту „Установленные обновления“ через Панель управления.

Моё внимание привлек файл wuindex.xml, расположенный в папке C:\Windows\servicing\Packages\. Для его анализа была написана следующая программа:

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

Вот мы подошли к тому, с чем связаны все эти методы. Продолжая анализ логов Process Monitor я выявил следующие папки и файлы.

Файл DataStore.edb, расположенный в папке C:\Windows\SoftwareDistribution\DataStore. Это база данных, в которой содержится история всех обновлений установленной версии Windows, включая те обновления, которые только стоят в очереди.

Для анализа файла DataStore.edb использовалась программа ESEDatabaseView. В БД существует таблица tbUpdates, содержимое которой трудно интерпретировать.

После мое внимание привлек процесс TiWorker.exe, который вызывался каждый раз при открытии пункта в Панели управления. Он „ходил“ по многим папкам, одна из которых вывела меня на верный путь.

C:\Windows\SoftwareDistribution — это папка, используемая службой обновления Windows для загрузки обновлений на компьютер с последующей их установкой, а также хранит сведения обо всех ранее установленных обновлениях.

Папка WinSxS, расположенная по адресу C:\Windows\winsxs. Это служебная папка операционной системы Windows служащая для хранения ранее установленных версий системных компонентов. Благодаря ее наличию существует возможность отката к более старой версии обновления в случае необходимости.

C:\Windows\servicing — основная составляющая всей системы, имя которой Component-Based Servicing (CBS).

CBS — обслуживание на основе компонентов, составляющая Windows, интегрированная с службой Windows Update. В противоположность обслуживанию на основе файлов File-Based Servicing (FBS) (для ОС, предшествующих Windows Vista), в котором файлы обновлялись прямо в системных директориях, в CBS появилась целая иерархия директорий и целое семейство (стек) модулей/библиотек обслуживания.

CbsApi.dll — основная библиотека поддержки технологии CBS. Не имеет открытых методов, поэтому напрямую использовать её я не смог. Microsoft использует TrustedInstaller.exe и TiWorker.exe для доступа к методам данной библиотеки и уже через эти процессы выводит нужные нам данные. ‪Записи ведутся в C:\Windows\Logs\CBS\CBS.log.

На момент создания прототипа программы (на скриншотах можете увидеть май 2019) русскоязычной информации о CBS не было, но в конце августа нашлась очень хорошая статья в блоге — http://datadump.ru/component-based-servicing. Очень интересная статья, которая подтвердила мой опыт и собрала в себе нужную информацию. И ещё по теме: http://www.outsidethebox.ms/17988/

Вывод

Microsoft слишком усложнила тривиальную задачу по получению списка обновлений и сделала этот процесс не совсем явным. Всё это сделано для безопасности, но не для простоты использования. Соглашусь с автором статьи — в получении обновлений стали отсутствовать предсказуемость и прозрачность.

В результате исследования была написана следующая программа, демонстрацию работы которой можно увидеть в данном видео:

В планах дописать:

  1. сравнение списка необходимых обновлений с полученным;
  2. передать результат по протоколу SNMP/OPC (если у кого есть опыт поделитесь в комментариях);
  3. организовать установку недостающих „офлайн“ обновлений из указанной папки.

Если вы знаете ещё методы получения списка не только обновлений, но и дополнительных компонентов (Adobe Flash, Acrobat Reader и т.д.) или у вас есть другие интересные предложения, напишите об этом в комментариях или в личные сообщения — буду рад любой обратной связи. И поучаствуйте в опросе к данной статье — так я буду знать, будет ли интересен мой опыт аудитории Habrahabr.

Только зарегистрированные пользователи могут участвовать в опросе. Войдите, пожалуйста.

Windows реестр установленные обновления

Advanced Member Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору aleksey1965
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall — из этой ветки реестра строится список установленных программ и обновлений.
Также информация об установленных обновлениях есть в ключе HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Updates Всего записей: 788 | Зарегистр. 04-11-2012 | Отправлено: 20:31 27-10-2014

botva0

Junior Member

Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору не совсем по теме, но можно удалять обновления не только из списка установленных.

Код:

wusa.exe /uninstall /kb:11111111

(вместо единиц — номер обновления)

Всего записей: 151 | Зарегистр. 05-04-2009 | Отправлено: 23:51 30-10-2014 | Исправлено: botva0, 23:53 30-10-2014
aleksey1965

Junior Member

Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору wusa.exe /uninstall /kb:11111111 — у меня не работает, наверное потому-что этот список установленных обновлений куда-то и исчез, и wusa.exe не может ничего найти.
Вот и хочу удалить самое первое обновление Windows Update Agent, а список установленных обновлений пустой, хотя неделю назад их было порядка 150 штук.
Знаю, это не поможет решению проблемы, нужно как-то переустанавливать Windows Update Agent 7.6.7600.256, у которого нет инсталлятора. Установки более раннего v7.4.7600.226 и более позднего 7.6.7600.320 дают ошибки. Переустановка Windows через обновление после более 150 установленных обновлений уже не идет, помогло бы Windows 7 SP2, но Майкрософт не делает его.
Вот и в процессе не решенной до сих пор задачи востановления службы обновлений Windows, я, чисто теоретически, задался вопросом, где, в каком месте, или каких местах, (файлах или ветке реестра) хранится список установленных обновлений. Журнал обновлений хранится в C:\Windows\SoftwareDistribution\DataStore\DataStore.edb. В HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall хранятся обновления, установленные через msiexec (*.msi файлы) или из фалов *.exe. В HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Updates хранятся обновления фреймворков. А где хранится список обновлений, которые устанавливались через wusa.exe (из *.msu и *.cab файлов).
Всего записей: 125 | Зарегистр. 08-01-2013 | Отправлено: 23:56 01-11-2014
botva0

Junior Member

Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору попробуйте вот эту хрень от мелкомягких. если не поможет, то сбросьте центр обновления, код под катом
Всего записей: 151 | Зарегистр. 05-04-2009 | Отправлено: 23:17 11-11-2014 | Исправлено: botva0, 23:22 11-11-2014
aleksey1965

Junior Member

Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору Что бы было понятно какие у меня проблемы и что я предпринимал для их решения, напишу все очень подробно.

Стоит Windows 7 SP1 x64 Ultimate (Лицензия).

Перестал работать Центр Обновлений Windows.

Произошло из-за того, что Windows стала устанавливать постоянно одни и те же обновления подряд. Отключил Windows Update. Через неделю включил и стал получать следующую картину: при попытке поиска обновлений вылетает: «Код 80073712. Произошла неизвестная ошибка Windows Update».

Попробовал все известное (или почти все):

1. Средство проверки готовности системы к обновлению: System Update Readiness Tool (Windows6.1-KB947821-v34-x64.msu) — установилось нормально, результат никакой.

2. WindowsUpdateAgent 7.4.7600.226 (WindowsUpdateAgent30-x64.exe /wuforce). Результат: «Произошла неисправимая ошибка при установке агента Windows Update».

3. Windows Update Agent version 7.6.7600.256 (По методике с Soft.Oszone.net, т. к. у этой версии нет инсталлятора).

Установка обновлений вручную из *.cab файлов:
WUClient-SelfUpdate-ActiveX

Получаем: «Система будет перезагружена через 10 сек.». После перезагрузки результат никакой.

4. WindowsUpdateAgent 7.6.7600.320 (WindowsUpdateAgent-7.6-x64. exe /wuforce). Результат: «Произошла неисправимая ошибка при установке агента Windows Update». Кстати, на момент сбоя согласно журнала обновлений стояла эта версия.

5. Сбрасывал Центр обновлений (вариант дл 64-битных версий):

net stop bits
net stop wuauserv
net stop cryptsvc
Del «%ALLUSERSPROFILE%\ApplicationData\Microsoft\Network\Downloader\qmgr*.dat»
cd /d %windir%\system32
%windir%\System32\regsvr32.exe %windir%\System32\urlmon.dll
%windir%\System32\regsvr32.exe %windir%\System32\Shdocvw.dll
%windir%\System32\regsvr32.exe %windir%\System32\Actxprxy.dll
%windir%\System32\regsvr32.exe %windir%\System32\Oleaut32.dll
%windir%\System32\regsvr32.exe %windir%\System32\Mshtml.dll
%windir%\System32\regsvr32.exe %windir%\System32\Browseui.dll
%windir%\System32\regsvr32.exe %windir%\System32\Shell32.dll
%windir%\System32\regsvr32.exe %windir%\System32\wuweb.dll
%windir%\System32\regsvr32.exe %windir%\System32\wups2.dll
%windir%\System32\regsvr32.exe %windir%\System32\wups.dll
%windir%\System32\regsvr32.exe %windir%\System32\wucltui.dll
%windir%\System32\regsvr32.exe %windir%\System32\wuaueng1.dll
%windir%\System32\regsvr32.exe %windir%\System32\wuaueng.dll
%windir%\System32\regsvr32.exe %windir%\System32\wuapi.dll
%windir%\System32\regsvr32.exe %windir%\System32\softpub.dll
%windir%\System32\regsvr32.exe %windir%\System32\wintrust.dll
%windir%\System32\regsvr32.exe %windir%\System32\initpki.dll
%windir%\System32\regsvr32.exe %windir%\System32\dssenh.dll
%windir%\System32\regsvr32.exe %windir%\System32\rsaenh.dll
%windir%\System32\regsvr32.exe %windir%\System32\gpkcsp.dll
%windir%\System32\regsvr32.exe %windir%\System32\sccbase.dll
%windir%\System32\regsvr32.exe %windir%\System32\atl.dll
%windir%\System32\regsvr32.exe %windir%\System32\jscript.dll
%windir%\System32\regsvr32.exe %windir%\System32\vbscript.dll
%windir%\System32\regsvr32.exe %windir%\System32\scrrun.dll
%windir%\System32\regsvr32.exe %windir%\System32\msxml.dll
%windir%\System32\regsvr32.exe %windir%\System32\msxml3.dll
%windir%\System32\regsvr32.exe %windir%\System32\msxml6.dll
%windir%\System32\regsvr32.exe %windir%\System32\slbcsp.dll
%windir%\System32\regsvr32.exe %windir%\System32\cryptdlg.dll
%windir%\System32\regsvr32.exe %windir%\System32\ole32.dll
%windir%\System32\regsvr32.exe %windir%\System32\qmgr.dll
%windir%\System32\regsvr32.exe %windir%\System32\qmgrprxy.dll
%windir%\System32\regsvr32.exe %windir%\System32\wucltux.dll
%windir%\System32\regsvr32.exe %windir%\System32\muweb.dll
%windir%\System32\regsvr32.exe %windir%\System32\wuwebv.dll
cd /d %windir%\SysWOW64
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\urlmon.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\Shdocvw.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\Actxprxy.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\Oleaut32.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\Mshtml.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\Browseui.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\Shell32.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\wuweb.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\wups2.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\wups.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\wucltui.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\wuaueng1.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\wuaueng.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\wuapi.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\softpub.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\wintrust.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\initpki.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\dssenh.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\rsaenh.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\gpkcsp.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\sccbase.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\atl.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\jscript.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\vbscript.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\scrrun.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\msxml.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\msxml3.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\msxml6.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\slbcsp.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\cryptdlg.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\ole32.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\qmgr.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\qmgrprxy.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\wucltux.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\muweb.dll
%windir%\SysWOW64\regsvr32.exe %windir%\SysWOW64\wuwebv.dll
ntsh reset winsock
net start wuauserv
net start cryptsvc
net start bits
pause

6. Различные Microsoft Fixit то же не помогли (испробовал их порядка 3-х штук различных версий с сайта http://support2.microsoft.com/fixit/ru для Windows Update).

7. Переустановка Windows через обновление, когда после установки SP1 установлено уже более 150 обновлений, уже не идет, вылетает ошибка. Потому что уже фактически поменялось ядро, а так же поменялось множество других системных файлов. Помог бы Windows 7 SP2, но Майкрософт не делает его.

8. Самое странное, что sfc /scannow пишет, что не нашло нарушений системных файлов. Значит где то тяжелые непоправимые (или неизвестно как поправимые) нарушения реестра.

9. Применил subinacl.exe для восстановления всех разрешений реестра:

subinacl /subkeyreg HKEY_LOCAL_MACHINE /grant=administrators=f
subinacl /subkeyreg HKEY_CURRENT_USER /grant=administrators=f
subinacl /subkeyreg HKEY_CLASSES_ROOT /grant=administrators=f
subinacl /subdirectories %SystemDrive% /grant=administrators=f
subinacl /subkeyreg HKEY_LOCAL_MACHINE /grant=system=f
subinacl /subkeyreg HKEY_CURRENT_USER /grant=system=f
subinacl /subkeyreg HKEY_CLASSES_ROOT /grant=system=f
subinacl /subdirectories %SystemDrive% /grant=system=f
pause

Windows Installer работает нормально, проверял, проблем нет.

Вообщем перепробовал все или почти все, а результат никакой.

Но, как я уже и писал, вопрос у меня не в этом. Вопрос у меня в следующем:

Список журнала обновлений по адресу: «Панель управления\ Центр обновления Windows\Просмотр журнала обновлений» формируется из файла C:\Windows\SoftwareDistribution\DataStore\DataStore.edb. С этим списком у меня все нормально.

А вот кто подскажет, откуда берется или как формируется список: «Панель управления\Программы и компоненты\Просмотр установленных обновлений» .

А этот список у меня стал пустой. Может быть поэтому и при попытке поиска обновлений вылетает: «Код 80073712. Произошла неизвестная ошибка Windows Update». А именно отсюда можно удалить Windows Update Agent, что бы попробовать его переустановить вручную или автоматически. Как восстановить этот список.

Просмотр установленных обновлений через командную строку командой wmic дает результат:
C:\Windows\system32>wmic q
No Instance(s) Available.

Просмотр установки конкретного обновления через командную строку (это обновление есть в журнале обновлений) тоже не дает результата:
C:\Windows\system32>wmic qfe list | find «2889914»
No Instance(s) Available.

Просмотр установленных обновлений через командную строку командой systeminfo дает результат:
C:\Windows\system32>systeminfo
.
Исправление(я): Н/Д
.

Может быть из-за того, что потерян этот список и идут все ошибки Windows Update.

Где он хранится или как формируется, потому что мне кажется, что Windows формирует его из нескольких источников:
1. В «HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall» хранится список обновлений, установленных через msiexec.exe (из *.msi или *.exe файлов). Записи присутствуют, но не отображаются в списке «Панель управления\Программы и компоненты\Просмотр установленных обновлений». Наверное этот список формируется не из этого ключа реестра.
2. В «HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Updates» хранится список обновлений фреймворков. Записи присутствуют, но не отображаются в списке «Панель управления\Программы и компоненты\Просмотр установленных обновлений». Наверное этот список формируется не из этого ключа реестра.
3. А где хранится список обычных обновлений, которые устанавливались через wusa.exe (из *.msu и *.cab файлов из папки C:\Windows\SoftwareDistribution\Download).

Может где то есть какой то другой ключ реестра, или какой то лог wusa.exe, откуда формируется этот список: «Панель управления\Программы и компоненты\Просмотр установленных обновлений».

P.S. У меня есть акронисовский бэкап полугодичной давности. Если бы я знал где и как лежит этот список, или из чего он формируется, я бы мог достать его оттуда и подсунуть Windows. Пусть это не совсем то, но попробовать было бы можно.

Всего записей: 125 | Зарегистр. 08-01-2013 | Отправлено: 13:29 12-11-2014 | Исправлено: aleksey1965, 18:19 12-11-2014
rmsmrd

Member

Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору Вряд ли актуально топикстартеру, но может быть полезно другим с такой же траблой.

«Проверьте, не отключены ли службы Windows Modules Installer и Windows Installer (соотвественно «Установщик модулей Windows» и «Установщик Windows», если по-русски).»

Стартуем их и вуаля.

Так же актуально для тех, у кого по команде sfc /scannow орёт «Защите ресурсов Windows не удается запустить службу восстановления»

Всего записей: 236 | Зарегистр. 21-07-2005 | Отправлено: 21:34 22-08-2016
aleksey1965

Junior Member

Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору Вопрос был не в этом.
С этим нет проблем, служба обновлений работает нормально.

Информация по адресу «Панель управления\Все элементы панели управления\Центр обновления Windows\Просмотр журнала обновлений» полностью отображается. Она хранится в файле «C:\Windows\SoftwareDistribution\DataStore\DataStore.edb». Если удалить файл DataStore.edb, журнал обновлений будет чистым. С этим все ясно.

А от где хранится информация по адресу «Панель управления\Программы\Программы и компоненты\Установленные обновления» .
В каком файле или кусте реестра .
Ответа так и нет.

Вот этот список у меня оказался чистым. То есть, если я захочу удалить какое-то обновление, то у меня это не получится. Пробовал удаление обновлений разными методами, в том числе и через командную строку — везде список чистый, то есть обновления как бы не установлены, хотя в журнале установленных обновлений ни есть. Вот и хотел узнать на форуме: возможно или нет восстановить этот список, например на основе журнала установленных обновлений.

Читайте также:  Tia portal v14 windows
Оцените статью