<?xml version="1.0" encoding="UTF-8"?><rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Serverless Archive - CEOsBay</title>
	<atom:link href="https://ceosbay.com/tag/serverless/feed/" rel="self" type="application/rss+xml" />
	<link>https://ceosbay.com/tag/serverless/</link>
	<description>It&#039;s all about Tech</description>
	<lastBuildDate>Mon, 17 Feb 2025 08:52:22 +0000</lastBuildDate>
	<language>de</language>
	<sy:updatePeriod>
	hourly	</sy:updatePeriod>
	<sy:updateFrequency>
	1	</sy:updateFrequency>
	<generator>https://wordpress.org/?v=6.9.1</generator>

<image>
	<url>https://i0.wp.com/ceosbay.com/wp-content/uploads/2022/11/image.jpg?fit=32%2C32&#038;ssl=1</url>
	<title>Serverless Archive - CEOsBay</title>
	<link>https://ceosbay.com/tag/serverless/</link>
	<width>32</width>
	<height>32</height>
</image> 
<site xmlns="com-wordpress:feed-additions:1">211828771</site>	<item>
		<title>SOA (Serviceorientierte Architekturen)</title>
		<link>https://ceosbay.com/2025/02/17/soa-serviceorientierte-architekturen/</link>
					<comments>https://ceosbay.com/2025/02/17/soa-serviceorientierte-architekturen/#respond</comments>
		
		<dc:creator><![CDATA[CEO]]></dc:creator>
		<pubDate>Mon, 17 Feb 2025 08:50:36 +0000</pubDate>
				<category><![CDATA[Entwicklung]]></category>
		<category><![CDATA[Informationstechnologie]]></category>
		<category><![CDATA[Software]]></category>
		<category><![CDATA[API]]></category>
		<category><![CDATA[Cloud]]></category>
		<category><![CDATA[DevOps]]></category>
		<category><![CDATA[Digitalisierung]]></category>
		<category><![CDATA[Enterprise Service Bus]]></category>
		<category><![CDATA[ESB]]></category>
		<category><![CDATA[Event-Driven Architecture]]></category>
		<category><![CDATA[Flexibilität]]></category>
		<category><![CDATA[gRPC]]></category>
		<category><![CDATA[Interoperabilität]]></category>
		<category><![CDATA[IT-Architektur]]></category>
		<category><![CDATA[IT-Systeme]]></category>
		<category><![CDATA[lose Kopplung]]></category>
		<category><![CDATA[Microservices]]></category>
		<category><![CDATA[Modularität]]></category>
		<category><![CDATA[Monolith]]></category>
		<category><![CDATA[Rest]]></category>
		<category><![CDATA[Serverless]]></category>
		<category><![CDATA[Serviceorientierte Architektur]]></category>
		<category><![CDATA[Skalierbarkeit]]></category>
		<category><![CDATA[SOA]]></category>
		<category><![CDATA[Softwareentwicklung]]></category>
		<category><![CDATA[Technologie-Trends]]></category>
		<category><![CDATA[Unternehmensarchitektur]]></category>
		<category><![CDATA[Wiederverwendbarkeit]]></category>
		<guid isPermaLink="false">https://ceosbay.com/?p=4822</guid>

					<description><![CDATA[<p>In der heutigen digitalen Welt sind Flexibilität, Skalierbarkeit und Effizienz entscheidende Faktoren für den Erfolg von IT-Systemen. Eine der bewährten Methoden, um diese Anforderungen zu erfüllen, ist die serviceorientierte Architektur (SOA). Doch was genau verbirgt &#8230;</p>
<p>Der Beitrag <a href="https://ceosbay.com/2025/02/17/soa-serviceorientierte-architekturen/">SOA (Serviceorientierte Architekturen)</a> erschien zuerst auf <a href="https://ceosbay.com">CEOsBay</a>.</p>
]]></description>
										<content:encoded><![CDATA[
<p>In der heutigen digitalen Welt sind Flexibilität, Skalierbarkeit und Effizienz entscheidende Faktoren für den Erfolg von IT-Systemen. Eine der bewährten Methoden, um diese Anforderungen zu erfüllen, ist die serviceorientierte Architektur (SOA). Doch was genau verbirgt sich hinter diesem Begriff, welche Vorteile bringt SOA mit sich und wie steht sie im Vergleich zu modernen Alternativen wie Microservices? In diesem Beitrag werfen wir einen genaueren Blick auf dieses Architekturparadigma.</p>



<figure class="wp-block-image size-full"><img data-recalc-dims="1" fetchpriority="high" decoding="async" width="871" height="871" src="https://i0.wp.com/ceosbay.com/wp-content/uploads/2025/02/SOA.jpg?resize=871%2C871&#038;ssl=1" alt="SOA" class="wp-image-4964" srcset="https://i0.wp.com/ceosbay.com/wp-content/uploads/2025/02/SOA.jpg?w=1024&amp;ssl=1 1024w, https://i0.wp.com/ceosbay.com/wp-content/uploads/2025/02/SOA.jpg?resize=300%2C300&amp;ssl=1 300w, https://i0.wp.com/ceosbay.com/wp-content/uploads/2025/02/SOA.jpg?resize=150%2C150&amp;ssl=1 150w, https://i0.wp.com/ceosbay.com/wp-content/uploads/2025/02/SOA.jpg?resize=768%2C768&amp;ssl=1 768w" sizes="(max-width: 871px) 100vw, 871px" /></figure>



<h3 class="wp-block-heading">Was ist SOA?</h3>



<p>Die serviceorientierte Architektur ist ein Ansatz zur Softwareentwicklung, bei dem man Anwendungen als eine Sammlung voneinander unabhängiger Dienste strukturiert. Jeder Dienst bietet eine klar definierte Funktionalität an, die man über standardisierte Schnittstellen ansprechen kann. Diese Dienste sind lose gekoppelt, was bedeutet, dass sie unabhängig voneinander entwickelt, aktualisiert und skaliert werden können.</p>



<h4 class="wp-block-heading">SOA basiert auf einer Reihe von Prinzipien:</h4>



<ul class="wp-block-list">
<li><strong>Lose Kopplung</strong>: Dienste sind nicht direkt voneinander abhängig, sondern kommunizieren über definierte Schnittstellen. Siehe auch meinen Beitrag &#8222;<a href="https://ceosbay.com/2023/04/20/api-nahtlose-verbindungen-fuer-innovationen/">API – Nahtlose Verbindungen für Innovationen</a>&#8222;.</li>



<li><strong>Wiederverwendbarkeit</strong>: Ein einmal entwickelter Dienst kann in verschiedenen Anwendungen oder Prozessen genutzt werden.</li>



<li><strong>Interoperabilität</strong>: Dienste können unabhängig von der zugrunde liegenden Technologie miteinander kommunizieren.</li>



<li><strong>Modularität</strong>: Anwendungen werden in kleinere, eigenständige Einheiten zerlegt.</li>
</ul>



<h3 class="wp-block-heading">Vorteile von SOA</h3>



<h4 class="wp-block-heading">SOA bietet eine Reihe von Vorteilen für Unternehmen, insbesondere in komplexen IT-Landschaften:</h4>



<ul class="wp-block-list">
<li><strong>Flexibilität</strong>: Durch die lose Kopplung der Dienste können Änderungen oder Erweiterungen vorgenommen werden, ohne dass das gesamte System betroffen ist.</li>



<li><strong>Skalierbarkeit</strong>: Einzelne Dienste können unabhängig voneinander skaliert werden, je nach Bedarf.</li>



<li><strong>Wiederverwendbarkeit</strong>: Vorhandene Dienste kann man in neuen Kontexten nutzen, was Entwicklungsaufwand spart.</li>



<li><strong>Bessere Wartbarkeit</strong>: Durch die Modularität der Architektur kann man Fehler schneller beheben und Updates einfacher durchführen.</li>
</ul>



<h3 class="wp-block-heading">Herausforderungen und Best Practices</h3>



<h4 class="wp-block-heading">Trotz der zahlreichen Vorteile gibt es einige Herausforderungen bei der Implementierung von SOA:</h4>



<ul class="wp-block-list">
<li><strong>Komplexität</strong>: Die Verwaltung vieler unabhängiger Dienste kann anspruchsvoll sein.</li>



<li><strong>Performance</strong>: Da Dienste häufig über Netzwerke kommunizieren, kann dies zu Latenzen führen.</li>



<li><strong>Sicherheit</strong>: Die Absicherung der Kommunikation zwischen Diensten ist essenziell, insbesondere in verteilten Systemen.</li>
</ul>



<h4 class="wp-block-heading">Um diesen Herausforderungen zu begegnen, sollte man einige Best Practices befolgen:</h4>



<ul class="wp-block-list">
<li><strong>Standardisierte Schnittstellen verwenden</strong>: <a href="https://ceosbay.com/2023/04/20/api-nahtlose-verbindungen-fuer-innovationen/">APIs</a> sollten gut dokumentiert und standardisiert sein.</li>



<li><strong>Service-Governance etablieren</strong>: Regeln für die Nutzung und Verwaltung von Diensten helfen, Chaos zu vermeiden.</li>



<li><strong>Monitoring und Logging</strong>: Eine gute Überwachung der Dienste ist entscheidend, um Probleme frühzeitig zu erkennen und zu beheben.</li>
</ul>



<h3 class="wp-block-heading">SOA vs. Microservices – Ist SOA veraltet?</h3>



<p>Viele moderne Entwickler bevorzugen heutzutage Microservices gegenüber SOA, da sie eine noch granularere und flexiblere <a href="https://ceosbay.com/2023/08/02/softwarearchitektur-entstehung-bedeutung-und-best-practices/">Architektur</a> bieten. Während SOA oft große, in sich geschlossene Dienste definiert, setzt der Microservices-Ansatz auf sehr kleine, spezialisierte Services, die über leichtgewichtige Protokolle (z.B. <a href="https://ceosbay.com/2022/12/23/erklaerung-rest/">REST</a> oder gRPC) kommunizieren.</p>



<h4 class="wp-block-heading">Einige Unterschiede zwischen SOA und Microservices:</h4>



<ul class="wp-block-list">
<li><strong>Granularität</strong>: Microservices sind feingranularer als klassische SOA-Dienste.</li>



<li><strong>Kommunikation</strong>: Während SOA häufig auf komplexe Middleware (z.B. Enterprise Service Bus, ESB) setzt, nutzen Microservices oft einfache <a href="https://ceosbay.com/2022/12/23/erklaerung-rest/">REST</a>&#8211; oder gRPC-Schnittstellen.</li>



<li><strong>Bereitstellung</strong>: Microservices erlauben eine unabhängige Bereitstellung und Skalierung einzelner Services, während SOA eher in größeren Einheiten verwaltet wird.</li>



<li><strong>Technologievielfalt</strong>: Microservices-Architekturen erlauben eine breitere Wahl an Technologien und Programmiersprachen für einzelne Services.</li>
</ul>



<h3 class="wp-block-heading">Alternativen zu SOA</h3>



<p>Neben Microservices gibt es weitere Architekturansätze, die für verschiedene Szenarien geeignet sein können:</p>



<ul class="wp-block-list">
<li><strong>Monolithische Architektur</strong>: Eine traditionelle Architektur, bei der die gesamte Anwendung als eine einzige Einheit entwickelt wird. Dies kann für kleinere Anwendungen sinnvoll sein, ist aber weniger skalierbar.</li>



<li><strong>Serverless Computing</strong>: Dienste werden nur bei Bedarf ausgeführt, was eine kosteneffiziente und skalierbare Alternative darstellt.</li>



<li><strong>Event-Driven Architecture</strong>: Anwendungen bestehen aus lose gekoppelten Komponenten, die auf Events reagieren, was eine hohe Skalierbarkeit ermöglicht.</li>
</ul>



<h3 class="wp-block-heading">Fazit</h3>



<p>SOA bleibt auch in Zeiten moderner <a href="https://ceosbay.com/2023/08/02/softwarearchitektur-entstehung-bedeutung-und-best-practices/">Architekturen</a> ein relevantes Konzept, insbesondere für Unternehmen mit bestehenden monolithischen Systemen. Dennoch gilt es heute als weniger agil (Siehe meinen Beitrag &#8222;<a href="https://ceosbay.com/2023/03/20/erklaerung-das-agile-manifest/">Agile Manifest – Die bessere Art der Softwareentwicklung</a>&#8222;) als Microservices, die mehr Flexibilität und Unabhängigkeit bieten. Abhängig von den Anforderungen eines Unternehmens kann SOA weiterhin eine geeignete Lösung sein, insbesondere wenn man bestehende Systeme integrieren muss. Wer sich jedoch für eine zukunftssichere, hochgradig skalierbare <a href="https://ceosbay.com/2023/08/02/softwarearchitektur-entstehung-bedeutung-und-best-practices/">Architektur</a> interessiert, sollte Alternativen wie Microservices oder Serverless-Ansätze in Betracht ziehen.</p>
<p>Der Beitrag <a href="https://ceosbay.com/2025/02/17/soa-serviceorientierte-architekturen/">SOA (Serviceorientierte Architekturen)</a> erschien zuerst auf <a href="https://ceosbay.com">CEOsBay</a>.</p>
]]></content:encoded>
					
					<wfw:commentRss>https://ceosbay.com/2025/02/17/soa-serviceorientierte-architekturen/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
		<post-id xmlns="com-wordpress:feed-additions:1">4822</post-id>	</item>
		<item>
		<title>SOAP &#8211; Effiziente Möglichkeit, um Daten zwischen Systemen zu übertragen</title>
		<link>https://ceosbay.com/2023/03/23/erklaerung-soap/</link>
					<comments>https://ceosbay.com/2023/03/23/erklaerung-soap/#respond</comments>
		
		<dc:creator><![CDATA[CEO]]></dc:creator>
		<pubDate>Thu, 23 Mar 2023 17:16:00 +0000</pubDate>
				<category><![CDATA[Agile]]></category>
		<category><![CDATA[Big-Data]]></category>
		<category><![CDATA[Datenbanken]]></category>
		<category><![CDATA[DevOps]]></category>
		<category><![CDATA[Entwicklung]]></category>
		<category><![CDATA[Internet]]></category>
		<category><![CDATA[Netzwerk]]></category>
		<category><![CDATA[Programmieren]]></category>
		<category><![CDATA[Raspberry Pi]]></category>
		<category><![CDATA[Sicherheit]]></category>
		<category><![CDATA[Website]]></category>
		<category><![CDATA[API]]></category>
		<category><![CDATA[Application]]></category>
		<category><![CDATA[Body]]></category>
		<category><![CDATA[Child]]></category>
		<category><![CDATA[Compliance]]></category>
		<category><![CDATA[Computing]]></category>
		<category><![CDATA[CSV]]></category>
		<category><![CDATA[Daten]]></category>
		<category><![CDATA[Datenaustausch]]></category>
		<category><![CDATA[EAI]]></category>
		<category><![CDATA[Empfänger]]></category>
		<category><![CDATA[Enterprise]]></category>
		<category><![CDATA[FTP]]></category>
		<category><![CDATA[Header]]></category>
		<category><![CDATA[https]]></category>
		<category><![CDATA[IBM]]></category>
		<category><![CDATA[Information]]></category>
		<category><![CDATA[Integration]]></category>
		<category><![CDATA[IoT]]></category>
		<category><![CDATA[Java]]></category>
		<category><![CDATA[JMS]]></category>
		<category><![CDATA[Kind]]></category>
		<category><![CDATA[Microsoft]]></category>
		<category><![CDATA[Middleware]]></category>
		<category><![CDATA[Object]]></category>
		<category><![CDATA[Post]]></category>
		<category><![CDATA[Protocol]]></category>
		<category><![CDATA[Protokoll]]></category>
		<category><![CDATA[Request]]></category>
		<category><![CDATA[Rest]]></category>
		<category><![CDATA[Richtlinien]]></category>
		<category><![CDATA[RSS]]></category>
		<category><![CDATA[Security]]></category>
		<category><![CDATA[Sender]]></category>
		<category><![CDATA[Serverless]]></category>
		<category><![CDATA[Services]]></category>
		<category><![CDATA[SOAP]]></category>
		<category><![CDATA[Source]]></category>
		<category><![CDATA[Transaktion]]></category>
		<category><![CDATA[Unternehmensanforderungen]]></category>
		<category><![CDATA[URL]]></category>
		<category><![CDATA[Verbindung]]></category>
		<category><![CDATA[Verschlüsselung]]></category>
		<category><![CDATA[W3C]]></category>
		<category><![CDATA[Ware]]></category>
		<category><![CDATA[Web]]></category>
		<category><![CDATA[www]]></category>
		<guid isPermaLink="false">https://ceosbay.com/?p=1069</guid>

					<description><![CDATA[<p>SOAP (Simple Object Access Protocol) ist ein Netzwerkprotokoll, mit dessen Hilfe man Daten zwischen Systemen austauschen und RPC’s (Remote Procedure Calls) durchführen kann. SOAP ist ein industrieller Standard des World Wide Web Consortiums (W3C). Es &#8230;</p>
<p>Der Beitrag <a href="https://ceosbay.com/2023/03/23/erklaerung-soap/">SOAP &#8211; Effiziente Möglichkeit, um Daten zwischen Systemen zu übertragen</a> erschien zuerst auf <a href="https://ceosbay.com">CEOsBay</a>.</p>
]]></description>
										<content:encoded><![CDATA[
<p>SOAP (Simple Object Access Protocol) ist ein Netzwerkprotokoll, mit dessen Hilfe man Daten zwischen Systemen austauschen und RPC’s (Remote Procedure Calls) durchführen kann. SOAP ist ein industrieller Standard des World Wide Web Consortiums (W3C).</p>



<p>Es stützt sich auf <a href="https://ceosbay.com/2022/12/27/erklaerung-xml/" target="_blank" rel="noreferrer noopener">XML</a> zur Repräsentation der Daten und auf Internet-Protokolle der Transport- und Anwendungsschicht zur Übertragung der Nachrichten. Die gängigste Kombination ist SOAP über https (Hypertext Transfer Protocol) und TCP (Transmission Control Protocol). Man kann SOAP auch über das SMTP (Simple Mail Transfer Protocol) oder JMS (Jakarta Messaging) verwenden.</p>



<p>Die mit der Nachricht übermittelten Nutzdaten man nicht zwingend in <a href="https://ceosbay.com/2022/12/27/erklaerung-xml/" target="_blank" rel="noreferrer noopener">XML</a> senden. Andere Formate wie Base64 oder CSV sind ebenfalls möglich. Seit Version 1.2. nutzt man die Abkürzung SOAP offiziell nicht mehr als Akronym, da es erstens (subjektiv) keineswegs einfach (Simple) ist und zweitens nicht nur dem Zugriff auf Objekte (Object Access) dient.</p>



<h3 class="wp-block-heading">Kurze Zeitreise</h3>



<p>SOAP entstand aus der Weiterentwicklung der Spezifikation für <a href="https://ceosbay.com/2022/12/27/erklaerung-xml/" target="_blank" rel="noreferrer noopener">XML</a>-RPC im Jahr 1998. Hauptverantwortlicher Software-Entwickler damals Dave Winer und seine Firma UserLand Software in engem Austausch mit Microsoft. Dave Winter ist übrigens auch für <a href="https://ceosbay.com/2022/12/28/erklaerung-rss/" target="_blank" rel="noreferrer noopener">RSS</a> 2.0 verantwortlich. Einen Beitrag über <a href="https://ceosbay.com/2022/12/28/erklaerung-rss/" target="_blank" rel="noreferrer noopener">RSS</a> findet man <a href="https://ceosbay.com/2022/12/28/erklaerung-rss/" target="_blank" rel="noreferrer noopener">hier</a>.</p>



<p>Im Jahr 1999 fand die Veröffentlichung der Version 1.0 von SOAP statt. Dies stellt unter Anderem den Zeitpunkt dar, an dem die Entwicklung mehr Unterstützung fand. Vor allem hat sich IBM im Jahr 2000 der Entwicklung angeschlossen, was dazu führte, dass IBM, Microsoft, DevelopMentor (Don Box) und UserLand Software (Dave Winer) die Spezifikation von SOAP 1.1 beim World Wide Web Consortium (W3C) einreichten. Dabei hat man das Ziel verfolgt, eine Arbeitsgruppe zu gründen, die SOAP weiterentwickeln sollte. Das Ergebnis dieser Arbeitsgruppe ist SOAP Version 1.2, empfing im Juni 2003 die Anerkennung als recommendation (Empfehlung).</p>



<p>Wie zu Beginn des Beitrags erwähnt, hat man SOAP nicht mehr als gebräuchliche(s) Akronym bzw. Abkürzung verstanden. Der Hauptgrund dafür ist die Tatsache, dass sämtliche Deutungen für SOAP, wie Simple Object Access Protocol oder Service Oriented Architecture Protocol, nicht mehr den vollständigen Sinn von SOAP trafen. Dies ermöglichte die Anmeldung von SOAP als Markennamen in den USA.</p>



<h3 class="wp-block-heading">Wie funktioniert SOAP?</h3>



<p>SOAP ist wie zuvor beschrieben, ein Protokoll zum Austausch <a href="https://ceosbay.com/2022/12/27/erklaerung-xml/" target="_blank" rel="noreferrer noopener">XML</a>-Information-Set-basierter Nachrichten über ein Rechnernetz und hat den Status einer W3C-Empfehlung. Es stellt Regeln für das Nachrichtendesign auf. Regelt, wie Daten in der Nachricht abzubilden und zu interpretieren sind. Es gibt eine Konvention für entfernte Prozeduraufrufe mittels SOAP-Nachrichten vor. SOAP macht keine Vorschriften zur Semantik applikationsspezifischer Daten, die man gegebenenfalls versendet möchte, sondern stellt ein <a href="https://ceosbay.com/2022/11/14/erklaerung-frameworks/" target="_blank" rel="noreferrer noopener">Framework</a> (Siehe meinen Beitrag) zur Verfügung, welches erlaubt, dass man beliebige applikationsspezifische Informationen übertragen kann. </p>



<p>Man kann SOAP für entfernte Prozeduraufrufe ebenso nutzen wie für einfache Nachrichtensysteme. Zum Senden von Nachrichten kann man beliebige Transportprotokolle verwendet. Dazu gehören beispielsweise FTP, SMTP, https oder auch JMS. Aus Gründen der Kompatibilität nutzt man in der Praxis hierzu gängige Netzwerk-Architekturen. Auch ist mittels https die verschlüsselte Übertragung von SOAP-Nachrichten möglich. Das ermöglicht jedoch keine End-to-End-Verschlüsselung. Dies kann man durch WS-Security erreichen. Die Einbindung erfolgt lediglich auf der Ebene der Nachrichten und nicht auf der des unterliegenden Transportprotokolls. Folglich ist es so, dass man das <a href="https://ceosbay.com/2022/12/27/erklaerung-xml/" target="_blank" rel="noreferrer noopener">XML</a> Information Set der SOAP-Anfrage bei Nutzung von https(S) im Body eines https POST Requests als <a href="https://ceosbay.com/2022/12/27/erklaerung-xml/" target="_blank" rel="noreferrer noopener">XML</a> an eine gegebene URL schickt.</p>



<p>In der Regel setzt man SOAP da ein, wo der direkte Zugang fremder Systeme zu einer Informationsquelle nicht sinnvoll erscheint. Dies kann sowohl an Kompatibilitätsproblemen zwischen verschiedenen Anwendungsarchitekturen liegen aber auch an diversen Sicherheitsaspekten. So kann man einen (partiellen) Zugriff auf eine Datenbank ermöglichen, ohne dem Anwenderprogramm den direkten Zugang zu ermöglichen. Die Menge der ausführbaren Methoden reglementiert und definiert man über die SOAP-Schnittstelle.</p>



<p>Die Kommunikation mit SOAP ermöglicht die Kopplung von Systemen. Der offene Entwurf ermöglicht jedoch lediglich den Aufbau schwach gekoppelter Systeme. Die Flexibilität des Konzeptes erkauft man sich durch die Nachteile beim Übertragungsvolumen und Rechenaufwand. Dies kann teuer werden, da man das <a href="https://ceosbay.com/2022/12/27/erklaerung-xml/" target="_blank" rel="noreferrer noopener">XML</a>-Dokument beim Sender zunächst aufbaut und anschließend validiert. Das Konzept verfolgt eigentlich das Ziel eines leichtgewichtigen Protokolls. </p>



<p>Doch durch den flexiblen Einsatzbereich führt die zu übertragende Datei eine Reihe von Metadaten mit sich, die bei der Konstruktion des <a href="https://ceosbay.com/2022/12/27/erklaerung-xml/" target="_blank" rel="noreferrer noopener">XML</a>-Dokuments weiter anwächst. So führt beispielsweise das einfache Versenden von „Wahr“ oder „Falsch“ zu einem Datenvolumen von mehreren hundert Bytes. In einem stark gekoppelten System sollte dafür theoretisch ein Bit reichen. </p>



<p>Durch die Möglichkeit des flexiblen Aufbaus des Dokuments kann man jedoch auch komplexe Transaktionen in einer Anfrage atomar zusammenfassen, während man in stark gekoppelten Systemen hierzu oftmals mehrere Anfragen erstellen muss. Dies verbessert das Nutzlastverhältnis (Nutzdaten zu Meta-Daten) und den Kommunikationsaufwand (für den Aufbau einer Verbindung, nur ein Senden/Empfangen).</p>



<p>SOAP unterscheidet zwischen dem endgültigen Empfänger und den Zwischenempfängern. Dies ermöglicht es, eine Nachricht über verschiedene „Hops“ zu schicken, bei denen man sogar verschiedene Transportprotokolle verwendet. Beispielsweise kann man zum ersten Hop die Nachricht mittels <a href="https://ceosbay.com/2023/03/16/erklaerung-java/" target="_blank" rel="noreferrer noopener">Java</a> Message Service schicken, im Anschluss über E-Mail und schließlich dem Empfänger mittels https weitergeben. Der Absender muss über die Zwischenhops keine Information haben, die Middleware jedoch schon.</p>



<h3 class="wp-block-heading">Wie ist eine SOAP-Nachricht aufgebaut?</h3>



<p>Eine minimale SOAP-Nachricht besteht aus einem Envelope genannten Element, dem man einen lokalen Namen zuweisen muss. Dieses Element referenziert mittels eines Namensraum-Attributes auf https://www.w3.org/2003/05/soap-envelope. Child dieses Elements muss ein Body-Element sein. Optional kann zuvor ein Header-Element stehen. In diesem kann man Meta-Informationen, beispielsweise zum Routing, zur Verschlüsselung oder zu Transaktionsidentifizierung, unterbringen. Im Body-Element sind die eigentlichen Nutzdaten untergebracht. Dies sieht dann folgendermaßen aus:</p>



<pre class="wp-block-code"><code>&lt;?xml version="1.0"?&gt;
&lt;s:Envelope xmlns:s="https://www.w3.org/2003/05/soap-envelope"&gt;
    &lt;s:Header&gt;
    &lt;/s:Header&gt;
    &lt;s:Body&gt;
    &lt;/s:Body&gt;
&lt;/s:Envelope&gt;</code></pre>



<p>Innerhalb des Body-Elements können sowohl Informationen zum Datenaustausch als auch Anweisungen für einen entfernten Prozeduraufruf stehen. Dies ist vom Empfänger entsprechend zu interpretieren.</p>



<p>Im Header gibt man den nächsten Hop (intermediary) und den endgültigen Empfänger (ultimate recipient) an. Ein intermediary kann beispielsweise die Nachricht verschlüsseln, sie loggen oder die Nachricht aufteilen. Ersteres erlaubt es, dass die Anwendungslogik sich nicht um die Sicherheit der Nachricht kümmern muss. Darum kümmert sich die Middleware. Was eine Middleware ist, erkläre ich in einem anderen Beitrag. Die Möglichkeit, dass Intermediaries beliebige Dinge tun können, ermöglicht EAI (Enterprise Application Integration).</p>



<h3 class="wp-block-heading">Fazit</h3>



<p>Viele Altsysteme verwenden möglicherweise noch SOAP. In der Vergangenheit war es auch die Lösung schlechthin. Heute ist es eher <a href="https://ceosbay.com/2022/12/23/erklaerung-rest/" target="_blank" rel="noreferrer noopener">REST</a>, welches zum Einsatz kommt und in webbasierten Szenarien häufig als die schnellere Alternative gilt.</p>



<p>Zusammengefasst kann man sagen, dass <a href="https://ceosbay.com/2022/12/23/erklaerung-rest/" target="_blank" rel="noreferrer noopener">REST</a> aus einer Reihe von Richtlinien für eine flexible Implementierung besteht und SOAP ein Protokoll mit spezifischen Anforderungen wie <a href="https://ceosbay.com/2022/12/27/erklaerung-xml/" target="_blank" rel="noreferrer noopener">XML</a>-Messaging ist.</p>



<p><a href="https://ceosbay.com/2022/12/23/erklaerung-rest/" target="_blank" rel="noreferrer noopener">REST-APIs</a> sind schlank und daher ideal für moderne Anwendungen geeignet, wie das Internet of Things (IoT), mobile Anwendungen und Serverless Computing. SOAP-Webservices bieten zwar integrierte Sicherheit und Transaktions-Compliance, die vielen Unternehmensanforderungen entspricht, doch die Erstellung und Wartung ist wesentlich aufwändiger. Darüber hinaus folgen auch viele öffentlich zugängliche APIsheutzutage, den REST-Richtlinien.</p>
<p>Der Beitrag <a href="https://ceosbay.com/2023/03/23/erklaerung-soap/">SOAP &#8211; Effiziente Möglichkeit, um Daten zwischen Systemen zu übertragen</a> erschien zuerst auf <a href="https://ceosbay.com">CEOsBay</a>.</p>
]]></content:encoded>
					
					<wfw:commentRss>https://ceosbay.com/2023/03/23/erklaerung-soap/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
		<post-id xmlns="com-wordpress:feed-additions:1">1069</post-id>	</item>
	</channel>
</rss>
