ClientConnectionFactory実装サービス jp.ossc.nimbus.service.publish.GroupClientConnectionFactoryService

jp.ossc.nimbus.service.publish.GroupClientConnectionFactoryServiceは、物理的に複数の接続を論理的には1つの接続に集約させて受信を簡易化させるClientConnectionFactory実装サービスです。
このサービスは、物理的な通信を司るClientConnectionFactory実装サービスを複数使用して、それぞれのClientConnectionを取得し、それらをまとめてラップしたClientConnectionを提供するサービスです。そのため、このサービスとは別に、実体となるClientConnectionFactory実装サービスが複数必要となります。

このサービスは、受信側サーバに定義します。
そのため、受信側のアプリケーションは、このサービスを取得して、ClientConnectionFactoryとして使用できます。

このサービスは、複合的なサービスで、以下のサービスを下位サービスとして使用します。

下位サービスインタフェース用途
jp.ossc.nimbus.service.publish.ClientConnectionFactory物理的な通信を司るClientConnectionFactoryとして使用する。
jp.ossc.nimbus.service.repository.RepositoryJNDIサーバからClientConnectionFactoryのリモートオブジェクトをlookupするために使用する。

以下に簡単なサービス定義を示します。

  1. <?xml version="1.0" encoding="Shift_JIS"?>
  2. <!DOCTYPE server PUBLIC
  3. "-//Nimbus//DTD Nimbus 1.0//JA"
  4. "http://nimbus.sourceforge.jp/dtd/nimbus-service_1_0.dtd">
  5. <server>
  6. <manager>
  7. <!-- グループコネクションファクトリサービス -->
  8. <service name="ConnectionFactory"
  9. code="jp.ossc.nimbus.service.publish.GroupClientConnectionFactoryService">
  10. <!-- クライアントコネクションファクトリをlookupするRMIサーバリポジトリサービスを設定する -->
  11. <attribute name="JndiRepositoryServiceName">#RMIRepository</attribute>
  12. <!-- サブジェクト hoge への配信を行うコネクションファクトリを設定する -->
  13. <invoke name="addSubjectMapping">
  14. <argument>
  15. <object code="jp.ossc.nimbus.service.publish.GroupClientConnectionFactoryService$SubjectMapping">
  16. <!-- 関連付けるサブジェクトを設定する -->
  17. <attribute name="Subject">hoge</attribute>
  18. <!-- クライアントコネクションファクトリを設定する -->
  19. <attribute name="ClientConnectionFactoryJndiName">publish/ClientConnectionFactory1</attribute>
  20. </object>
  21. </argument>
  22. </invoke>
  23. <!-- サブジェクト fuga への配信を行うコネクションファクトリを設定する -->
  24. <invoke name="addSubjectMapping">
  25. <argument>
  26. <object code="jp.ossc.nimbus.service.publish.GroupClientConnectionFactoryService$SubjectMapping">
  27. <!-- 関連付けるサブジェクトを設定する -->
  28. <attribute name="Subject">fuga</attribute>
  29. <!-- クライアントコネクションファクトリを設定する -->
  30. <attribute name="ClientConnectionFactoryJndiName">publish/ClientConnectionFactory2</attribute>
  31. </object>
  32. </argument>
  33. </invoke>
  34. <depends>RMIRepository</depends>
  35. </service>
  36. <!-- RMIサーバからlookupするリポジトリサービス -->
  37. <service name="RMIRepository"
  38. code="jp.ossc.nimbus.service.repository.RMIRepositoryService">
  39. <attribute name="HostName">192.168.1.15</attribute>
  40. <attribute name="Port">1099</attribute>
  41. </service>
  42. </manager>
  43. </server>


メッセージ配信/ClientConnectionFactory