НИС Распределенные системы (осень 2016) — различия между версиями
Материал из Wiki - Факультет компьютерных наук
Sandello (обсуждение | вклад) |
Sandello (обсуждение | вклад) |
||
Строка 26: | Строка 26: | ||
Вопросы для самопроверки: | Вопросы для самопроверки: | ||
* Какие классы сетевых ошибок встречаются в распределенных системах? | * Какие классы сетевых ошибок встречаются в распределенных системах? | ||
− | * Что такое | + | * Что такое удаленный вызов (Remote Procedure Call)? |
* Опишите основные фазы исполнения удаленного вызова согласно оригинальной статье. | * Опишите основные фазы исполнения удаленного вызова согласно оригинальной статье. | ||
* Как осуществляется связывание вызывающей и вызываемой стороны? | * Как осуществляется связывание вызывающей и вызываемой стороны? | ||
− | * Как осуществляется передача аргументов? | + | * Как осуществляется передача аргументов и результата между вызывающей и вызываемой сторонами? |
− | * Каким механизмом обеспечивается гарантия однократного исполнения вызова | + | * Каким механизмом обеспечивается гарантия однократного исполнения вызова? |
* Можно ли передавать указатели в удаленные вызовы? | * Можно ли передавать указатели в удаленные вызовы? | ||
* Какие новые классы ошибок появляются при удаленных вызовах и отсутствуют при локальных вызовах? | * Какие новые классы ошибок появляются при удаленных вызовах и отсутствуют при локальных вызовах? |
Версия 14:05, 14 сентября 2016
Содержание
Информация про семинар
В рамках научно-исследовательского семинара по распределенным системам изучаются основные понятия, принципы и результаты предметной области.
[TBD: Оценка за НИС, отчетность, курсовые работы]
Занятия
2 сентября
Вводное занятие.
Материалы:
- Mockapetris, Dunlap -- Development of the domain name system (pdf)
9 сентября
Отмена занятия
16 сентября
Сетевое взаимодействие в распределенных системах.
Материалы:
- Google Code University -- Introduction to Distributed Systems Design (pdf)
- Birrell, Nelson -- Implementing remote procedure calls (pdf)
- Eriksen -- Your server as a function (pdf)
- (extra) Liskov -- Promises: linguistic support for efficient asynchronous procedure calls in distributed systems (pdf)
Вопросы для самопроверки:
- Какие классы сетевых ошибок встречаются в распределенных системах?
- Что такое удаленный вызов (Remote Procedure Call)?
- Опишите основные фазы исполнения удаленного вызова согласно оригинальной статье.
- Как осуществляется связывание вызывающей и вызываемой стороны?
- Как осуществляется передача аргументов и результата между вызывающей и вызываемой сторонами?
- Каким механизмом обеспечивается гарантия однократного исполнения вызова?
- Можно ли передавать указатели в удаленные вызовы?
- Какие новые классы ошибок появляются при удаленных вызовах и отсутствуют при локальных вызовах?
- Какие предпосылки в оригинальном дизайне RPC стоит пересмотреть с учетом прогресса за последние 30 лет?
- Зачем нужна концепция futures/promises? Чем отличается удаленный вызов с использованием future/promise и без?
- Как использование futures/promises влияет на структуру асинхронной программы?
- Какую роль играют сервисы, фильтры в Finagle? Перечислите аргументы "за" и "против" использования данных абстракций.
- Какие другие паттерны сетевого взаимодействия вы можете представить помимо RPC?
23 сентября
Время, часы, синхронизация событий.
[TBD]
30 сентября
[TBD]