Внутреннее устройство windows руссинович марк соломон дэвид руссинович марк соломон дэвид

Внутреннее устройство Windows (pdf+epub)

PDF

Объем 944 страницы

2017 год

PDF

Подарите скидку 10%

Посоветуйте эту книгу и получите 69,91 ₽ с покупки её другом.

О книге

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

Описание книги

С момента выхода предыдущего издания этой книги операционная система Windows прошла длинный путь обновлений и концептуальных изменений, результатом которых стала новая стабильная архитектура ядра Windows 10.

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

Прочитав эту книгу, вы будете лучше разбираться в работе Windows и в истинных причинах того или иного поведения ОС.

Книга Марка Руссиновича «Внутреннее устройство Windows (pdf+epub)» — скачать в pdf или читать онлайн. Оставляйте комментарии и отзывы, голосуйте за понравившиеся.

Возрастное ограничение:

16+

Дата выхода на Литрес:

24 декабря 2013 г.

Последнее обновление:

2017

ISBN:

978-5-4461-0663-9, 9780735684188

Общее кол-во страниц:

944

С этой книгой читают

PDF

rating-star

4,4

340

rating-star

4,5

147

PDF

rating-star

4,2

116

PDF

rating-star

4,0

84

PDF

rating-star

4,0

51

PDF

rating-star

4,0

60

PDF

rating-star

4,1

126

PDF

rating-star

4,1

53

PDF

rating-star

4,1

58

rating-star

4,6

216

Другие книги автора

PDF

rating-star

4,3

26

Время на прочтение
8 мин

Количество просмотров 29K

image С момента выхода предыдущего издания этой книги операционная система Windows прошла длинный путь обновлений и концептуальных изменений, результатом которых стала новая стабильная архитектура ядра Windows 10.

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

Динамика списков страниц

На рис. 5.37 показана диаграмма состояний переходов страничных блоков. Для простоты на ней не представлен список измененных, но не подлежащих записи страниц.

image

Страничные блоки перемещаются между страничными списками следующими способами.

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

2. Одна из причин востребованности страниц, заполненных нулями, заключается в выполнении различных требований безопасности — например, общих критериев (Common Criteria). Большинство положений общих критериев указывает на то, что процессы пользовательского режима должны получать обнуленные страничные блоки, чтобы они не могли прочитать содержимое памяти предыдущих процессов. Поэтому диспетчер памяти предоставляет процессам пользовательского режима обнуленные страничные блоки, если только страница не была считана из резервного хранилища. В таком случае диспетчер памяти использует необнуленные страничные блоки, инициализируя их данными с диска или с удаленного хранилища. Список страниц, заполненных нулями, пополняется из списка свободных страниц системным программным потоком, который называется потоком обнуления страниц (zero page thread), — это поток 0 в процессе System. Поток обнуления страниц ждет сигнала на работу от объекта шлюза. Когда в списке свободных имеется восемь и более страниц, шлюз подает сигнал. Но поток обнуления страниц запускается, только если хотя бы у одного процессора нет других выполняемых потоков, поскольку поток обнуления страниц запускается с приоритетом 0, а наименьший приоритет, который может быть установлен для пользовательского потока, равен 1.

ПРИМЕЧАНИЕ Когда память в результате выделения физической страницы драйвером, вызывающим функцию MmAllocatePagesForMdl или MmAllocatePagesForMdlEx, должна быть заполнена нулями Windows-приложением, вызывающим функцию AllocateUserPhysicalPages или AllocateUserPhysicalPagesNuma, или когда приложение выделяет большие страницы, диспетчер памяти обнуляет память, используя высокопроизводительную функцию под названием MiZeroInParallel, которая отображает более крупные области, чем поток обнуления страниц, обнуляющий только одну страницу за раз. Кроме того, на мультипроцессорных системах диспетчер памяти создает дополнительный системный поток для обнуления в параллельном режиме (а на NUMA-платформах это делается в стиле, оптимизированном под технологию NUMA).

