Table des matières
Introduction à Spring Boot et Apache ServiceMix
Spring Boot
Apache ServiceMix
Créer un système ESB à l'aide de Spring Boot et ServiceMix
Définir le format de message du système ESB
Créer la configuration de base de ServiceMix
Ajouter un point de terminaison REST du système ESB
Démarrez le système ESB
Résumé
Maison Java javaDidacticiel Créer un système ESB à l'aide de Spring Boot et Apache ServiceMix

Créer un système ESB à l'aide de Spring Boot et Apache ServiceMix

Jun 22, 2023 pm 12:30 PM
spring boot apache servicemix esb系统

Alors que les entreprises modernes s'appuient de plus en plus sur une variété d'applications et de systèmes disparates, l'intégration d'entreprise devient encore plus importante. Enterprise Service Bus (ESB) est un modèle d'architecture d'intégration qui connecte différents systèmes et applications entre eux pour fournir des services communs d'échange de données et de routage de messages afin de réaliser l'intégration des applications au niveau de l'entreprise. En utilisant Spring Boot et Apache ServiceMix, nous pouvons facilement créer un système ESB. Cet article explique comment l'implémenter.

Introduction à Spring Boot et Apache ServiceMix

Spring Boot

Spring Boot est un framework permettant de créer des applications Java autonomes de niveau production basées sur le framework Spring. Il simplifie le processus de création et de configuration des applications Spring en fournissant des configurations et des préréglages courants prêts à l'emploi. Spring Boot fournit également de nombreuses autres fonctionnalités, telles que la configuration automatique, les serveurs Web intégrés et la prise en charge de divers services externes, qui peuvent être utilisés pour créer différents types d'applications, notamment des applications Web, des applications par lots et des microservices.

Apache ServiceMix

Apache ServiceMix est un bus de services d'entreprise (ESB) basé sur Java open source, qui fournit une série de services de base, notamment le routage des messages, la transformation des messages, la propagation des transactions et la sécurité. ServiceMix prend également en charge de nombreuses normes de bus de services différentes, telles que les services Web et Java Message Service (JMS). Grâce à ServiceMix et à ses composants externes, les développeurs peuvent facilement intégrer des systèmes et des applications disparates pour un routage efficace des messages et un échange de données.

Créer un système ESB à l'aide de Spring Boot et ServiceMix

Afin de créer un système ESB à l'aide de Spring Boot et ServiceMix, nous devons d'abord effectuer les étapes suivantes :

  1. Installer et configurer l'environnement Java.
  2. Téléchargez et installez Apache Maven et Apache ServiceMix.
  3. Créez un projet Spring Boot nommé "esb-demo".

Ensuite, nous mettrons en œuvre différentes parties du système ESB étape par étape.

Définir le format de message du système ESB

La partie essentielle du système ESB est le format de message. Dans cet exemple, nous utiliserons un format JSON simple comme format de message, qui comprend les champs suivants :

  • id : L'identifiant unique du message.
  • source : source.
  • destination : Destination du message.
  • content : Contenu du message.

Créer la configuration de base de ServiceMix

Ensuite, nous devons définir la configuration de base de ServiceMix. Pour ce faire, créez un fichier appelé "esb.xml" et ajoutez le contenu suivant :

<?xml version="1.0" encoding="UTF-8"?>
<blueprint
        xmlns="http://www.osgi.org/xmlns/blueprint/v1.0.0"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:schemaLocation="
            http://www.osgi.org/xmlns/blueprint/v1.0.0
            http://www.osgi.org/xmlns/blueprint/v1.0.0/blueprint.xsd">

    <camelContext id="camel" xmlns="http://camel.apache.org/schema/blueprint">
        <route>
            <from uri="jms:queue:incoming"/>
            <to uri="jms:queue:outgoing"/>
        </route>
    </camelContext>

    <bean id="jmsConnectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory">
        <property name="brokerURL" value="tcp://localhost:61616"/>
    </bean>

    <bean id="pooledConnectionFactory" class="org.apache.activemq.pool.PooledConnectionFactory" destroy-method="stop">
        <property name="maxConnections" value="8"/>
        <property name="connectionFactory" ref="jmsConnectionFactory"/>
    </bean>

    <bean id="jmsConfig" class="org.apache.camel.component.jms.JmsConfiguration">
        <property name="connectionFactory" ref="pooledConnectionFactory"/>
    </bean>

    <bean id="jms" class="org.apache.camel.component.jms.JmsComponent" lazy-init="true">
        <property name="configuration" ref="jmsConfig"/>
    </bean>

</blueprint>
Copier après la connexion

Ce fichier de configuration définit une route Camel qui reçoit les messages d'une file d'attente JMS nommée "incoming" et les envoie vers une file d'attente JMS nommée "outgoing". ". Le fichier de configuration définit également une fabrique de connexions JMS pour se connecter à ActiveMQ, ainsi qu'une fabrique de connexions poolée, qui permet une utilisation maximale des connexions JMS, et un composant JMS pour intégrer Camel et JMS ensemble.

