![]() |
1. Заголовок или название темы должно быть информативным !
2. Все тексты фрагментов программ должны помещаться в теги [code] ... [/code] или [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ" и используйте ПОИСК !
4. НЕ используйте форум для личного общения!
5. Самое главное - это раздел теоретический, т.е. никаких задач и программ (за исключением небольших фрагментов) - для этого есть отдельный раздел!
![]() |
malor |
![]()
Сообщение
#1
|
Новичок ![]() Группа: Пользователи Сообщений: 10 Пол: Мужской Реальное имя: yuriy Репутация: ![]() ![]() ![]() |
Э.Таненбаум "Современные операционные системы" 2-е издание, Питер, 2006.
Стр.113: Цитата "На рис. 2.7 показан один из способов организации web-сервера. Один поток, называемый диспетчером, считывает приходящие по сети запросы. После этого он находит свободный(т.е. блокированный) рабочий поток и передает ему запрос, скажем,записывая указатель сообщения в специальное слово, связанное с каждым потоком." Что такое "указатель сообщения"? Что за "специальное слово"?Стр.114: Цитата "После активации рабочий поток проверяет возможность удовлетворения запроса в кэше web-сервера, к которому имеют доступ все потоки. В случае отрицательного ответа поток начинает операцию чтения read, чтобы считать страницу с диска, и блокируется до завершения этой операции" Как он 'блокированный' занимается считыванием данных с диска? |
![]() ![]() |
hardcase |
![]()
Сообщение
#2
|
![]() code warrior ![]() ![]() ![]() ![]() Группа: Пользователи Сообщений: 484 Пол: Мужской Реальное имя: Славен Репутация: ![]() ![]() ![]() |
Э.Таненбаум "Современные операционные системы" 2-е издание, Питер, 2006. Стр.113:Что такое "указатель сообщения"? Что за "специальное слово"? Под указателем сообщения подразумевается запрос, пришедший из сети. Специальное слово - это некая область памяти, зарезервированная за рабочим потоком, подразумевается, что через него диспетчер взаимодействует с рабочими потоками. Э.Таненбаум "Современные операционные системы" 2-е издание, Питер, 2006. В данном случае подразумевается асинхронная работа потоков, когда рабочий поток запускает некую длительную задачу - большой запрос к БД, вызов удаленного веб-сервиса, запрос к диску или еще чтонить подобное, - он на время "забывает" о вызове и переходит в блокированное состояние (ожидание запроса), диспетчер проверяя на завершенность такие асинхронные операции возобновляет прерванную работу (не обязательно тем же потоком, какой вызвал операцию). Подобный механизм используется в "асинхронных" страницах ASP.NET2.0Стр.114:Как он 'блокированный' занимается считыванием данных с диска? -------------------- ИзВ ин ИтЕ зА нЕ рОв НЫй П оч ЕРк
|
![]() ![]() |
![]() |
Текстовая версия | 20.07.2025 14:29 |