J'essaie d'interroger un DB côté client et d'envoyer le résultat via HTTP à un serveur qui collecte des données. Malheureusement, seul le premier message est livré. Je suis nouveau à l'intégration de printemps (1.0.3)Seul le premier message est remis au serveur
Quel est le problème avec ma configuration?
clients config:
<si:channel id="msgChannel">
<si:queue capacity="1" />
</si:channel>
<si:inbound-channel-adapter ref="jdbcInputAdapter" method="fetchData" channel="msgChannel">
<si:poller max-messages-per-poll="1">
<si:interval-trigger interval="5000" />
</si:poller>
</si:inbound-channel-adapter>
<http:outbound-gateway id="httpChannelAdapter" request-channel="msgChannel" default-url="http://localhost:8080/company/gateway"/>
<si:poller default="true">
<si:interval-trigger interval="5000" />
</si:poller>
serveurs config:
<si:channel id="requestChannel">
<si:queue capacity="4" />
</si:channel>
<si:channel id="replyChannel" />
<http:inbound-gateway id="InboundGateway" request-channel="requestChannel" reply-channel="replyChannel"/>
<bean id="shouter" class="com.company.Shouter"/>
<si:outbound-channel-adapter ref="shouter" method="shout" channel="replyChannel"/>
<si:service-activator input-channel="requestChannel"
ref="StorageService" method="store"
output-channel="replyChannel" />
<bean id="StorageService" class="com.company.StorageService" />
<si:poller default="true">
<si:interval-trigger interval="1000" />
</si:poller>
EDIT: Chaque fois que je redémarrer le client un seul message sera reçu par le serveur.
RESOLU: Je devais changer la signature de StorageService de
public void store(Message msg)
à
public Message store(Message msg)
merci j'ai supprimé les capacités de file d'attente qui n'avaient aucun effet. – stacker
la réponse est trompeuse, mais je suis d'accord le -1 est redondant – iwein