Ajouter un point de terminaison REST du système ESB

Afin de recevoir et d'envoyer des messages ESB, nous devons créer un point de terminaison REST pour le système d'entreprise. Dans cet article, nous allons implémenter les deux points de terminaison suivants :

  • POST /esb/incoming : recevoir les messages ESB des systèmes d'entreprise.
  • GET /esb/outgoing : renvoie le message ESB traité.

Pour implémenter ces points de terminaison, créez un contrôleur Spring Boot nommé "EsbController.java" et ajoutez ce qui suit à son code source :

@RestController
public class EsbController {

    private final JmsTemplate jmsTemplate;

    public EsbController(JmsTemplate jmsTemplate) {
        this.jmsTemplate = jmsTemplate;
    }

    @PostMapping("/esb/incoming")
    public ResponseEntity<?> sendIncomingMessage(@RequestBody EsbMessage message) {
        jmsTemplate.convertAndSend("incoming", message.toMessage());
        return ResponseEntity.ok().build();
    }

    @GetMapping("/esb/outgoing")
    public ResponseEntity<List<EsbMessage>> getOutgoingMessages() {
        List<EsbMessage> messages = jmsTemplate.browse("outgoing", session -> {
            List<EsbMessage> result = new ArrayList<>();
            Enumeration<?> enumeration = session.getEnumeration();
            while (enumeration.hasMoreElements()) {
                Message message = (Message) enumeration.nextElement();
                result.add(EsbMessage.fromMessage(message));
            }
            return result;
        });
        return ResponseEntity.ok(messages);
    }

}
Copier après la connexion

Cette classe de contrôleur utilise JmsTemplate pour convertir le JSON du système d'entreprise. Les messages sont convertis en messages JMS. et envoyé à la file d'attente ESB. Utilisez également JmsTemplate pour récupérer les messages JSON traités de la file d'attente ESB.

Démarrez le système ESB

Après avoir terminé les étapes ci-dessus, nous avons construit l'infrastructure d'un système ESB. Afin de l'exécuter et de le tester localement, nous devons effectuer les étapes suivantes :

  1. Basculez vers le répertoire racine du projet.
  2. Exécutez la commande "mvn clean install" dans le terminal pour générer le fichier JAR du projet.
  3. Démarrez Apache ServiceMix et exécutez "bin/servicemix".
  4. Installez le fichier de configuration ESB dans la console de ligne de commande ServiceMix et saisissez "install esb.xml".
  5. Installez le projet ESB dans la console de ligne de commande ServiceMix, entrez "install -s mvn:com.example/esb-demo/0.0.1-SNAPSHOT".
  6. Utilisez la requête POST pour envoyer un message ESB, par exemple : "curl -X POST -H "Content-Type:application/json" -d '{"id":1,"source":"SystemA","destination" :" SystemB","content":"test message"}' http://localhost:8080/esb/incoming".
  7. Récupérez les messages ESB traités à l'aide de la requête GET, par exemple : "curl http://localhost:8080/esb/outgoing".

Résumé

En utilisant Spring Boot et Apache ServiceMix, nous pouvons facilement créer un système ESB efficace pour connecter plusieurs systèmes et applications, et mettre en œuvre l'échange de données et le routage des messages. Dans cet article, nous avons vu comment configurer un système ESB de base et ajouté des points de terminaison REST pour faciliter la communication avec les systèmes d'entreprise. Bien que cet article ne soit qu’un exemple simple, il constitue un bon point de départ pour créer des systèmes ESB plus complexes.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Spring Boot+MyBatis+Atomikos+MySQL (avec code source) Spring Boot+MyBatis+Atomikos+MySQL (avec code source) Aug 15, 2023 pm 04:12 PM

Dans les projets réels, nous essayons d'éviter les transactions distribuées. Cependant, il est parfois vraiment nécessaire de procéder à un fractionnement des services, ce qui entraînera des problèmes de transactions distribuées. Dans le même temps, des transactions distribuées sont également demandées sur le marché lors des entretiens. Vous pouvez vous entraîner avec ce cas et parler de 123 lors de l'entretien.

Comment utiliser Spring Boot pour créer des applications blockchain et des contrats intelligents Comment utiliser Spring Boot pour créer des applications blockchain et des contrats intelligents Jun 22, 2023 am 09:33 AM

Avec l’essor des monnaies numériques telles que Bitcoin, la technologie blockchain est progressivement devenue un sujet brûlant. Les contrats intelligents peuvent être considérés comme un élément important de la technologie blockchain. SpringBoot, en tant que framework de développement back-end Java populaire, peut également être utilisé pour créer des applications blockchain et des contrats intelligents. Cet article explique comment utiliser SpringBoot pour créer des applications et des contrats intelligents basés sur la technologie blockchain. 1. SpringBoot et blockchain Tout d'abord, nous devons comprendre certains concepts de base liés à la blockchain. Chaîne de blocs