3. Когда диспетчеру памяти не нужна страница, заполненная нулями, он сначала обращается к списку свободных страниц. Если этот список пуст, он переходит к списку обнуленных страниц. Если и список обнуленных страниц пуст, он переходит к списку ожидающих страниц. Перед тем как диспетчер памяти сможет воспользоваться страничным блоком из списка ожидающих страниц, он должен сначала вернуться и удалить ссылку из недостоверной PTE-записи (или из прототипной PTE-записи), которая все еще указывает на страничный блок. Поскольку в записях базы данных PFN-номеров содержатся обратные указатели на предыдущую страницу пользовательской таблицы страниц (или на страницу пула прототипной PTE-записи для общих страниц), диспетчер памяти может быстро найти PTE-запись и внести в нее соответствующее изменение.

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

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

ЭКСПЕРИМЕНТ: ПРОСМОТР СПИСКОВ СВОБОДНЫХ И ОБНУЛЕННЫХ СТРАНИЦ

За освобождением закрытых страниц при завершении работы процесса можно наблюдать в окне System Information (Системная информация) программы Process Explorer. Сначала нужно создать процесс с большим количеством закрытых страниц в его рабочем наборе. Мы уже делали это в одном из предыдущих экспериментов с помощью утилиты TestLimit:

C:\Tools\Sysinternals>Testlimit.exe -d 1 -c 1500

Testlimit v5.24 - test Windows limits
Copyright (C) 2012-2015 Mark Russinovich
Sysinternals - www.sysinternals.com

Process ID: 13928

Leaking private bytes with touch 1 MB at a time...
Leaked 1500 MB of private memory (1500 MB total leaked). Lasterror: 0
The operation completed successfully.

Ключ –d заставляет TestLimit не только выделить память в качестве закрытой и подтвержденной, но и «прикоснуться» к ней, т. е. обратиться к этой памяти. Это приводит к выделению физической памяти и присвоению ее процессу, чтобы освободить область закрытой подтвержденной виртуальной памяти. Если в системе имеется достаточный объем доступной оперативной памяти, для процесса в оперативной памяти будет выделено целых 1500 Мбайт. Теперь этот процесс будет ждать, пока вы не заставите его завершить или прервать работу (возможно, с комбинацией клавиш Ctrl+C в его командном окне). Выполните следующие действия.

1. Откройте Process Explorer.

2. Выберите команду ViewSystem Information и перейдите на вкладку Memory.

3. Понаблюдайте за размерами списков свободных (Free) и обнуленных (Zeroed) страниц.

4. Завершите или прервите процесс TestLimit.

Возможно, вам удастся увидеть, что список свободных страниц кратковременно увеличился в размере. Мы говорим «возможно», потому что поток обнуления страниц «проснется», как только в списке обнуленных страниц останется всего восемь записей, и отработает очень быстро. Process Explorer обновляет это окно только раз в секунду, и похоже, что остальные страницы уже успевают обнулиться и попасть в список обнуленных страниц, пока нам удалось «поймать» это состояние. Если вам удалось заметить временное увеличение списка свободных страниц, то вслед за этим вы увидите, что его размер упадет до нуля, а в списке обнуленных страниц произойдет соответствующее увеличение. Если же момент будет упущен, вы просто увидите увеличение списка обнуленных страниц.

ЭКСПЕРИМЕНТ: ПРОСМОТР СПИСКОВ ИЗМЕНЕННЫХ И ОЖИДАЮЩИХ СТРАНИЦ

За перемещением страниц из рабочего набора процесса в список измененных страниц и затем в список ожидающих страниц можно понаблюдать при помощи программ VMMap и RAMMap из пакета Sysinternals или в отладчике ядра. Выполните следующие действия.

1.Запустите программу RAMMap и понаблюдайте за спокойным состоянием системы. В данном случае это система x86 с 3 Гбайт оперативной памяти. Столбцы в окне отражают различные состояния страниц (см. рис. 5.37). Некоторые столбцы, которые не имеют значения для данного эксперимента, для удобства были сужены.

image

