Når SOA er en del af problemet - og ikke løsningen

Klumme: SOA kan ikke gå på vandet. Man skal omhyggeligt bygge bro hver gang. Desværre udråbes SOA alt for ofte til fremtidens mirakel.

Serviceorienteret arkitektur (SOA) har vist sig nyttig til at opbygge nye systemer, der trækker på data i store, gamle systemer.

Programmørerne udvider de gamle systemer med et antal services, der kan overføre data, og de nye systemer trækker på disse services.

De, der har prøvet det, ved, at det ikke er smertefrit, men alligevel sikrere end den traditionelle løsning, hvor nye systemer udfører SQL-sætninger direkte på de gamle databaser.

Så langt så godt. Problemet kommer, når SOA udråbes som fremtidens mirakel. Alt skal gøres serviceorienteret.

Man skal opbygge alle systemer som moduler, der hver især tilbyder et antal forretningsorienterede services. Så kan modulerne let sættes sammen til nye løsninger, siges det. SQL-sætningerne skal skjules bag services.

Det lyder jo forjættende, men som med så meget andet i it-verdenen, går det ikke helt, som præsten prædiker. I praksis bliver der for eksempel hele tiden behov for nye services i de eksisterende moduler, og det er langt mere besværligt at tilføje en ny service end at skrive en ny SQL-sætning.

Jeg vil illustrere problemerne med to eksempler fra virksomheder med store SOA-løsninger. De har typisk opbygget en SOA-løsning bestående af 5-10 systemer (moduler) koblet sammen med services. Hvert modul tilbyder 30-40 serviceoperationer, som er defineret i et tæt samarbejde med dem, der står for de andre moduler.

Man forestiller sig, at man nu har defineret alle de nødvendige serviceoperationer – man har jo tænkt sig grundigt om.

Første eksempel

Eksempel 1: Virksomheden begynder at opbygge en ny anvendelse med nye skærmbilleder. Det går ikke så let, for de eksisterende services passer alligevel ikke rigtigt, og man forhandler flittigt om, hvem der har skylden. Er services defineret forkert, eller kan de nye udviklere ikke finde ud af at bruge dem?

Problemet stammer ofte fra brugergrænsefladen.

Et typisk skærmbillede bruger flere SQL-sætninger: En til hovedet af billedet, en til en tabel i billedet, et par stykker til drop-down-lister. Og behovet varierer fra billede til billede.

Disse SQL-sætninger svarer sjældent til de eksisterende services.

Skal man holde sig til dem, får man enten dårlig brugerstøtte, eller også må den nye anvendelse overføre en masse overflødigt data og selv uddrage det relevante (såkaldte client-level joins).

Her har djævlen spillet os et puds ved at forbinde brugergrænsefladens detaljer med databasens detaljer – tværs over arkitekternes forretningsorienterede services. Den magi, der ligger i en relationsdatabase, kan ikke udføres på klient-siden.

Andet eksempel

Virksomheden vil købe et nyt standardsystem, som skal kobles sammen med de eksisterende. Hvad kræver det af leverandøren? Det nye standard­system har måske 500 SQL-sætninger og stored procedures, der trækker på leverandørens egen database.

De skal nu erstattes med kald af nogle services, men igen er der ikke lige den rigtige service. Enten må man atter tilføje services eller lave client-level join.

Men uanset den valgte løsning er det ikke længere et standardsystem, så det skal vedligeholdes for sig selv og vil koste en formue. Det er fordi, standardsystemet ikke er SOA-baseret, siger profeterne.

Ak, nej. Dets services ville sandsynligvis være inkompatible med kundens, og resultatet ville blive det samme.

Leverandøren vil eventuelt foreslå, at hans system replikerer virksomhedens data og på passende tidspunkter synkroniserer de to databaser. Det kan han lettere lave som et tillægsmodul, der ikke griber dybt ind i standardsystemet.

Desværre er SOA-idealet nu revnet og, dataaktualiteten ikke optimal, men det kan alligevel være den bedste løsning.

Nej, heller ikke SOA kan gå på vandet. Man skal omhyggeligt bygge bro hver gang, man skal til en ny ø. Brug kun SOA, hvor en traditionel database-løsning er umulig. Er SOA uomgængeligt, så gør det i det mindste let at tilføje nye services, og accepter lidt datareplikering.

