OberonCore

Текущее время: Вторник, 07 Сентябрь, 2010 23:05

Часовой пояс: UTC + 3 часа [ Летнее время ]




Начать новую тему Ответить на тему  [ Сообщений: 2 ] 
Автор Сообщение
 Заголовок сообщения: Блэкбокс-процессы
СообщениеДобавлено: Понедельник, 07 Апрель, 2008 12:22 
Аватара пользователя

Зарегистрирован: Пятница, 25 Ноябрь, 2005 19:55
Сообщения: 1470
Откуда: Россия, Нижний Новгород
Как известно, запустив несколько экземпляров Блэкбокса (в разных процессах) общающихся друг с другом по TCP можно получить "тяжёлый" вариант эдакой "параллельной программы".

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

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

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

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


Вернуться к началу
 Профиль Отправить email  
 
 Заголовок сообщения: Re: Блэкбокс-процессы
СообщениеДобавлено: Понедельник, 07 Апрель, 2008 13:15 
Модератор
Аватара пользователя

Зарегистрирован: Понедельник, 14 Ноябрь, 2005 19:39
Сообщения: 6235
Откуда: Россия, Орёл
Идея хорошая и не новая (бродит уже в головах давно).

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

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

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

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


Вернуться к началу
 Профиль  
 
Показать сообщения за:  Поле сортировки  
Начать новую тему Ответить на тему  [ Сообщений: 2 ] 

Часовой пояс: UTC + 3 часа [ Летнее время ]


Кто сейчас на конференции

Сейчас этот форум просматривают: нет зарегистрированных пользователей и гости: 1


Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете добавлять вложения

Найти:
Powered by phpBB © 2000, 2002, 2005, 2007 phpBB Group
Русская поддержка phpBB