2. У системы имеется около 420 Мбайт свободной оперативной памяти (складывающейся из свободных и обнуленных страниц). Около 580 Мбайт фигурирует в списке ожидающих страниц (следовательно, часть из них «доступна», но, скорее всего, содержит данные, ранее утраченные процессами или используемые при супервыборке). Около 830 Мбайт активны, будучи отображенными непосредственно на виртуальные адреса через достоверные записи таблицы страниц.

3. Каждая строка далее разбивается в соответствии с состояниями страниц по использованию или происхождению (закрытые страницы процесса, отображаемый файл и т. д.). Например, на данный момент из активных 830 Мбайт около 400 Мбайт обусловлено выделением закрытых страниц процесса.

4. Теперь, как и в предыдущем эксперименте, воспользуйтесь утилитой TestLimit, чтобы создать процесс с большим количеством страниц в рабочем наборе. Здесь опять мы используем ключ –d, чтобы заставить TestLimit сделать запись в каждую страницу, но на этот раз без ограничения, чтобы создать как можно больше закрытых измененных страниц:

C:\Tools\Sysinternals>Testlimit.exe -d

Testlimit v5.24 - test Windows limits
Copyright (C) 2012-2015 Mark Russinovich
Sysinternals - www.sysinternals.com

Process ID: 7548

Leaking private bytes with touch (MB)...
Leaked 1975 MB of private memory (1975 MB total leaked). Lasterror: 8

5. Теперь программа TestLimit создала 1975 областей выделения по 1 Мбайт каждая. Для обновления экрана в программе RAMMap нужно воспользоваться командой FileRefresh для обновления экрана, поскольку самостоятельно программа RAMMap этого не делает (из-за больших затрат на выполнение этой операции).

image

6. Как видите, активно свыше 2,8 Гбайт, из которых 2,4 Гбайт находятся в строке закрытых страниц процесса (строка Process Private). Это результат выделения памяти и доступа к ней со стороны процесса TestLimit. Также обратите внимание на то, что списки ожидающих (Standby), обнуленных (Zeroed) и свободных (Free) страниц теперь стали намного меньше. Большая часть памяти, выделенной программе TestLimit, взята из страниц, фигурировавших в этих списках.

7. Далее с помощью RAMMap нужно оценить выделение физических страниц процесса. Перейдите на вкладку Physical Pages и установите фильтр, находящийся в нижней части столбца Process, присвоив ему значение Testlimit.exe. В следующем окне показаны все физические страницы, являющиеся частью рабочего набора процесса.

image

8. Нам нужно идентифицировать физическую страницу, задействованную в выделении физического адресного пространства, которое было выполнено с помощью ключа –d при запуске программы TestLimit. RAMMap не дает никаких указаний на то, какие виртуальные области были выделены благодаря вызову из RAMMap функции VirtualAlloc. Но мы можем получить ценную подсказку на этот счет с помощью программы VMMap. Вызвав VMMap для
того же процесса, мы получим следующий результат (см. рис. на с. 535 вверху).

9. В нижней части выводимой информации находятся сотни выделенных областей для закрытых данных процесса, каждая из которых имеет размер 1 Мбайт при 1 Мбайт подтвержденной памяти. Это соответствует размеру памяти, выделенной программой TestLimit. В предыдущей копии экрана подсвечен первый из таких вариантов распределения. Заметьте, что его начальный виртуальный адрес равен 0x310000.

10. Теперь вернемся к информации о физической памяти, выводимой на экран программой RAMMap. Перестройте столбцы так, чтобы хорошо был виден столбец Virtual Address. Щелкните на нем, чтобы отсортировать строки по этому значению, и вы сможете найти нужный виртуальный адрес (см. рисунок на с. 535 внизу).

image

11. Здесь показано, что виртуальная страница, начинающаяся с адреса 0x310000, в данный момент отображена на физический адрес 0x212D1000. С ключом -d программа TestLimit записывает в первые байты каждой выделенной области свое имя. Это можно продемонстрировать с помощью команды !dc локального отладчика ядра (dc — сокращение от «display characters», т. е. вывод символов по физическому адресу):

