Microservice-Architektur - MSA zum Anfassen

In diesem Kapitel erstellen wir eine Microservice-Anwendung, die verschiedene verfügbare Services verwendet. Wir alle wissen, dass Microservice kein kostengünstiger Weg ist, um eine Anwendung zu erstellen, da jeder einzelne Service, den wir erstellen, von Natur aus vollständig gestapelt sein wird. Das Erstellen eines Mikrodienstes in der lokalen Umgebung würde eine High-End-Systemkonfiguration erfordern, da Sie vier Instanzen eines Servers benötigen, um weiter ausgeführt zu werden, damit er zu einem bestimmten Zeitpunkt verwendet werden kann. Um unseren ersten Microservice zu erstellen, werden wir einige der verfügbaren SOA-Endpunkte verwenden und diese in unserer Anwendung verwenden.

Systemkonfiguration und -einrichtung

Bereiten Sie Ihr System entsprechend vor, bevor Sie mit der Erstellungsphase fortfahren. Sie würden einige öffentliche Webdienste benötigen. Sie können leicht dafür googeln. Wenn Sie den SOAP-Webdienst nutzen möchten, erhalten Sie eine WSDL-Datei, und von dort aus müssen Sie den spezifischen Webdienst nutzen. Für den REST-Service benötigen Sie nur einen Link, um denselben zu nutzen. In diesem Beispiel blockieren Sie drei verschiedene Webdienste "SOAP", "REST" und "Custom" in einer Anwendung.

Anwendungsarchitektur

Sie erstellen eine Java-Anwendung mithilfe des Microservice-Implementierungsplans. Sie erstellen einen benutzerdefinierten Dienst und die Ausgabe dieses Dienstes dient als Eingabe für andere Dienste.

Im Folgenden finden Sie die Schritte zum Entwickeln einer Microservice-Anwendung.

Step 1: Client creation for SOAP service- Es gibt viele kostenlose Web-APIs, mit denen Sie einen Webdienst erlernen können. Verwenden Sie für dieses Tutorial den GeoIP-Dienst von „http://www.webservicex.net/.”Die WSDL-Datei finden Sie unter dem folgenden Link auf der Website „ webservicex.net. Um den Client aus dieser WSDL-Datei zu generieren, müssen Sie lediglich den folgenden Befehl in Ihrem Terminal ausführen.

wsimport http://www.webservicex.net/geoipservice.asmx?WSDL

Dieser Befehl generiert alle erforderlichen Client-Dateien in einem Ordner mit dem Namen "SEI", der nach der Service-Endpunkt-Schnittstelle benannt ist.

Step 2: Create your custom web service- Befolgen Sie den in diesem Tutorial bereits erwähnten Prozess und erstellen Sie eine Maven-basierte REST-API mit dem Namen „CustomRest“. Nach Abschluss finden Sie eine Klasse mit dem Namen "MyResource.java". Aktualisieren Sie diese Klasse mit dem folgenden Code.

package com.tutorialspoint.customrest;

import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;

@Path("myresource")
public class MyResource {
   @GET
   @Produces(MediaType.TEXT_PLAIN)
   
   public String getIt() {
      return "IND|INDIA|27.7.65.215";
   }
}

Wenn alles abgeschlossen ist, führen Sie diese Anwendung auf dem Server aus. Sie sollten die folgende Ausgabe im Browser erhalten.

Dies ist der Webserver, der nach dem Aufruf ein Zeichenfolgenobjekt zurückgibt. Dies ist der Eingabedienst, der Eingaben bereitstellt, die von anderen Anwendungen zum Generieren von Datensätzen verwendet werden können.

Step 3: Configure another Rest API- Verwenden Sie in diesem Schritt einen anderen Webdienst, der unter services.groupkt.com verfügbar ist. Dies gibt beim Aufrufen ein JSON-Objekt zurück.

Step 4: Create JAVA application - Erstellen Sie eine normale Java-Anwendung, indem Sie "Neues Projekt" -> "JAVA-Projekt" auswählen und auf "Fertig stellen" klicken (siehe folgenden Screenshot).

Step 5: Add the SOAP client- In Schritt 1 haben Sie die Client-Datei für den SOAP-Webdienst erstellt. Fügen Sie diese Client-Dateien Ihrem aktuellen Projekt hinzu. Nach dem erfolgreichen Hinzufügen der Client-Dateien sieht Ihr Anwendungsverzeichnis wie folgt aus.

Step 6: Create your main app- Erstellen Sie Ihre Hauptklasse, in der Sie alle diese drei Webdienste nutzen. Klicken Sie mit der rechten Maustaste auf das Quellprojekt und erstellen Sie eine neue Klasse mit dem Namen "MicroServiceInAction.java". Die nächste Aufgabe besteht darin, andere Webdienste als diese aufzurufen.

Step 7: Call your custom web service - Fügen Sie dazu die folgenden Codes hinzu, um den Aufruf Ihres eigenen Dienstes zu implementieren.

try {
   url = new URL("http://localhost:8080/CustomRest/webapi/myresource");
   conn = (HttpURLConnection) url.openConnection();
   conn.setRequestMethod("GET");
   conn.setRequestProperty("Accept", "application/json");
   
   if (conn.getResponseCode() != 200) {
      throw new RuntimeException("Failed : HTTP error code : " + conn.getResponseCode());
   }
   
   BufferedReader br = new BufferedReader(new InputStreamReader(
      (conn.getInputStream())));
   while ((output = br.readLine()) != null) {
      inputToOtherService = output;
   }
   conn.disconnect();

} catch (MalformedURLException e) {
   e.printStackTrace();
} catch (IOException e) {
   e.printStackTrace();
}

