Spring Boot Microservices und Entitäten

OnDemand

Top Contributor
Hallo zusammen,

ich habe ein Problem mit dem Aufbau meines Systems:

Ich habe 15 Services die alle samt das gleiche machen, nur anders.

Beispiel:
Jeder Service gehört einem Autohersteller an, der Service holt alle 10 Minuten über eine API die aktuellen Fahrzeuge vom Hersteller.

Dabei werden Objekte vom Typ Auto erstellt und gespeichert in einer DB.

Wenn ich nun in jedem Service eine Entity "Auto" erstelle und irgendwann was anpasse, muss ich das i allen 15 Services machen, dass kann nicht im Sinne des Erfinders sein.

Ich habe nun testweise ein jar gewacht welches ich einbinde, so muss ich nur 1 x das Auto verwalten und alle Services die dieses jar implementiert haben, haben Zugriff auf das neue Auto oder dessen Änderungen.

Gibts da noch eine bessere Möglichkeit sowas zu handeln?
 

httpdigest

Top Contributor
Aus diesem Grunde solltest du Microservices eher an Domain Boundaries errichten und nicht an Funktionen innerhalb einer Domäne. Wenn sich die Definition dessen, was ein Auto ist/ausmacht, ändert, dann sollte das nur einen einzigen Service betreffen. Das sollte dann entweder dein einziger Microservice sein oder es sollte derjenige sein, der sich für das geänderte Detail des Autos interessiert. Nicht jeder Microservice sollte dasselbe Verständnis davon haben, was ein Auto ist/was es ausmacht.
Ich würde mal sagen, der Trick beim Microservice-Schnitt ist, dass eben gerade nicht alle Microservices dasselbe Datenmodell verwenden, sondern dass sie nur ein gemeinsames Verständnis von der "Identität" eines Datensatzes haben und jeder Service sich für einen anderen Teil des Datensatzes interessiert und diesen verwaltet.
Denn sonst hast du mit Microservices gegenüber einem Monolithen ja nicht viel gewonnen, außer, dass du das Deployment-Modell auf mehrere Prozesse verteilst. Aber die Kopplung/Kohäsion besteht ja trotzdem zwischen allen Services und dem gemeinsamen Datenmodell.

EDIT: Wenn aber, wie du sagst, die einzige Variabilität/Parameterisierung deines Services darin besteht, jeweils unterschiedliche APIs zu bedienen, die für den jeweiligen Hersteller ein Auto holen und das Auto dabei dann auch immer dasselbe Schema hat, dann hast du ja sowieso nur eine Codebasis mit Adaptern für die einzelnen Autohersteller. Da würde ich nicht von mehreren Microservices sprechen, sondern nur von einer horizontalen Skalierung/Instanziierung deines einen Services. Wahrscheinlich benutzen dann alle Instanzen auch dieselbe Datenbankinstanz?
 
Zuletzt bearbeitet:

OnDemand

Top Contributor
Hi ja genau, die nutzen eine DB vorerst.

Mein Plan war je Hersteller einen eigenen Service laufen zu lasse, da die Daten echt umfangreich sind die ich da bekomme.

So würde der eine Service weiter laufen, auch wenn der andere nicht mehr funktioniert.

Du hast geschrieben, jeder Service sollte die für einen eigenen Teil des Datensatzes interessieren, kannst du am
Autobeispiel bitte erklären? Ich verstehe es so, dass ein Service die technischen Daten wie PS, Hubraum verwaltet, ein andere die Ausstatuutung innen und so weiter?!

Plan war:

1 MS für BMW
1 MS für Audi
1 MS für VW
1 MS für DB CRUD
die zapfen die Hersteller API an und senden es an den Service DB CRUD welcher die Daten speichert, updated usw
Die DB sollte dann noch tenant werden, da jeder User eine eigene DB bekommen soll, damit er seine Autos selbst bearbeiten kann und eigene hinzufügen kann
 
Zuletzt bearbeitet:

mihe7

Top Contributor
da die Daten echt umfangreich sind die ich da bekomme.
Definiere "umfangreich".

jeder Service sollte die für einen eigenen Teil des Datensatzes interessieren, kannst du am Autobeispiel bitte erklären?

Wenn die Software unterschiedliche Problembereiche abdeckt, dann erhältst Du für jeden Bereich ggf. ganz unterschiedliche Beschreibungen für ein Auto. D. h. jeder Bereich modelliert das Auto auf seine eigene Weise. Im Extremfall haben diese Modelle nur noch die VIN gemeinsam. So werden Vertrieb und Produktion von einem Auto teils erheblich unterschiedliche Vorstellungen haben.
 

OnDemand