lkd> !dc 0x212d1000
#212d1000 74736554 696d694c 00000074 00000000 TestLimit.......
#212d1010 00000000 00000000 00000000 00000000 ................
...

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

13. Выбрав в программе VMMap процесс TestLimit, откройте меню View и выберите команду Empty Working Set, чтобы сократить рабочий набор процесса до минимума. Теперь в окне VMMap должна выводиться следующая информация:

image

14. Обратите внимание на то, что линейка Working Set (Рабочий набор) практически пуста. В средней части для процесса показано, что общий размер рабочего набора равен всего лишь 4 Кбайт, причем почти все его пространство занято таблицами страниц. Теперь вернитесь в RAMMap. На вкладке Use Counts видно, что количество активных страниц существенно сократилось, а большое количество страниц находится в списке измененных и существенное количество страниц — в списке ожидающих.

image

15. Данные на вкладке Processes программы RAMMap подтверждают, что большинство этих страниц появилось в данных списках из-за процесса TestLimit.

image

» Более подробно с книгой можно ознакомиться на сайте издательства
» Оглавление
» Отрывок

Для Хаброжителей скидка 20% по купону — Windows

✎ Случайные комментарии:



vit

vit:  

Отличная сборка , устанавливаю 2-ой раз и все работает на ура . Если кто-то пишет про какие то вирусы или черви то это полная хрень . Обновления устанавливаются без проблем (почти) .Примерно раз пять я обновления устанавливал с успехом ,правда иногда приходилось скачивать msu  с сайта моикросовт  ведь для Россиян обновления не всегда винда находит

➥ Windows 11 IoT Enterprise 22H2 без Защитника


Error

Error:  

Оказываеться была проблемма в том, что при выборе разлела куда ее ставить 1ин из них был не 100мб, а 95мб и выскакивала ошибка поэтому.
Вчера установил под чистую. Обновился
Все классно, быстро работает.
Единственное хочу кнопку пуск заменить.
Ещё вопрос, разница для тяжелых игр и тд между 10й и 11 есть? А то говорят 11я хуже сейчас.
Спасибо всем !!!!
➥ Windows 10 x64 22H2 FULL 2023 by Flibustier 19045.2673


Злой разраб

Злой разраб:  

Еще раз провел тест на долбае*а в отношении себя. Прикинул, что в теории я мог притащить моимер с активатором — KMSAuto. Запустил его на вашей сборке. И таки это он и оказался троянским конем (во всех смыслах). Сразу и в hosts записи посыпались, и бинарей он своих раскидал по тем же местам.

Короче. Торжественно и во всеуслышанье признаю, что долбае*ом оказался я. Вроде сайт kmsauto.pro существует давно (с 2020 года). Но их активатор оказался пи*орским, ой, т.е. моимерским. Вот так вот. Век живи, век косячь.

Все же активаторы — о*уенная тема для распространения вирусни. Всегда можно правдоподобно ответить, почему надо оффнуть авер перед установкой! потому шо активатор аверы не любят. А вот как кишки ему разобрать без запуска — вопрос.

Мои извинения ресурсу и админу, которых облил говном, в которое сам же окунулся. Предлагаю снести данный топик, дабы на сборку пятно не ставить. Но тут уж на усмотрение админа. Вообще, я погуглил. Я не один такой молодец. Под несколькими сборками винды на вашем сайте есть комменты (затертые, но сохранившиеся в выдаче гугла) о моимерах. Народ систематически так накалывается. Я бы от себя посоветовал либо прям аттачить проверенный активатор к каждой неактивированной виндовой сборке, либо черным огромным текстом добавлять, что качать надо вот отсюда [сцылка], а не по первой ссылке с гугла. Даже сайт с трехлетней регой, пролезший в топ-3 выдачи гугла, не является нихуя гарантией.

Как бы вот. Всем спокойной ночи и аккуратнее с активаторами, штоб их.

➥ Windows 11 Tiny самая популярная сборка 2023 на английском