Step 8: Consume SOAP Services- Sie haben Ihre Client-Datei generiert, wissen aber nicht, welche Methode in diesem gesamten Paket aufgerufen werden soll? Dazu müssen Sie erneut auf die WSDL verweisen, mit der Sie Ihre Client-Dateien generiert haben. Jede WSDL-Datei sollte eine "wsdl: service" -Tag-Suche für dieses Tag haben. Es sollte Ihr Einstiegspunkt für diesen Webdienst sein. Im Folgenden finden Sie den Service-Endpunkt dieser Anwendung.

Jetzt müssen Sie diesen Dienst in Ihrer Anwendung implementieren. Im Folgenden finden Sie den Java-Code, den Sie zum Implementieren Ihres SOAP-Webdiensts benötigen.

GeoIPService newGeoIPService = new GeoIPService();
GeoIPServiceSoap newGeoIPServiceSoap = newGeoIPService.getGeoIPServiceSoap();
GeoIP newGeoIP = newGeoIPServiceSoap.getGeoIP(Ipaddress);  
// Ipaddress is output of our own web service.

System.out.println("Country Name from SOAP Webserivce ---"+newGeoIP.getCountryName());

Step 9: Consume REST web service- Zwei der Dienste wurden bisher in Anspruch genommen. In diesem Schritt wird mithilfe Ihres benutzerdefinierten Webdienstes ein anderer REST-Webdienst mit angepasster URL verwendet. Verwenden Sie dazu den folgenden Code.

String url1="http://services.groupkt.com/country/get/iso3code/";//customizing the Url
url1 = url1.concat(countryCode);

try {
   URL url = new URL(url1);
   HttpURLConnection conn = (HttpURLConnection) url.openConnection();
   conn.setRequestMethod("GET");
   conn.setRequestProperty("Accept", "application/json");
   
   if (conn.getResponseCode() != 200) {
      throw new RuntimeException("Failed : HTTP error code : " + conn.getResponseCode());
   }
   
   BufferedReader br = new BufferedReader(new InputStreamReader(
      (conn.getInputStream())));
   while ((output = br.readLine()) != null) {
      System.out.println(output);
   }
   conn.disconnect();

} catch (MalformedURLException e) {
   e.printStackTrace();
} catch (IOException e) {
   e.printStackTrace();
}

Step 10: Consume all services - Wenn Ihr Webdienst "CustomRest" ausgeführt wird und Sie mit dem Internet verbunden sind, sollte Ihre konsolidierte Hauptklasse folgen, wenn alles erfolgreich abgeschlossen wurde.

package microserviceinaction;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.StringTokenizer;

import net.webservicex.GeoIP;
import net.webservicex.GeoIPService;
import net.webservicex.GeoIPServiceSoap;

public class MicroServiceInAction {
   static URL url;
   static HttpURLConnection conn;
   static String output;
   static String inputToOtherService;
   static String countryCode;
   static String ipAddress;
   static String CountryName;
   public static void main(String[] args) {
      //consuming of your own web service
      try {
         url = new URL("http://localhost:8080/CustomRest/webapi/myresource");
         conn = (HttpURLConnection) url.openConnection();
         conn.setRequestMethod("GET");
         conn.setRequestProperty("Accept", "application/json");
         
         if (conn.getResponseCode() != 200) {
            throw new RuntimeException("Failed : HTTP error code : " + conn.getResponseCode());
         }
         
         BufferedReader br = new BufferedReader(new InputStreamReader(
            (conn.getInputStream())));
         while ((output = br.readLine()) != null) {
            inputToOtherService = output;
         }
         conn.disconnect();
      
      } catch (MalformedURLException e) {
         e.printStackTrace();
      } catch (IOException e) {
         e.printStackTrace();
      }
      
      //Fetching IP address from the String and other information
      StringTokenizer st = new StringTokenizer(inputToOtherService);
      countryCode = st.nextToken("|");
      CountryName = st.nextToken("|");
      ipAddress = st.nextToken("|");
      
      // Call to SOAP web service with output of your web service--- 
      // getting the location of our given IP address
      String Ipaddress = ipAddress;
      GeoIPService newGeoIPService = new GeoIPService();
      GeoIPServiceSoap newGeoIPServiceSoap = newGeoIPService.getGeoIPServiceSoap();
      GeoIP newGeoIP = newGeoIPServiceSoap.getGeoIP(Ipaddress);
      System.out.println("Country Name from SOAP Webservice ---"+newGeoIP.getCountryName());
      
      // Call to REST API --to get all the details of our country
      String url1 = "http://services.groupkt.com/country/get/iso3code/"; //customizing the Url
      url1 = url1.concat(countryCode);
      
      try {
         URL url = new URL(url1);
         HttpURLConnection conn = (HttpURLConnection) url.openConnection();
         conn.setRequestMethod("GET");
         conn.setRequestProperty("Accept", "application/json");
			
         if (conn.getResponseCode() != 200) {
            throw new RuntimeException("Failed : HTTP error code : " + conn.getResponseCode());
         }
      
         BufferedReader br = new BufferedReader(new InputStreamReader(
            (conn.getInputStream())));
         while ((output = br.readLine()) != null) {
            System.out.println(output);
         }
      
         conn.disconnect();
      } catch (MalformedURLException e) {
         e.printStackTrace();
      } catch (IOException e) {
         e.printStackTrace();
      }
   }
}

Sobald Sie diese Datei ausgeführt haben, wird die folgende Ausgabe in der Konsole angezeigt. Sie haben Ihre erste Microservice-Anwendung erfolgreich entwickelt.