nimbus (1.2.4) | 2018-01-25 20:02 |
nimbus-sample (1.2.4) | 2018-01-26 17:06 |
jp.ossc.nimbus.service.publish.GroupConnectionFactoryServiceは、物理的に複数の接続を論理的には1つの接続に集約させて送受信を簡易化させるClientConnectionFactory及びServerConnectionFactory実装サービスです。
このサービスは、物理的な通信を司るClientConnectionFactory及びServerConnectionFactory実装サービスを複数使用して、それぞれのClientConnection及びServerConnectionを取得し、それらをまとめてラップしたClientConnection及びServerConnectionを提供するサービスです。そのため、このサービスとは別に、実体となるClientConnectionFactory及びServerConnectionFactory実装サービスが複数必要となります。
このサービスは、送信側サーバに定義します。
そのため、送信側のアプリケーションは、このサービスを取得して、ServerConnectionFactoryとして使用できます。
しかし、受信側のアプリケーションは、このサービスが定義されたサーバと異なるリモートサーバ上で稼働するため、このサービスを直接取得する事はできません。このサービスは、JNDIサーバ(RMIサーバも可)にClientConnectionFactoryのリモートオブジェクトを登録するので、受信側のアプリケーションは、JNDIサーバからClientConnectionFactoryをlookupして、使用します。
このサービスは、複合的なサービスで、以下のサービスを下位サービスとして使用します。
下位サービスインタフェース | 用途 |
jp.ossc.nimbus.service.publish.ClientConnectionFactory | 物理的な通信を司るClientConnectionFactoryとして使用する。 |
jp.ossc.nimbus.service.publish.ServerConnectionFactory | 物理的な通信を司るServerConnectionFactoryとして使用する。 |
jp.ossc.nimbus.service.repository.Repository | JNDIサーバにClientConnectionFactoryのリモートオブジェクトをバインドするために使用する。 |
以下に簡単なサービス定義を示します。
- <?xml version="1.0" encoding="Shift_JIS"?>
- <!DOCTYPE server PUBLIC
- "-//Nimbus//DTD Nimbus 1.0//JA"
- "http://nimbus.sourceforge.jp/dtd/nimbus-service_1_0.dtd">
- <server>
- <manager>
- <!-- グループコネクションファクトリサービス -->
- <service name="ConnectionFactory"
- code="jp.ossc.nimbus.service.publish.GroupConnectionFactoryService">
- <!-- クライアントコネクションファクトリを登録するRMIサーバリポジトリサービスを設定する -->
- <attribute name="JndiRepositoryServiceName">#LocalRMIRepository</attribute>
- <!-- サブジェクト hoge への配信を行うコネクションファクトリを設定する -->
- <invoke name="addSubjectMapping">
- <argument>
- <object code="jp.ossc.nimbus.service.publish.GroupConnectionFactoryService$SubjectMapping">
- <!-- 関連付けるサブジェクトを設定する -->
- <attribute name="Subject">hoge</attribute>
- <!-- クライアントコネクションファクトリを設定する -->
- <attribute name="ClientConnectionFactoryServiceName">#ConnectionFactory1</attribute>
- <!-- サーバコネクションファクトリを設定する -->
- <attribute name="ServerConnectionFactoryServiceName">#ConnectionFactory1</attribute>
- </object>
- </argument>
- </invoke>
- <!-- サブジェクト fuga への配信を行うコネクションファクトリを設定する -->
- <invoke name="addSubjectMapping">
- <argument>
- <object code="jp.ossc.nimbus.service.publish.GroupConnectionFactoryService$SubjectMapping">
- <!-- 関連付けるサブジェクトを設定する -->
- <attribute name="Subject">fuga</attribute>
- <!-- クライアントコネクションファクトリを設定する -->
- <attribute name="ClientConnectionFactoryServiceName">#ConnectionFactory2</attribute>
- <!-- サーバコネクションファクトリを設定する -->
- <attribute name="ServerConnectionFactoryServiceName">#ConnectionFactory2</attribute>
- </object>
- </argument>
- </invoke>
- <depends>ConnectionFactory1</depends>
- <depends>ConnectionFactory2</depends>
- <depends>LocalRMIRepository</depends>
- </service>
- <!-- TCPコネクションファクトリサービス -->
- <service name="ConnectionFactory1"
- code="jp.ossc.nimbus.service.publish.tcp.ConnectionFactoryService"/>
- <!-- TCPコネクションファクトリサービス -->
- <service name="ConnectionFactory2"
- code="jp.ossc.nimbus.service.publish.tcp.ConnectionFactoryService"/>
- <!-- RMIサーバに登録するリポジトリサービス -->
- <service name="LocalRMIRepository"
- code="jp.ossc.nimbus.service.repository.RMIRepositoryService">
- <attribute name="CreateRegistry">true</attribute>
- <attribute name="Port">1099</attribute>
- </service>
- </manager>
- </server>
メッセージ配信/ServerConnectionFactory
メッセージ配信/ClientConnectionFactory