«Плагин C» четко не определен в контексте erlang.
Либо вы пишете порт, который в основном разветвляет системный процесс.
Или вы пишете связанный драйвер, которыйработает в том же контексте, что и Erlang vm.
В обоих случаях вы можете использовать преимущества многоядерных процессоров.В первом случае просто используется ОС для размещения процессов ОС на разных процессорах (на что должна быть способна любая приличная ОС SMP).
Во втором случае я не уверен, но я ожидаю, что драйверыработать на разных ядрах процессора также.Если у вас нет веских оснований для использования связанных драйверов и вы точно знаете, что делаете, я рекомендую использовать их по причинам сложности и стабильности.В случае сбоя порта Erlang получает уведомление и может перезапустить его или принять другие меры предосторожности.В случае сбоя драйвера весь Erlang vm сильно удаляется.
Главный вопрос - какую часть проблемы вы хотите решить в Erlang, если вы используете erlang только для запуска своих «плагинов», это может быть оченьпроще решить проблему, просто запустив процессы из оболочки, поскольку вашим «потокам» не нужно обмениваться данными, почему бы не передать параметры командной строки и обработать рабочие процессы из сценария оболочки?