Top Contributor
Umfangreich im Sinne von viel. 500.000 Datensätze prüfen Hersteller, daher jeder Hersteller ein eigener Service.

Ich habe nun erstmal jedem Herstellerservice seine eigene Verbindung zur DB erstellt, somit entfällt der Datenbankservice, welcher mit CRUD völlig zugeballert wurde. Jeder Hersteller-Service verwaltet nun seine Fahrzeuge selber. So das passt, damit komme ich denke am besten. Zwar hab ich jetzt nach wie vor meine jar welche immer das aktuelle "Auto" hat aber es funktioniert. Wenn ich nun Änderungen am "Auto" mache, können alle Hersteller-Services dieses Attribut nutzen
 

mihe7

Top Contributor
daher jeder Hersteller ein eigener Service.
Das ist evtl. ein Grund für jeweils eine eigene Instanz eines Services aber nicht für jeweils eigene Services. Siehe dazu den letzten Abschnitt des Posts von @httpdigest.

Ich habe nun erstmal jedem Herstellerservice seine eigene Verbindung zur DB erstellt, somit entfällt der Datenbankservice, welcher mit CRUD völlig zugeballert wurde.
Why not? Die DB ist auch nur ein Service :)
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
D Spring Boot und Microservices Frameworks - Spring, Play, Blade, Vaadin & Co 1
R Spring Boot Test Assertions mit Objekten Frameworks - Spring, Play, Blade, Vaadin & Co 6
8u3631984 Pfad zu Test Datei in application.yml in Spring Boot Test Frameworks - Spring, Play, Blade, Vaadin & Co 7
R Spring Boot sql Beziehungen Frameworks - Spring, Play, Blade, Vaadin & Co 12
M Spring Boot 3 Datenbanken zur Laufzeit Verbinden Frameworks - Spring, Play, Blade, Vaadin & Co 5
ExceptionOfExpectation In Meiner Spring-Boot Applikation verlangt die Datenbank Wert für eine ID Frameworks - Spring, Play, Blade, Vaadin & Co 5
H Spring Boot Applikation und JHM Benchmark sowie ContextConfiguration in H2 Tests ich bekomme es nicht hin Frameworks - Spring, Play, Blade, Vaadin & Co 2
ExceptionOfExpectation Tests in Spring-Boot Frameworks - Spring, Play, Blade, Vaadin & Co 4
Avalon Get Request doppelt abfeuern ohne Post Redirect Get Pattern. Spring Boot Thymeleaf MVC Frameworks - Spring, Play, Blade, Vaadin & Co 12
thor_norsk Konfigurationsprobleme mit Spring Boot Frameworks - Spring, Play, Blade, Vaadin & Co 9
R Spring Boot Integration-testing mit Keycloak Frameworks - Spring, Play, Blade, Vaadin & Co 1
R Spring Boot Integration-testing mit Keycloak Frameworks - Spring, Play, Blade, Vaadin & Co 13
thor_norsk Spring Boot Fehler Frameworks - Spring, Play, Blade, Vaadin & Co 1
thor_norsk Spring Boot und Docker Frameworks - Spring, Play, Blade, Vaadin & Co 5
D Spring Boot Test ob Validation geprüft wurde Frameworks - Spring, Play, Blade, Vaadin & Co 8
K Spring Boot OneToMany Frameworks - Spring, Play, Blade, Vaadin & Co 6
8u3631984 Spring Boot Docker Image erstellen und mit docker-compose konfigurieren Frameworks - Spring, Play, Blade, Vaadin & Co 1
gradlew.bat spring-boot:run funktioniert nicht Frameworks - Spring, Play, Blade, Vaadin & Co 4
Zrebna Spring Boot/Thymeleaf: Bestätigungsemail senden. Frameworks - Spring, Play, Blade, Vaadin & Co 2
B Spring Boot und JPA Error creating bean Frameworks - Spring, Play, Blade, Vaadin & Co 24
R Spring Boot: Warum soll PasswordEncoder in einer neuen Methode definiert sein? Frameworks - Spring, Play, Blade, Vaadin & Co 1
M Spring Boot additional Datasource for a single entity Frameworks - Spring, Play, Blade, Vaadin & Co 0
Avalon Wie sieht bei Euch das Deployment einer Spring Boot Anwendung aus? Frameworks - Spring, Play, Blade, Vaadin & Co 4
M Threads in Spring Boot Frameworks - Spring, Play, Blade, Vaadin & Co 7
W DI-Problem in Spring Boot Frameworks - Spring, Play, Blade, Vaadin & Co 4
T Spring Boot: Was bewirkt parent in maven genau? Frameworks - Spring, Play, Blade, Vaadin & Co 4
OnDemand Vaadin+Spring Boot erster Seitenload nach Neustart endlos Frameworks - Spring, Play, Blade, Vaadin & Co 0
doncarlito87 Wie erhalte ich ein JSON aus eine NativeQuery (Spring Boot)? Frameworks - Spring, Play, Blade, Vaadin & Co 8
Avalon @Query Select Abfrage liefert falsche Werte (Spring Boot, JPA, Hibernate) Frameworks - Spring, Play, Blade, Vaadin & Co 3
Avalon Erstellung Dockerimage mit spring-boot:build-image in Spring Boot mit Umgebungsvariablen Frameworks - Spring, Play, Blade, Vaadin & Co 0
D Spring Boot Field Injection in MapStruct Frameworks - Spring, Play, Blade, Vaadin & Co 5
OnDemand Spring Boot seltsame Logeinträge: Manipulationsversuche? Frameworks - Spring, Play, Blade, Vaadin & Co 2
D Spring Boot Mile Stone und Snapshot Versionen Frameworks - Spring, Play, Blade, Vaadin & Co 2
OnDemand Spring Boot Exception Body Frameworks - Spring, Play, Blade, Vaadin & Co 2
N Spring Boot - Overkill für private Projekte? Frameworks - Spring, Play, Blade, Vaadin & Co 3
K Migration eines internen Frameworks zu Spring:Boot Frameworks - Spring, Play, Blade, Vaadin & Co 0
Z Hibernate & Postgres in Spring Boot (Syntaxprobleme) Frameworks - Spring, Play, Blade, Vaadin & Co 2
Z Spring Boot mit JPA;, Hibernate, Rest & Lombok Frameworks - Spring, Play, Blade, Vaadin & Co 8
OnDemand Spring Security/Boot/Vaadin Cookie Problem bei iFrame Frameworks - Spring, Play, Blade, Vaadin & Co 4
OnDemand Spring Boot: Feld ignorieren Frameworks - Spring, Play, Blade, Vaadin & Co 3
N Buch zum Spring Framework bzw. Spring Boot Frameworks - Spring, Play, Blade, Vaadin & Co 3
OnDemand Jasypt Spring Boot HIbernate wie komme ich an den Key? Frameworks - Spring, Play, Blade, Vaadin & Co 4
8u3631984 Spring Boot im Docker Container - Logback wird nicht verwendet Frameworks - Spring, Play, Blade, Vaadin & Co 13
sascha-sphw Spring Boot Resource Server (OAuth2) @MockMvc Frameworks - Spring, Play, Blade, Vaadin & Co 5
OnDemand Spring Boot CDN Frameworks - Spring, Play, Blade, Vaadin & Co 1
OnDemand Spring Boot Deserialiserung mit JSON Frameworks - Spring, Play, Blade, Vaadin & Co 9
OnDemand Spring Boot POST zu PHP API Frameworks - Spring, Play, Blade, Vaadin & Co 12
OnDemand Spring Boot WebClient ErrorHandling Frameworks - Spring, Play, Blade, Vaadin & Co 5
8u3631984 Spring boot : Unique Constraint mit Many to Many Frameworks - Spring, Play, Blade, Vaadin & Co 2
OnDemand Spring Boot Repository null Frameworks - Spring, Play, Blade, Vaadin & Co 1
OnDemand Spring Boot Limits API calls Frameworks - Spring, Play, Blade, Vaadin & Co 20
J Spring boot mit Keyclaok rollen basiert Frameworks - Spring, Play, Blade, Vaadin & Co 2
OnDemand Spring Boot Scheduler flexibel machen Frameworks - Spring, Play, Blade, Vaadin & Co 4
OnDemand Spring Boot + Vaadin API Security Frameworks - Spring, Play, Blade, Vaadin & Co 1
S Spring Boot und seine Module verstehen Frameworks - Spring, Play, Blade, Vaadin & Co 3
R Architektur für Spring Boot Projekt Frameworks - Spring, Play, Blade, Vaadin & Co 5
M Spring Boot, Versionskontrolle und Entwicklungsumgebung und Deployment Frameworks - Spring, Play, Blade, Vaadin & Co 2
Avalon Image aus JSON Objekt im Browser anzeigen (BLOB, extrahieren, konvertieren) Spring Boot Frameworks - Spring, Play, Blade, Vaadin & Co 4
Avalon CSS Datei wird in Spring Boot mit Thymeleaf im Standardordner nicht gefunden Frameworks - Spring, Play, Blade, Vaadin & Co 3
OnDemand Spring Boot Mapping null bei GET Aufruf Frameworks - Spring, Play, Blade, Vaadin & Co 8
OnDemand Spring Boot Test mit Junit Frameworks - Spring, Play, Blade, Vaadin & Co 8
J Spring Boot - Reactor Frameworks - Spring, Play, Blade, Vaadin & Co 1
L Spring Boot, H2 und Restschnittstelle synchonisation mit Client Frameworks - Spring, Play, Blade, Vaadin & Co 10
TonioTec Spring Boot Datenbankabfrage Frameworks - Spring, Play, Blade, Vaadin & Co 7
OnDemand Spring Boot encoding Slash in URL Parameter Frameworks - Spring, Play, Blade, Vaadin & Co 7
S Spring Boot startet nicht Frameworks - Spring, Play, Blade, Vaadin & Co 3
S Spring Boot -> War File | 404 in Tomcat Frameworks - Spring, Play, Blade, Vaadin & Co 20
LimDul Spring Boot Anwendung "automatisch" neustarten Frameworks - Spring, Play, Blade, Vaadin & Co 3
A Spring boot Frameworks - Spring, Play, Blade, Vaadin & Co 18
bueseb84 Unit Test mit Spring Boot - Service Autowired Frameworks - Spring, Play, Blade, Vaadin & Co 5
OnDemand DTO <> Entity Hibernate Spring Boot Frameworks - Spring, Play, Blade, Vaadin & Co 28
OnDemand Verständnisfrage DTO Spring Boot Frameworks - Spring, Play, Blade, Vaadin & Co 19
OnDemand Spring Boot Load Balancing Frameworks - Spring, Play, Blade, Vaadin & Co 5
S Spring Boot Frameworks - Spring, Play, Blade, Vaadin & Co 1
OnDemand Spring Boot Threads Frameworks - Spring, Play, Blade, Vaadin & Co 6
S Spring Boot: Wert aus Config Datei ermitteln Frameworks - Spring, Play, Blade, Vaadin & Co 3
S Spring Boot: Ein geschütztes Verzeichnis Frameworks - Spring, Play, Blade, Vaadin & Co 1
bueseb84 Probleme mit Spring Boot Docker und Bootstrap Frameworks - Spring, Play, Blade, Vaadin & Co 9
OnDemand Spring Boot Eureka/Zuul Frameworks - Spring, Play, Blade, Vaadin & Co 0
F Redirect in einer Spring Boot WebApplication Frameworks - Spring, Play, Blade, Vaadin & Co 7
B Erstes Spring Boot Projekt: Gameserver-Manager Frameworks - Spring, Play, Blade, Vaadin & Co 5
V Spring Boot, thymeleaf, Eingaben cashen oder per session speichern? Frameworks - Spring, Play, Blade, Vaadin & Co 2
S Spring Boot Security Frameworks - Spring, Play, Blade, Vaadin & Co 3
S Spring Boot i18n Frameworks - Spring, Play, Blade, Vaadin & Co 28
bueseb84 Spring Boot : Update H2 Repository Frameworks - Spring, Play, Blade, Vaadin & Co 14
A Spring Boot/ OneToMany Relation Frameworks - Spring, Play, Blade, Vaadin & Co 29
S Spring Boot testen mit Service Klassen Frameworks - Spring, Play, Blade, Vaadin & Co 4
L Controller Spring Boot mit Java Frameworks - Spring, Play, Blade, Vaadin & Co 20
J Spring Boot H2 Datbase Frameworks - Spring, Play, Blade, Vaadin & Co 2
J Spring Boot Thymleaf mit Java.Optional Frameworks - Spring, Play, Blade, Vaadin & Co 0
L JavaFX Anwendung mit Spring Boot und mehrere FXML Forms Frameworks - Spring, Play, Blade, Vaadin & Co 5
P Mit Maven (und Spring-boot) ein FatJAR und ein EAR bauen Frameworks - Spring, Play, Blade, Vaadin & Co 3
OnDemand Spring Boot Basic Authentication langsam Frameworks - Spring, Play, Blade, Vaadin & Co 2
OnDemand Start Stop Spring Boot Frameworks - Spring, Play, Blade, Vaadin & Co 4
H Spring Boot - Dependency Injection Frameworks - Spring, Play, Blade, Vaadin & Co 26
B Java Spring Boot - POM-Problem Frameworks - Spring, Play, Blade, Vaadin & Co 8
OnDemand Spring Boot parallele Requests Frameworks - Spring, Play, Blade, Vaadin & Co 1
OnDemand Spring Boot Resttemplate exchange XML Frameworks - Spring, Play, Blade, Vaadin & Co 6
S Root-Pfad zu meiner Spring Boot Application Frameworks - Spring, Play, Blade, Vaadin & Co 3
OnDemand Spring Boot Error Logging Frameworks - Spring, Play, Blade, Vaadin & Co 5

Ähnliche Java Themen

Neue Themen


Oben