IPB
ЛогинПароль:

> Правила раздела!

1. Заголовок или название темы должно быть информативным !
2. Все тексты фрагментов программ должны помещаться в теги [code] ... [/code] или [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ" и используйте ПОИСК !
4. НЕ используйте форум для личного общения!
5. Самое главное - это раздел теоретический, т.е. никаких задач и программ (за исключением небольших фрагментов) - для этого есть отдельный раздел!

 
 Ответить  Открыть новую тему 
> Ряд вопросов про потоки, По книгам: Таненбаум etc
сообщение
Сообщение #1


Новичок
*

Группа: Пользователи
Сообщений: 10
Пол: Мужской
Реальное имя: yuriy

Репутация: -  0  +


Э.Таненбаум "Современные операционные системы" 2-е издание, Питер, 2006.
Стр.113:
Цитата
"На рис. 2.7 показан один из способов организации web-сервера. Один поток, называемый диспетчером, считывает приходящие по сети запросы. После этого он находит свободный(т.е. блокированный) рабочий поток и передает ему запрос, скажем,записывая указатель сообщения в специальное слово, связанное с каждым потоком."
Что такое "указатель сообщения"? Что за "специальное слово"?

Стр.114:
Цитата
"После активации рабочий поток проверяет возможность удовлетворения запроса в кэше web-сервера, к которому имеют доступ все потоки. В случае отрицательного ответа поток начинает операцию чтения read, чтобы считать страницу с диска, и блокируется до завершения этой операции"
Как он 'блокированный' занимается считыванием данных с диска?
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
сообщение
Сообщение #2


code warrior
****

Группа: Пользователи
Сообщений: 484
Пол: Мужской
Реальное имя: Славен

Репутация: -  8  +


Цитата(malor @ 23.07.2007 12:00) *
Э.Таненбаум "Современные операционные системы" 2-е издание, Питер, 2006.
Стр.113:Что такое "указатель сообщения"? Что за "специальное слово"?

Под указателем сообщения подразумевается запрос, пришедший из сети. Специальное слово - это некая область памяти, зарезервированная за рабочим потоком, подразумевается, что через него диспетчер взаимодействует с рабочими потоками.
Цитата(malor @ 23.07.2007 12:00) *
Э.Таненбаум "Современные операционные системы" 2-е издание, Питер, 2006.
Стр.114:Как он 'блокированный' занимается считыванием данных с диска?
В данном случае подразумевается асинхронная работа потоков, когда рабочий поток запускает некую длительную задачу - большой запрос к БД, вызов удаленного веб-сервиса, запрос к диску или еще чтонить подобное, - он на время "забывает" о вызове и переходит в блокированное состояние (ожидание запроса), диспетчер проверяя на завершенность такие асинхронные операции возобновляет прерванную работу (не обязательно тем же потоком, какой вызвал операцию). Подобный механизм используется в "асинхронных" страницах ASP.NET2.0


--------------------
ИзВ ин ИтЕ зА нЕ рОв НЫй П оч ЕРк
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
сообщение
Сообщение #3


Гость






Стр.114-115:
Цитата
Итак, мы рассмотрели два возможных варианта: web-сервер с одним потоком и несколькими потоками. Представьте себе, что многопоточная система невозможна, но хочется увеличить эффективность системы с одним потоком. Возможен третий вариант web-сервера в случае существования системного запроса read без блокировки. На сервер приходит запрос, его считывает и проверяет единственный поток. Если запрашиваемая web-страница есть в кэше - хорошо, если нет - запускается дисковая операция без блокировки.
Сервер записывает в таблицу текущее состояние запроса и переходит к следующему событию. Оно может быть как новым запросом, так и ответом предыдущей операции. В случае нового запроса он начинает обрабатываться, в противном случаесоответствующая информация считывается из таблицы и формируется ответ. В случае процедуры ввода-вывода с диска без блокировки ответ может иметь форму сигнала или прерывания.
При такой схеме модель "последовательных процессов" которая была справедлива в первых ситуациях, не действует. Состояние программы должно явно сохраняться и восстанавливаться в таблице каждый раз, когда сервер переключается между запросами. Фактически мы имитируем потоки и стеки, причем не самым простым способом. Такая модель, в которой каждому расчету соответствует сохраненное состояние и есть несколько событий, кроторые могут изменить это состояние, называется машиной с конечным числом состояний или конечным автоматом. Эта модель широко используется в программировании.
Что за "расчеты" ? Что за "несколько событий"?
 К началу страницы 
+ Ответить 

 Ответить  Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 





- Текстовая версия 28.09.2020 1:19
500Gb HDD, 6Gb RAM, 2 Cores, 7 EUR в месяц — такие хостинги правда бывают
Связь с администрацией: bu_gen в домене octagram.name