Microservice-Architektur - praktische SOA
In diesem Kapitel werden wir eine CRUD-basierte Anwendung mit SOA-Architektur entwickeln. Später in den folgenden Kapiteln werden wir diesen Service in Microservice aufteilen und den grundlegenden Unterschied zwischen SOA- und Microservice-Architektur kennenlernen.
Systemkonfiguration und -einrichtung
In diesem Abschnitt erstellen wir eine CRUD-Beispielanwendung, die bei jedem Aufruf unseres Dienstes ein JSON-Objekt als Antwort zurückgibt. Wir werden das Jersey-Framework verwenden, um dasselbe zu entwickeln. Im Folgenden finden Sie die Schritte zum Einrichten Ihrer lokalen Systemumgebung.
Entwicklung einer CRUD-Anwendung
Step 1- Wir werden NetBeans als Entwicklungs-IDE verwenden. Bitte laden Sie die neueste Version herunter und installieren Sie sie auf der offiziellen NetBeans-Websitehttps://netbeans.org/downloads/.
Step 2- Öffnen Sie Ihre NetBeans-IDE. Gehen Sie zu "Datei -> Neues Projekt". Der folgende Screenshot wird angezeigt. Wählen Sie "Maven" als Kategorie und wählen Sie "Projekt von ArchType" als Projekt und klicken Sie auf "Weiter".
Dadurch werden alle erforderlichen JAR-Dateien heruntergeladen, um Ihr erstes Maven-Projekt und Ihren ersten RESTful-Webdienst zu erstellen.
Step 3- Wenn Sie im vorherigen Schritt auf die Schaltfläche Weiter klicken, wird der folgende Screenshot angezeigt. Hier müssen Sie den Maven-Archetyp angeben.
Suchen Sie im Suchfeld nach "Jersey-archType-Webapp (2.16)" und aktivieren Sie das Kontrollkästchen "Älter anzeigen".
Step 4- Sobald Sie dasselbe ausgewählt haben, werden Sie zum folgenden Bildschirm weitergeleitet. Wählen Sie das bevorzugte Glas aus der Liste aus und klicken Sie auf Weiter, um fortzufahren.
Step 5- In diesem Schritt müssen Sie den Namen Ihres Projekts und seine Gruppen-ID sowie die Paketdetails angeben. Nachdem Sie alle diese Informationen eingegeben haben, klicken Sie auf Fertig stellen, um fortzufahren.
Step 6- Sie sind mit der Einrichtung Ihres Arbeitsbereichs fertig. Das Projektverzeichnis sieht folgendermaßen aus.
Überprüfen Sie Ihren Ordner "Abhängigkeiten" und Sie werden feststellen, dass Maven automatisch alle erforderlichen JAR-Dateien für dieses Projekt heruntergeladen hat.
Step 7- Ihr Arbeitsbereich ist eingerichtet und Sie können mit der Codierung beginnen. Erstellen Sie vier Klassen und Pakete, wie im folgenden Screenshot beschrieben. Sie können feststellen, dass MyResource.java bereits von Maven erstellt wurde, da Maven intelligent genug ist, um zu erkennen, dass Sie Ihren eigenen Webdienst erstellen werden.
Step 8 - Sobald wir mit dem obigen Schritt fertig sind, erstellen wir unsere POJO-Klasse UserProfile.java wie folgt.
package com.tutorialspoint.userprofile.Model;
import javax.xml.bind.annotation.XmlRootElement;
@XmlRootElement
public class UserProfile {
private long ProId;
private String FName;
private String LName;
private String Add;
public UserProfile(){}
public UserProfile(long Proid, String Fname, String Lname,String Add) {
this.ProId = Proid;
this.FName = Fname;
this.LName = Lname;
this.Add = Add;
}
public long getProId() {
return ProId;
}
public void setProId(long ProId) {
this.ProId = ProId;
}
public String getFName() {
return FName;
}
public void setFName(String FName) {
this.FName = FName;
}
public String getLName() {
return LName;
}
public void setLName(String LName) {
this.LName = LName;
}
public String getAdd() {
return Add;
}
public void setAdd(String Add) {
this.Add = Add;
}
}
Step 9- Jetzt erstellen wir unsere Datenbankklasse. Da dies Teil des Lernmaterials ist, werden wir keine Datenbank als Datenbank verwenden. Wir werden einen eingebauten Java-Speicher als temporären Speicher verwenden. Wie Sie im folgenden Code sehen können, verwenden wir MAP als Datenbank. Bei allen von uns ausgeführten Webdienstvorgängen werden wir an diesem in der Klasse definierten MAP arbeiten.
package com.tutorialspoint.userprofile.DAO;
import com.tutorialspoint.userprofile.Model.UserProfile;
import java.util.HashMap;
import java.util.Map;
public class DatabaseClass {
private static Map<Long,UserProfile> messages = new HashMap<Long,UserProfile>();
public static Map<Long,UserProfile> getUsers() {
return messages;
// Each time this method will return entire map as an instance of database
}
}
Step 10- Lassen Sie uns jetzt unsere Serviceklasse aufbauen. Kopieren Sie den folgenden Codesatz und fügen Sie ihn in die Klasse "ProfileService.java" ein. Dies ist die Klasse, in der wir alle unsere Webdienstmethoden deklarieren, die für die Außenwelt verfügbar gemacht werden sollen. Wir müssen eine Referenz unserer DatabaseClass erstellen, damit in dieser Klasse auf unsere temporäre Datenbank zugegriffen werden kann.
package com.tutorialspoint.userprofile.service;
import com.tutorialspoint.userprofile.DAO.DatabaseClass;
import com.tutorialspoint.userprofile.Model.UserProfile;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
public class ProfileService {
private Map<Long,UserProfile> Userprofiles = DatabaseClass.getUsers();
// Creating some predefine profile and populating the same in the map
public ProfileService() {
UserProfile m1 = new UserProfile(1L,"Tutorials1","Point1","TutorialsPoint.com");
UserProfile m2 = new UserProfile(2L,"Tutorials2","Point2","TutorialsPoint.com2");
UserProfile m3 = new UserProfile(3L,"Tutorials3","Point3","TutorialsPoint.com3");
UserProfile m4 = new UserProfile(4L,"Tutorials4","Point4","TutorialsPoint.com4");
Userprofiles.put(1L, m1);
Userprofiles.put(2L, m2);
Userprofiles.put(1L, m3);
Userprofiles.put(2L, m4);
}
//Method to fetch all profile
public List<UserProfile> getAllProfile() {
List<UserProfile> list = new ArrayList<UserProfile>(Userprofiles.values());
return list;
} // Method to fetch only one profile depending on the ID provided
public UserProfile getProfile(long id) {
return Userprofiles.get(id);
} //Method to add profile
public UserProfile addProfile(UserProfile UserProfile) {
UserProfile.setProId(Userprofiles.size()+1);
Userprofiles.put(UserProfile.getProId(), UserProfile);
return UserProfile;
} //method to update Profile
public UserProfile UpdateProfile(UserProfile UserProfile) {
if(UserProfile.getProId()<=0) {
return null;
} else {
Userprofiles.put(UserProfile.getProId(), UserProfile);
return UserProfile;
}
} //method to delete profile
public void RemoveProfile(long Id) {
Userprofiles.remove(Id);
}
}
Step 11 - In diesem Schritt erstellen wir unsere Ressourcenklasse, die mit der URL verknüpft wird, und der entsprechende Dienst wird aufgerufen.
package com.tutorialspoint.userprofile.Resource;
import com.tutorialspoint.userprofile.Model.UserProfile;
import com.tutorialspoint.userprofile.service.ProfileService;
import java.util.List;
import javax.ws.rs.Consumes;
import javax.ws.rs.DELETE;
import javax.ws.rs.GET;
import javax.ws.rs.POST;
import javax.ws.rs.PUT;
import javax.ws.rs.Path;
import javax.ws.rs.PathParam;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;
@Path("/Profile")
@Consumes(MediaType.APPLICATION_XML)
@Produces(MediaType.APPLICATION_XML)
public class ProfileResource {
ProfileService messageService = new ProfileService();
@GET
public List<UserProfile> getProfile() {
return messageService.getAllProfile();
}
@GET
@Path("/{ProID}")
public UserProfile getProfile(@PathParam("ProID")long Id) {
return messageService.getProfile(Id);
}
@POST
public UserProfile addProfile(UserProfile profile) {
return messageService.addProfile(profile);
}
@PUT
@Path("/{proID}")
public UserProfile UpdateProfile(@PathParam("proID")long Id,UserProfile UserProfile) {
UserProfile.setProId(Id);
return messageService.UpdateProfile(UserProfile);
}
@DELETE
@Path("/{ProID}")
public void deleteProfile(@PathParam("ProID")long Id) {
messageService.RemoveProfile(Id);
}
}
Step 12- Erstellen Sie das Projekt sauber und führen Sie es aus. Wenn alles gut geht, sollten Sie beim Zugriff die folgende Ausgabe im Browser erhaltenhttp://localhost:8080/UserProfile/webapi/Profile” URL.
Sie können sehen, dass verschiedene Einträge mithilfe der XML-Darstellung ausgefüllt werden.
Verschiedene Methoden können mit Postman getestet werden, indem die richtige Methoden-URL angewendet wird.
@GET method - Der folgende Screenshot zeigt, wie wir das gewünschte Ergebnis für die Abrufanforderung erhalten können, die alle Benutzerdetails zurückgibt.
@POST- Die folgende Anfrage kann verwendet werden, um unsere Post-Methode zu testen. Beachten Sie, wie die proId automatisch generiert wurde.
@PUT- Diese Methode aktualisiert die Einträge. Der folgende Screenshot zeigt, wie Jersey die proId von der Anforderungs-URL nimmt und dieselbe Benutzerprofilantwort aktualisiert.
Auf die gleiche Weise können Sie nach anderen Methoden suchen, die in Ihren Webdiensten verfügbar sind.
Im vorherigen Abschnitt haben wir einen Dienst entwickelt, der die CRUD-Funktionalität verfügbar macht. Wenn wir jetzt versuchen, diesen Service in unserer Anwendung zu implementieren, müssen wir einen Client für diese Anwendung erstellen und an unsere Anwendung anhängen. In diesem Kapitel erfahren Sie, wie Sie diese Funktionalität mithilfe des Konzepts von Microservice erstellen. Das Folgende ist eine schematische Darstellung unserer Anwendung, die mit den obigen Schritten erstellt wurde.
Der Schauspieler sollte der Einstiegspunkt unseres Dienstes sein. In diesem Fall übernimmt „ProfileResource.java“ die Verantwortung eines Akteurs. Diese Klasse ruft verschiedene Methoden auf, um verschiedene Vorgänge wie Hinzufügen, Aktualisieren und Löschen auszuführen.
Zerlegung der CRUD-Anwendung
Nach dem Hauptprinzip des Mikroservices müssen wir für jedes Modul nur eine Geschäftsaufgabe haben, daher sollte nicht ein Akteur für alle vier CRUD-Funktionen verantwortlich sein. Betrachten Sie das folgende Beispiel, in dem wir einige neue Rollen eingeführt haben, damit Ihnen konzeptionell klar wird, dass Microservice eine architektonische Darstellung von SOA ist.
"Hauptbenutzer" ist der Benutzer, der mit dem "Anwendungscontroller" kommuniziert, um seine Bedürfnisse zu erfüllen. "Application Controller" ist derjenige, der je nach Anforderung des Endbenutzers nur unterschiedliche "Resource Manager" aufruft. "Resource Manager" erledigt die Aufgabe, die erledigt werden muss. Lassen Sie uns einen kurzen Blick auf die verschiedenen Rollen der verschiedenen Einheiten der Anwendung werfen.
End User/Main Users - Anforderung einiger Ressourcen an Application Controller.
Application - Empfängt die Anfrage und leitet sie an einen bestimmten Ressourcenmanager weiter.
Resource Manager - Erledigt die eigentliche Aufgabe des Aktualisierens, Löschens und Hinzufügens von Benutzern.
Sehen Sie, wie sich die Gesamtverantwortung einer Klasse auf verschiedene andere Klassen verteilt.