falka

falka:  

Просто коммент в поддержку этой сборки, ибо авторы молодцы, и реально спасибо. Продолжайте свою работу.

Писал коммент об этой винде в декабре прошлого года, когда ставил ее только. Как раз смущали негативные комменты. До сих пор ей пользуюсь, обновлял уже несколько раз. Работает отлично. В играх почти так и не тестировал больше) дота, валорант, кс го работают прекрасно, точно не хуже, чем на моей старой 10-ке. Проц не нагружается, это чушь! Хз к чему этот наплыв негатива, кому это вообще нужно было)) У меня стояла до этого водянка старая, и она даже при открытии браузера начинала шуметь на старой винде, в играх как самолет. Слабая была. так что я бы сразу заметил, если бы проц грелся/нагружался лишний раз. Ведь вирусы давно могут закрываться к примеру, когда диспетчер открываешь или аиду, чтобы посмотреть загруженность. Тут в покое все было точно также, тишина. В диспетчере/аиде разумеется тоже нет никакой нагрузки. На видеокарту тоже нет нагрузки, она не шумит. даже в играх (ну у меня не требовательные), хотя если запускать игры по мощней, то ее охлаждение слышится ощутимо. Так что тоже бы заметил. 
Единственное проблемы с магазином старые пропали, про которые писал, но появились новые. К примеру вотсап обновлял каждый день в течении 2-х недель))) ибо просило. Просто при каждом запуске вотсапа просило обновление. Жал обновить, но при очередном запуске все по новой. Благо в итоге видимо обновился все таки. Уже дней 5 без этой хрени. 
В остальном все круто. Работает идеально. Авторы, не забрасывайте свои сборки, получилось очень хорошо. 

➥ Windows 11 IoT Enterprise 22H2 без Защитника


Platinum

Platinum:  

Сборку не нужно ни настраивать, ни возвращать что-либо. Установил и пользуйся. Подходит — отлично, нет — значит, нет.

Если Защитник, Xbox, обновление, Hyper-V, Магазин (или еще что-то вырезанное) нужны — то вернуть их вряд ли возможно. Но если времени свободного много — попробуйте что-либо вернуть в эту систему, это поле для личных экспериментов. И обязательно отпишитесь о результатах. 😉

И еще — сборка создана не для использования учетки Microsoft, она только для локальной учетки. 

Она так и называется «базовая сборка» — то есть, с базовыми функциями.

Все сборки by Revision — это коллективное творение, конфигурация каждой такой сборки согласовывается несколькими людьми. Эта сборка сделана из оригинала и без аудита — с использованием Dism. 

➥ Windows 10 x64 Pro Чистая базовая сборка 22H2 на русском

Руссинович Дэвид Соломон Внутреннее устройство Windows. 7 е издание 2018Книга создана для профессионалов, желающих разобраться во внутренней жизни основных компонентов Windows 10. Опираясь на эту информацию, разработчикам будет проще находить правильные проектные решения, создавая приложения для платформы Windows, и решать сложные проблемы, связанные с их эксплуатацией.
Системные администраторы, зная что находится у операционной системы «под капотом», смогут разобраться с поведением системы и быстрее решать задачи повышения производительности и диагностики сбоев. Специалистам по безопасности пригодится информация о борьбе с уязвимостями операционной системы.
Прочитав эту книгу, вы будете лучше разбираться в работе Windows и в истинных причинах того или иного поведения ОС.

img

Нажмите на звезду, чтобы оценить!

Прочитали: 1 982

Предложите, как улучшить StudyLib

(Для жалоб на нарушения авторских прав, используйте

другую форму
)

Ваш е-мэйл

Заполните, если хотите получить ответ

Оцените наш проект

1

2

3

4

5

  • Во время переустановки windows синий экран
  • Внезапно перезагружается компьютер windows 10
  • Внутренняя ошибка 2203 c windows installer inprogressinstallinfo ipi
  • Во время игры сворачивается окно на рабочий стол windows 10
  • Внезапно выключается компьютер windows 10