Bénéficiez d'un support multilingue et d'applications internationales grâce à Spring Boot Bénéficiez d'un support multilingue et d'applications internationales grâce à Spring Boot Jun 23, 2023 am 09:09 AM

Avec le développement de la mondialisation, de plus en plus de sites Web et d'applications doivent fournir un support multilingue et des fonctions d'internationalisation. Pour les développeurs, la mise en œuvre de ces fonctions n’est pas une tâche facile car elle nécessite de prendre en compte de nombreux aspects, tels que la traduction linguistique, les formats de date, d’heure et de devise, etc. Cependant, grâce au framework SpringBoot, nous pouvons facilement implémenter un support multilingue et des applications internationales. Tout d’abord, comprenons l’interface LocaleResolver fournie par SpringBoot. Lieu

Comment utiliser Spring Boot pour créer des applications de traitement de Big Data Comment utiliser Spring Boot pour créer des applications de traitement de Big Data Jun 23, 2023 am 09:07 AM

Avec l’avènement de l’ère du Big Data, de plus en plus d’entreprises commencent à comprendre et à reconnaître la valeur du Big Data et à l’appliquer à leurs activités. La question qui se pose est de savoir comment gérer ce flux important de données. Dans ce cas, les applications de traitement du Big Data sont devenues quelque chose que chaque entreprise doit prendre en compte. Pour les développeurs, comment utiliser SpringBoot pour créer une application efficace de traitement du Big Data est également une question très importante. SpringBoot est un framework Java très populaire qui permet

Implémenter le mappage ORM basé sur Spring Boot et MyBatis Plus Implémenter le mappage ORM basé sur Spring Boot et MyBatis Plus Jun 22, 2023 pm 09:27 PM

Dans le processus de développement d'applications Web Java, la technologie de mappage ORM (Object-RelationalMapping) est utilisée pour mapper les données relationnelles de la base de données avec des objets Java, ce qui facilite l'accès et l'exploitation des données par les développeurs. SpringBoot, en tant que l'un des frameworks de développement Web Java les plus populaires à l'heure actuelle, a fourni un moyen d'intégrer MyBatis, et MyBatisPlus est un framework ORM étendu sur la base de MyBatis.

Intégration et utilisation de Spring Boot et base de données NoSQL Intégration et utilisation de Spring Boot et base de données NoSQL Jun 22, 2023 pm 10:34 PM

Avec le développement d’Internet, l’analyse des mégadonnées et le traitement de l’information en temps réel sont devenus un besoin important pour les entreprises. Afin de répondre à de tels besoins, les bases de données relationnelles traditionnelles ne répondent plus aux besoins du développement commercial et technologique. Au lieu de cela, l’utilisation de bases de données NoSQL est devenue une option importante. Dans cet article, nous aborderons l'utilisation de SpringBoot intégré aux bases de données NoSQL pour permettre le développement et le déploiement d'applications modernes. Qu'est-ce qu'une base de données NoSQL ? NoSQL n'est pas seulement du SQL

Système de mise en cache et de stockage de données distribué basé sur Spring Boot Système de mise en cache et de stockage de données distribué basé sur Spring Boot Jun 22, 2023 am 09:48 AM

Avec le développement et la vulgarisation continus d'Internet, la demande en matière de traitement et de stockage de données augmente également. La manière de traiter et de stocker les données de manière efficace et fiable est devenue un sujet brûlant parmi l'industrie et les chercheurs. Le système distribué de mise en cache et de stockage des données basé sur SpringBoot est une solution qui a beaucoup retenu l'attention ces dernières années. Qu'est-ce qu'un système distribué de mise en cache et de stockage de données ? Les systèmes de mise en cache et de stockage de données distribuées font référence au stockage distribué de données via plusieurs nœuds (serveurs), ce qui améliore la sécurité et la fiabilité des données et peut également améliorer le traitement des données.

Créer un système ESB à l'aide de Spring Boot et Apache ServiceMix Créer un système ESB à l'aide de Spring Boot et Apache ServiceMix Jun 22, 2023 pm 12:30 PM

Alors que les entreprises modernes s’appuient de plus en plus sur une variété d’applications et de systèmes disparates, l’intégration d’entreprise devient encore plus importante. Enterprise Service Bus (ESB) est un modèle d'architecture d'intégration qui connecte différents systèmes et applications entre eux pour fournir des services communs d'échange de données et de routage de messages afin de réaliser l'intégration des applications au niveau de l'entreprise. En utilisant SpringBoot et ApacheServiceMix, nous pouvons facilement créer un système ESB. Cet article explique comment l'implémenter. SpringBoot et A

See all articles