OberonCore
https://forum.oberoncore.ru/

Блэкбокс-процессы
https://forum.oberoncore.ru/viewtopic.php?f=31&t=938
Страница 1 из 1

Автор:  Сергей Губанов [ Понедельник, 07 Апрель, 2008 11:22 ]
Заголовок сообщения:  Блэкбокс-процессы

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

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

Назовём поток с выполняющейся копией Блэкбокса блэкбокс-процессом. В этой терминологии, расширенное ядро умеет исполнять несколько блэкбокс-процессов. Обмен указателями между блекбокс-процессами надо запретить, так что в каждом из блекбокс-процессов будет работать свой обычный-однопоточный сборщик мусора.

Разумеется код модулей и дескрипторы типов копировать не надо, они все хранятся в единственном экземпляре в расширенном ядре.

Вместо неструктурного и тяжёлого TCP, расширенное ядро должно предоставить объёктно ориентированную обычную обероновскую программную шину (или канал) обмена межпроцессными сообщениями (сообщения не долны содержать указателей).

Автор:  Илья Ермаков [ Понедельник, 07 Апрель, 2008 12:15 ]
Заголовок сообщения:  Re: Блэкбокс-процессы

Идея хорошая и не новая (бродит уже в головах давно).

Такая шина поверх TCP (для распределёнки) у нас уже сделана. Допускаются указатели на Store, которые экстернализируются в поток и воссоздаются на другом конце канала.

Еще неплохо позволить обмен указателями на immutable data structures. В одном адресном пространстве может разделяться одна копия, в разных - выполняться репликация.

По этому поводу:
An Abstract Data Type for Freezable Lists and DAGs
Wolfgang Weck (1997)

Есть здесь - http://europrog.ru/ilog.html (дайте поиск по странице).

Страница 1 из 1 Часовой пояс: UTC + 3 часа
Powered by phpBB® Forum Software © phpBB Group
https://www.phpbb.com/