Ряд вопросов про потоки
Релиб
Форумы       Участники    Календарь    Кто он-лайн?
Добро пожаловать, гость ( Вход | Регистрация )
        



Ряд вопросов про потоки Expand / Collapse
Автор
Сообщение
23.07.2007 11:48
Junior Member

Junior MemberJunior MemberJunior MemberJunior MemberJunior MemberJunior MemberJunior MemberJunior Member

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

Стр.114:
"После активации рабочий поток проверяет возможность удовлетворения запроса в кэше web-сервера, к которому имеют доступ все потоки. В случае отрицательного ответа поток начинает операцию чтения read, чтобы считать страницу с диска, и блокируется до завершения этой операции"
Как он 'блокированный' занимается считыванием данных с диска?
Сообщ. #914892
23.07.2007 12:07
Supreme Being

Supreme Being

модератор
Last Login: 04.05.2008 13:32
Сообщ.: 7 240, Visits: 65 445
malor (23.07.2007)
Что такое "указатель сообщения"?

Число представляющее из себя адрес информации в памяти.

malor (23.07.2007)
Что за "специальное слово"?

Скорее всего просто ячейка памяти.

malor (23.07.2007)
Как он 'блокированный' занимается считыванием данных с диска?

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

Сообщ. #914893
28.07.2007 20:05
Junior Member

Junior MemberJunior MemberJunior MemberJunior MemberJunior MemberJunior MemberJunior MemberJunior Member

участник
Last Login: 08.11.2007 9:27
Сообщ.: 20, Visits: 49
Стр.114-115:
Итак, мы рассмотрели два возможных варианта: web-сервер с одним потоком и несколькими потоками. Представьте себе, что многопоточная система невозможна, но хочется увеличить эффективность системы с одним потоком. Возможен третий вариант web-сервера в случае существования системного запроса read без блокировки. На сервер приходит запрос, его считывает и проверяет единственный поток. Если запрашиваемая web-страница есть в кэше - хорошо, если нет - запускается дисковая операция без блокировки.
Сервер записывает в таблицу текущее состояние запроса и переходит к следующему событию. Оно может быть как новым запросом, так и ответом предыдущей операции. В случае нового запроса он начинает обрабатываться, в противном случаесоответствующая информация считывается из таблицы и формируется ответ. В случае процедуры ввода-вывода с диска без блокировки ответ может иметь форму сигнала или прерывания.
При такой схеме модель "последовательных процессов" которая была справедлива в первых ситуациях, не действует. Состояние программы должно явно сохраняться и восстанавливаться в таблице каждый раз, когда сервер переключается между запросами. Фактически мы имитируем потоки и стеки, причем не самым простым способом. Такая модель, в которой каждому расчету соответствует сохраненное состояние и есть несколько событий, кроторые могут изменить это состояние, называется машиной с конечным числом состояний или конечным автоматом. Эта модель широко используется в программировании.
Что за "расчеты" ? Что за "несколько событий"?
Сообщ. #915019
30.07.2007 10:15
Supreme Being

Supreme Being

модератор
Last Login: 04.05.2008 13:32
Сообщ.: 7 240, Visits: 65 445
malor (28.07.2007)
Что за "расчеты"? Что за "несколько событий"?

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

Сообщ. #915029
12.08.2007 14:29
Junior Member

Junior MemberJunior MemberJunior MemberJunior MemberJunior MemberJunior MemberJunior MemberJunior Member

участник
Last Login: 08.11.2007 9:27
Сообщ.: 20, Visits: 49
Стр. 98:
Когда время, отведенное текущему запросу, заканчивается, физический счетчик команда сохраняется в логическом счетчике команд процесса в памяти
Физический - это регистр в процессоре, а что за "логический счетчик"?

Стр. 100:
Когда на UNIX работает X Window, новый процесс получает то окно, в котором был запущен.
Что значит "процесс получает окно"?

Стр. 100-101:
После выполнения запроса fork двум процессам - родительскому и дочернему - соответствуют одинаковые образы памяти, строки окружения и одни и те же открытые файлы. Обычно дочерний процесс выполняет системный вызов execve(или похожий) для изменения своего образа памяти и запуска новой программы. Так, когда пользователь наберет на клавиатуре команду sort, оболочка создаст путем ветвления дочерний процесс, который и выполняет программу sort. Смысл этого двухступенчатого процесса заключается в том, что дочерний процесс успевает обработать описания файлов после fork, но до execve,
чтобы выполнить перенаправление стандартных устройств ввода и вывода и потока сообщений об ошибках
Что за "описания файлов"?
Сообщ. #915289
13.08.2007 15:28
Supreme Being

Supreme Being

модератор
Last Login: 04.05.2008 13:32
Сообщ.: 7 240, Visits: 65 445
Ответы на все эти вопросы должны быть понятны из контекста книги.
Сообщ. #915296
« пред. тема | след. тема »


Эту тему читают Expand / Collapse
Посетители: 0 (0 гостей, 0 участников, 0 скрыт.участников)
Сейчас нет участников, просматривающих тему.
Модераторы: Alexey, boombastik, bazile, pl

Время GMT +3:00, Сейчас 9:42