TCP コンポーネントに JavaDSL を使用する
TCP コンポーネントの DSL サポートには、アダプターとゲートウェイの仕様、接続ファクトリ Bean を作成するファクトリメソッドを備えた Tcp
クラス、およびシリアライザーとデシリアライザーを作成するファクトリメソッドを備えた TcpCodecs
クラスが含まれます。詳細については、javadoc を参照してください。
DSL を使用して DSL を使用してフローを構成する例を次に示します。
サーバーアダプターフロー
@Bean
public IntegrationFlow server() {
return IntegrationFlow.from(Tcp.inboundAdapter(Tcp.netServer(1234)
.deserializer(TcpCodecs.lengthHeader1())
.backlog(30))
.errorChannel("tcpIn.errorChannel")
.id("tcpIn"))
.transform(Transformers.objectToString())
.channel("tcpInbound")
.get();
}
クライアントアダプターフロー
@Bean
public IntegrationFlow client() {
return f -> f.handle(Tcp.outboundAdapter(Tcp.nioClient("localhost", 1234)
.serializer(TcpCodecs.lengthHeader1())));
}
サーバーゲートウェイフロー
@Bean
public IntegrationFlow server() {
return IntegrationFlow.from(Tcp.inboundGateway(Tcp.netServer(1234)
.deserializer(TcpCodecs.lengthHeader1())
.serializer(TcpCodecs.lengthHeader1())
.backlog(30))
.errorChannel("tcpIn.errorChannel")
.id("tcpIn"))
.transform(Transformers.objectToString())
.channel("tcpInbound")
.get();
}
クライアントゲートウェイフロー
@Bean
public IntegrationFlow client() {
return f -> f.handle(Tcp.outboundGateway(Tcp.nioClient("localhost", 1234)
.deserializer(TcpCodecs.lengthHeader1())
.serializer(TcpCodecs.lengthHeader1())));
}