Ricerca…


Osservazioni

Questa sezione fornisce una panoramica di cosa è l'integrazione di primavera e perché uno sviluppatore potrebbe volerlo utilizzare.

Dovrebbe anche menzionare tutti i soggetti di grandi dimensioni all'interno dell'integrazione primaverile e collegarsi agli argomenti correlati. Poiché la Documentazione per l'integrazione di primavera è nuova, potrebbe essere necessario creare versioni iniziali di tali argomenti correlati.

Versioni

Versione Data di rilascio
4.3.x 2016/11/07
4.2.x 2016/11/07
4.1.x 2016/07/25
4.0.x 2016/07/26
3.0.x 2015/10/27
2.2.x 2016/01/27
2.1.x 2013/06/10
2.0.x 2013/04/11
1.0.x 2010-04-16

Installazione o configurazione

Il modo migliore per iniziare a utilizzare Spring-Integration nel tuo progetto è con un sistema di gestione delle dipendenze, come gradle.

dependencies {
    compile 'org.springframework.integration:spring-integration-core:4.3.5.RELEASE'
}

Qui di seguito è un esempio molto semplice utilizzando i Gateway , servizio-attivatore endpoint messaggio.

//these annotations will enable Spring integration and scan for components
@Configuration
@EnableIntegration
@IntegrationComponentScan
public class Application {
    //a channel has two ends, this Messaging Gateway is acting as input from one side of inChannel
    @MessagingGateway
    interface Greeting {
        @Gateway(requestChannel = "inChannel")
        String greet(String name);
    }

    @Component
    static class HelloMessageProvider {
        //a service activator act as a handler when message is received from inChannel, in this example, it is acting as the handler on the output side of inChannel
        @ServiceActivator(inputChannel = "inChannel")
        public String sayHello(String name) {
            return "Hi, " + name;
        }
    }

    @Bean
    MessageChannel inChannel() {
        return new DirectChannel();
    }

    public static void main(String[] args) {
        ApplicationContext context = new AnnotationConfigApplicationContext(Application.class);
        Greeting greeting = context.getBean(Greeting.class);
        //greeting.greet() send a message to the channel, which trigger service activitor to process the incoming message
        System.out.println(greeting.greet("Spring Integration!"));
    }
}

Mostrerà la stringa Hi, Spring Integration! nella console.

Naturalmente, Spring Integration fornisce anche la configurazione in stile xml. Per l'esempio precedente, è possibile scrivere il seguente file di configurazione xml.

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:int="http://www.springframework.org/schema/integration"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/integration
        http://www.springframework.org/schema/integration/spring-integration.xsd">
    <int:gateway default-request-channel="inChannel"
                 service-interface="spring.integration.stackoverflow.getstarted.Application$Greeting"/>
    <int:channel id="inChannel"/>
    <int:service-activator input-channel="inChannel" method="sayHello">
        <bean class="spring.integration.stackoverflow.getstarted.Application$HelloMessageProvider"/>
    </int:service-activator>
</beans>

Per eseguire l'applicazione utilizzando il file di configurazione xml, è necessario modificare il codice new AnnotationConfigApplicationContext(Application.class) nella classe Application in new ClassPathXmlApplicationContext("classpath:getstarted.xml") . Ed esegui nuovamente questa applicazione, puoi vedere lo stesso output.

Adattatore canale in entrata e uscita generico

L'adattatore di canale è uno degli endpoint del messaggio in Spring Integration. È usato per il flusso di messaggi unidirezionale. Esistono due tipi di adattatori di canale:

Adattatore in entrata : lato di ingresso del canale. Ascolta o legge attivamente il messaggio.

Adattatore in uscita : lato di uscita del canale. Invia un messaggio alla classe Java o al sistema o protocollo esterno.

inserisci la descrizione dell'immagine qui

  • Codice sorgente.

    public class Application {
        static class MessageProducer {
            public String produce() {
                String[] array = {"first line!", "second line!", "third line!"};
                return array[new Random().nextInt(3)];
            }
        }
    
        static class MessageConsumer {
            public void consume(String message) {
                System.out.println(message);
            }
        }
    
        public static void main(String[] args) {
            new ClassPathXmlApplicationContext("classpath:spring/integration/stackoverflow/ioadapter/ioadapter.xml");
        }
    }
    
  • File di configurazione in stile XML:

    <?xml version="1.0" encoding="UTF-8"?>
    <beans xmlns="http://www.springframework.org/schema/beans"
           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
           xmlns:int="http://www.springframework.org/schema/integration"
           xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
           http://www.springframework.org/schema/integration http://www.springframework.org/schema/integration/spring-integration.xsd">
        <int:channel id="channel"/>
        <int:inbound-channel-adapter id="inAdapter" channel="channel" method="produce">
            <bean class="spring.integration.stackoverflow.ioadapter.Application$MessageProducer"/>
            <int:poller fixed-rate="1000"/>
        </int:inbound-channel-adapter>
        <int:outbound-channel-adapter id="outAdapter" channel="channel" method="consume">
            <bean class="spring.integration.stackoverflow.ioadapter.Application$MessageConsumer"/>
        </int:outbound-channel-adapter>
    </beans>
    
  • Flusso di messaggi

    • inAdapter : un adattatore per canale in entrata. Richiama il metodo Application$MessageProducer.produce ogni 1 secondo ( <int:poller fixed-rate="1000"/> ) e invia la stringa restituita come messaggio al canale del channel .
    • channel : canale per trasferire il messaggio.
    • outAdapter : un adattatore per canale in uscita. Una volta raggiunto il messaggio sul canale channel , questo adattatore riceverà il messaggio e quindi lo invierà al metodo Application$MessageConsumer.consume che stampa il messaggio sulla console.
    • Quindi è possibile osservare che questa stringa di scelta casuale verrà visualizzata sulla console ogni 1 secondo.

Semplice Echo Excample con Spring-Integration-Stream

inserisci la descrizione dell'immagine qui

Codice Java:

public class StdioApplication {
    public static void main(String[] args) {
        new ClassPathXmlApplicationContext("classpath:spring/integration/stackoverflow/stdio/stdio.xml");
    }
}

File di configurazione Xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:int="http://www.springframework.org/schema/integration"
       xmlns:int-stream="http://www.springframework.org/schema/integration/stream"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
       http://www.springframework.org/schema/beans/spring-beans.xsd
       http://www.springframework.org/schema/integration/stream
       http://www.springframework.org/schema/integration/stream/spring-integration-stream.xsd
       http://www.springframework.org/schema/integration
       http://www.springframework.org/schema/integration/spring-integration.xsd">
    <int:channel id="channel"/>
    <int-stream:stdin-channel-adapter id="stdin" channel="channel">
        <int:poller fixed-rate="1000"/>
    </int-stream:stdin-channel-adapter>
    <int-stream:stdout-channel-adapter id="stdout" channel="channel"/>
</beans>

Questo è un esempio di eco. Quando si esegue questa applicazione Java, è possibile immettere una stringa e quindi verrà visualizzata sulla console.



Modified text is an extract of the original Stack Overflow Documentation
Autorizzato sotto CC BY-SA 3.0
Non affiliato con Stack Overflow