Søren Lauesen er professor ved ITU.

Computerworlds klummer er ikke nødvendigvis udtryk for Computerworlds holdninger, men er alene udtryk for skribentens holdninger.

Forsvarsministeriets Materiel- og Indkøbsstyrelse

Chef for Styringssektionen til Cyberdivisionen i Hvidovre

Københavnsområdet

AK Techotel A/S

Systemudvikler søges til innovativt firma

Københavnsområdet

KMD A/S

SAP-arkitekt

Skåne

Computerworld Events

Vi samler hvert år mere end 6.000 deltagere på mere end 70 events for it-professionelle.

Ekspertindsigt – Lyt til førende specialister og virksomheder, der deler viden om den nyeste teknologi og de bedste løsninger.
Netværk – Mød beslutningstagere, kolleger og samarbejdspartnere på tværs af brancher.
Praktisk viden – Få konkrete cases, værktøjer og inspiration, som du kan tage direkte med hjem i organisationen.
Aktuelle tendenser – Bliv opdateret på de vigtigste dagsordener inden for cloud, sikkerhed, data, AI og digital forretning.

Sikkerhed | Aarhus C

Strategisk It-sikkerhedsdag 2026 - Aarhus

Få overblik over cybersikkerhedens vigtigste teknologier, trusler og strategiske valg. Hør skarpe oplæg om AI-risici, forsvar, compliance og governance. Vælg mellem tre spor og styrk både indsigt og netværk. Deltag i Aarhus 22. januar.

Digital transformation | København Ø

Digital Innovation & Transformation Summit 2026

Få indsigt i aktuelle digitale trends, lær af andres erfaringer med store transformationer og drøft fremtidens forandringer med ligesindede.

Digital transformation | Aarhus C

Derfor skal du videre fra Dynamics AX – og sådan gør du

Computerworld giver klar viden om vejen videre fra Dynamics AX. Du ser forskellen mellem AX og moderne cloud-ERP og får et konkret beslutningsgrundlag for næste skridt. Tilmeld dig og få styr på skiftet til Dynamics 365 FO eller BC.

Se alle vores events inden for it

Navnenyt fra it-Danmark

EG Danmark A/S har pr. 1. december 2025 ansat Søren Jermiin Olesen som Senior Product Manager. Han skal især beskæftige sig med finans- og debitorstyring i det offentlige med ansvar for økonomistyringssystemet EG ØS Indsigt. Han kommer fra en stilling som Product Manager hos KMD A/S. Han er uddannet Cand. oecon. Han har tidligere beskæftiget sig med økonomi bl.a. i Aarhus Kommune og været med til at udvikle NemØkonom før og efter salget til KMD. Nyt job

Søren Jermiin Olesen

EG Danmark A/S

Forte Advice har pr. 5. januar 2026 ansat Claes Frederiksen som Commercial Director. Claes skal især beskæftige sig med at løfte den kommercielle modenhed i teknologiprojekter og sikre, at teknologi bliver brugt som strategisk løftestang. Claes kommer fra en stilling som Senior Client Partnership Director, Nordics hos Valtech. Claes har tidligere beskæftiget sig med teknologivalg og platformstrategi til teknologidrevet forretningsudvikling og marketing initiativer. Nyt job

Claes Frederiksen

Forte Advice

IT Confidence A/S har pr. 1. oktober 2025 ansat Henrik Thøgersen som it-konsulent med fokus på salg. Han skal især beskæftige sig med rådgivende salg, account management og udvikling af kundeporteføljer på tværs af it-drift, sikkerhed og cloud-løsninger. Han kommer fra en stilling som freelancer i eget firma og client manager hos IT Relation og IT-Afdelingen A/S. Han er uddannet elektromekaniker. Han har tidligere beskæftiget sig med salg af it-løsninger, account management, it-drift og rådgivning samt undervisning og ledelse. Nyt job

Henrik Thøgersen

IT Confidence A/S

Alcadon ApS har pr. 1. januar 2026 ansat Thomas Møller Pedersen som Key Account Manager. Han skal især beskæftige sig med teknisk support og salg inden for FTTx/Telecom i Jylland og på Fyn. Nyt job