Ответ 1
1) Иностранные JMS-серверы были определены как автономные компоненты, аналогичные коннекторам, мостам обмена сообщениями и т.д. Эти компоненты (исторически) целевые серверы приложений или кластеры непосредственно вместо промежуточного компонента, такого как JMS-сервер.
С более поздними выпусками Oracle пытается объединить как внутреннюю, так и иностранную JMS под универсальным зонтиком. Однако целевые варианты были разными. Чтобы обеспечить гибкость с помощью JMS-части, были внедрены вспомогательные развертывания. По-видимому, Oracle, по-видимому, была расширена подразделениями для иностранных серверов для обеспечения согласованности, что делает вещи довольно сложными/беспорядочными.
Я бы не назвал это несчастным случаем, так как новые версии продолжают соответствовать этой настройке:)
2) Для приложений, развернутых в кластерах, вам нужно будет создать один JMS-модуль для всего кластера. Несколько определений вашего соединения factory будут искажать балансировку нагрузки JMS.
Наши лучшие практики были сосредоточены вокруг стандартного создания единого модуля JMS для каждого кластера (или сервера приложений, если он не был кластеризован), а затем создавали как внешний сервер, так и weblogic JMS очереди/фабрики соединений в одном модуле. Кроме того, наличие хороших соглашений об именах для ваших вспомогательных развертываний и модулей JMS имеет большое значение.
3) Зарубежные серверы (особенно с IBM MQ) могут иметь множество сложных проблем, если вы запускаете > 16 параллельных MDB. Мы избегали внешнего сервера → Сервер JMS → Управляемый сервер, чтобы сократить дополнительный уровень абстракции/сложности inorder, чтобы упростить конфигурацию. Вы также уменьшаете риск того, что исключения вашего внешнего сервера замаскированы криптовальным исключением JMS-сервера (у меня нет никаких доказательств этого).
Один партнер команды предположил, что настройка сервера Foreign Server → Application Server была более высокой, но команда Oracle A подтвердила, что это только логическое/эстетическое изменение и не имеет большого значения.
Надеюсь, что это поможет!