स्प्रिंग बूट - माइक्रो सर्विस लॉग्स का पता लगाना

किसी भी समस्या के होने पर, अधिकांश डेवलपर्स लॉग को ट्रेस करने में कठिनाई का सामना करते हैं। इसे स्प्रिंग क्लाउड स्लीथ और जिपकिन सर्वर द्वारा स्प्रिंग बूट एप्लिकेशन के लिए हल किया जा सकता है।

स्प्रिंग क्लाउड स्लीथ

स्प्रिंग क्लाउड स्लीथ लॉग निम्न प्रारूप में छपे हैं -

[application-name,traceid,spanid,zipkin-export]

कहाँ पे,

  • आवेदन-नाम = आवेदन का नाम

  • ट्रेसिड = प्रत्येक अनुरोध और प्रतिक्रिया ट्रेसिड एक ही सेवा या एक सेवा से दूसरी सेवा पर कॉल करते समय समान होती है।

  • स्पैनिड = स्पैन आईडी ट्रेस आईडी के साथ मुद्रित की जाती है। स्पैन आईडी हर अनुरोध और प्रतिक्रिया को एक सेवा से दूसरे सेवा पर कॉल करने के लिए अलग है।

  • जिपकिन-एक्सपोर्ट = डिफ़ॉल्ट रूप से यह गलत है। यदि यह सही है, तो लॉग को जिपकिन सर्वर पर निर्यात किया जाएगा।

अब, अपनी बिल्ड कॉन्फ़िगरेशन फ़ाइल में स्प्रिंग क्लाउड स्टार्टर स्लीथ डिपेंडेंसी को इस प्रकार जोड़ें -

Maven उपयोगकर्ता आपकी pom.xml फ़ाइल में निम्न निर्भरता जोड़ सकते हैं -

<dependency>
   <groupId>org.springframework.cloud</groupId>
   <artifactId>spring-cloud-starter-sleuth</artifactId>
</dependency>

ग्रेडल उपयोगकर्ता आपकी बिल्ड.gradle फ़ाइल में निम्न निर्भरता जोड़ सकते हैं -

compile('org.springframework.cloud:spring-cloud-starter-sleuth')

अब, अपने स्प्रिंग बूट एप्लिकेशन में लॉग्स जोड़ें, जैसा कि यहां दिखाया गया है

package com.tutorialspoint.sleuthapp;

import java.util.logging.Level;
import java.util.logging.Logger;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@SpringBootApplication
@RestController
public class SleuthappApplication {
   private static final Logger LOG = Logger.getLogger(SleuthappApplication.class.getName());
   public static void main(String[] args) {
      SpringApplication.run(SleuthappApplication.class, args);
   }
   @RequestMapping("/")
   public String index() {
      LOG.log(Level.INFO, "Index API is calling");
      return "Welcome Sleuth!";
   }
}

अब, आवेदन का नाम आवेदन में जोड़ें।

spring.application.name = tracinglogs

बिल्ड कॉन्फ़िगरेशन फ़ाइल के लिए पूरा कोड नीचे दिया गया है -

Maven – pom.xml

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>sleuthapp</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>

   <name>sleuthapp</name>
   <description>Demo project for Spring Boot</description>

   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.9.RELEASE</version>
      <relativePath/> <!-- lookup parent from repository -->
   </parent>

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
      <spring-cloud.version>Edgware.RELEASE</spring-cloud.version>
   </properties>

   <dependencies>
      <dependency>
         <groupId>org.springframework.cloud</groupId>
         <artifactId>spring-cloud-starter-sleuth</artifactId>
      </dependency>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-web</artifactId>
      </dependency>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>
   </dependencies>

   <dependencyManagement>
      <dependencies>
         <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-dependencies</artifactId>
            <version>${spring-cloud.version}</version>
            <type>pom</type>
            <scope>import</scope>
         </dependency>
      </dependencies>
   </dependencyManagement>

   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
   
</project>

Gradle – build.gradle

buildscript {
   ext {
      springBootVersion = '1.5.9.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}

apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'

group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8

repositories {
   mavenCentral()
}
ext {
   springCloudVersion = 'Edgware.RELEASE'
}
dependencies {
   compile('org.springframework.cloud:spring-cloud-starter-sleuth')
   compile('org.springframework.boot:spring-boot-starter-web')
   testCompile('org.springframework.boot:spring-boot-starter-test')
}
dependencyManagement {
   imports {
      mavenBom "org.springframework.cloud:spring-cloud-dependencies:${springCloudVersion}"
   }
}

आप एक निष्पादन योग्य JAR फ़ाइल बना सकते हैं, और निम्न Maven या Gradle कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं।

मावेन के लिए, आप निम्नलिखित कमांड का उपयोग कर सकते हैं -

mvn clean install

"बिल्ड सफलता" के बाद, आप लक्ष्य निर्देशिका के तहत जार फ़ाइल पा सकते हैं।

ग्रेडल के लिए, आप निम्न कमांड का उपयोग कर सकते हैं -

gradle clean build

“BUILD SUCCESSFUL” के बाद, आप JAR फाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

अब, यहाँ दिखाए गए कमांड का उपयोग करके JAR फ़ाइल चलाएँ -

java –jar <JARFILE>

अब, Tomcat पोर्ट 8080 पर आवेदन शुरू हो गया है।

अब, अपने वेब ब्राउज़र में URL को हिट करें और कंसोल लॉग में आउटपुट देखें।

http://localhost:8080/

कंसोल विंडो में आप निम्न लॉग देख सकते हैं। उस प्रारूप का निरीक्षण करें जिसे निम्नलिखित प्रारूप में मुद्रित किया गया है [आवेदन-नाम, ट्रेसिड, स्पिडिड, जिपकिन-एक्सपोर्ट]

जिपक सर्वर

जिपकिन एक ऐसा एप्लिकेशन है जो आपके स्प्रिंग बूट एप्लिकेशन के स्प्रिंग क्लाउड स्लीथ लॉग की निगरानी और प्रबंधन करता है। ज़िपकिन सर्वर बनाने के लिए, हमें अपनी बिल्ड कॉन्फ़िगरेशन फ़ाइल में जिपकिन यूआई और जिपकिन सर्वर निर्भरता जोड़ने की आवश्यकता है।

Maven उपयोगकर्ता आपकी pom.xml फ़ाइल में निम्न निर्भरता जोड़ सकते हैं -

<dependency>
   <groupId>io.zipkin.java</groupId>
   <artifactId>zipkin-server</artifactId>
</dependency>
<dependency>
   <groupId>io.zipkin.java</groupId>
   <artifactId>zipkin-autoconfigure-ui</artifactId>
</dependency>

ग्रेडल उपयोगकर्ता आपकी बिल्ड.gradle फ़ाइल में नीचे की निर्भरता जोड़ सकते हैं -

compile('io.zipkin.java:zipkin-autoconfigure-ui')
compile('io.zipkin.java:zipkin-server')

अब, अनुप्रयोग गुण फ़ाइल में server.port = 9411 कॉन्फ़िगर करें।

गुण फ़ाइल उपयोगकर्ताओं के लिए, नीचे दी गई संपत्ति को application.properties फ़ाइल में जोड़ें।

server.port = 9411

YAML उपयोगकर्ताओं के लिए, application.yml फ़ाइल में निम्न गुण जोड़ें।

server:
   port: 9411

अपने मुख्य स्प्रिंग बूट एप्लिकेशन क्लास फ़ी में @EnableZipkinServer एनोटेशन जोड़ें। @EnableZipkinServer एनोटेशन का उपयोग आपके एप्लिकेशन एक्ट को जिपकिन सर्वर के रूप में सक्षम करने के लिए किया जाता है।

package com.tutorialspoint.zipkinapp;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import zipkin.server.EnableZipkinServer;

@SpringBootApplication
@EnableZipkinServer
public class ZipkinappApplication {
   public static void main(String[] args) {
      SpringApplication.run(ZipkinappApplication.class, args);
   }
}

पूर्ण बिल्ड कॉन्फ़िगरेशन फ़ाइल के लिए कोड नीचे दिया गया है।

Maven – pom.xml

<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.tutorialspoint</groupId>
   <artifactId>zipkinapp</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>
   <name>zipkinapp</name>
   <description>Demo project for Spring Boot</description>

   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>1.5.9.RELEASE</version>
      <relativePath /> <!-- lookup parent from repository -->
   </parent>

   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
      <java.version>1.8</java.version>
      <spring-cloud.version>Edgware.RELEASE</spring-cloud.version>
   </properties>

   <dependencies>
      <dependency>
         <groupId>io.zipkin.java</groupId>
         <artifactId>zipkin-server</artifactId>
      </dependency>
      <dependency>
         <groupId>io.zipkin.java</groupId>
         <artifactId>zipkin-autoconfigure-ui</artifactId>
      </dependency>
      <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
      </dependency>
   </dependencies>

   <dependencyManagement>
      <dependencies>
         <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-dependencies</artifactId>
            <version>${spring-cloud.version}</version>
            <type>pom</type>
            <scope>import</scope>
         </dependency>
      </dependencies>
   </dependencyManagement>

   <build>
      <plugins>
         <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
      </plugins>
   </build>
   
</project>

Gradle – build.gradle

buildscript {
   ext {
      springBootVersion = '1.5.9.RELEASE'
   }
   repositories {
      mavenCentral()
   }
   dependencies {
      classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
   }
}
apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'

group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8

repositories {
   mavenCentral()
}
ext {
   springCloudVersion = 'Edgware.RELEASE'
}
dependencies {
   compile('io.zipkin.java:zipkin-autoconfigure-ui')
   compile('io.zipkin.java:zipkin-server')
   testCompile('org.springframework.boot:spring-boot-starter-test')
}
dependencyManagement {
   imports {
      mavenBom "org.springframework.cloud:spring-cloud-dependencies:${springCloudVersion}"
   }
}

आप एक निष्पादन योग्य JAR फ़ाइल बना सकते हैं, और नीचे मावेन या ग्रैडल कमांड का उपयोग करके स्प्रिंग बूट एप्लिकेशन चला सकते हैं -

मावेन के लिए, नीचे दिए गए आदेश का उपयोग करें -

mvn clean install

"बिल्ड सफलता" के बाद, आप लक्ष्य निर्देशिका के तहत जार फ़ाइल पा सकते हैं।

ग्रेडल के लिए, नीचे दिए गए कमांड का उपयोग करें -

gradle clean build

“BUILD SUCCESSFUL” के बाद, आप JAR फाइल को बिल्ड / लिबास डायरेक्टरी के तहत पा सकते हैं।

दिखाए गए कमांड का उपयोग करके JAR फ़ाइल चलाएँ -

java –jar <JARFILE>

अब, आवेदन नीचे दिखाए गए अनुसार Tomcat पोर्ट 9411 पर शुरू हो गया है -

अब, नीचे दिए गए URL को हिट करें और Zipkin सर्वर UI देखें।

http://localhost:9411/zipkin/

उसके बाद, अपने क्लाइंट सेवा एप्लिकेशन में निम्न निर्भरता जोड़ें और ज़िपकिन यूआई के माध्यम से माइक्रो सर्विस लॉग का पता लगाने के लिए ज़िपकिन सर्वर URL को इंगित करें।

अब, अपनी क्लाउड कॉन्फ़िगरेशन फ़ाइल में स्प्रिंग क्लाउड स्टार्टर जिपक निर्भरता जोड़ें जैसा कि दिखाया गया है -

Maven उपयोगकर्ता pom.xml फ़ाइल में निम्न निर्भरता जोड़ सकते हैं -

<dependency>
   <groupId>org.springframework.cloud</groupId>
   <artifactId>spring-cloud-sleuth-zipkin</artifactId>
</dependency>

Gradle उपयोगकर्ता build.gradle फ़ाइल में निम्न निर्भरता जोड़ सकते हैं -

compile('org.springframework.cloud:spring-cloud-sleuth-zipkin')

अब, जोड़ें Always Sampler Bean ज़िपक सर्वर में लॉग निर्यात करने के लिए अपने स्प्रिंग बूट आवेदन में।

@Bean
public AlwaysSampler defaultSampler() {
   return new AlwaysSampler();
}

यदि आप ऑलवेजस्मैपर बीन को जोड़ते हैं, तो स्वचालित रूप से स्प्रिंग स्लीथ जिपकिन एक्सपोर्ट विकल्प झूठे से सच में बदल जाएगा।

इसके बाद, क्लाइंट सेवा application.properties फ़ाइल में अपने जिप्किन सर्वर बेस URL को कॉन्फ़िगर करें।

spring.zipkin.baseUrl = http://localhost:9411/zipkin/

फिर, ट्रेस आईडी प्रदान करें और ज़िपकिन यूआई में निशान ढूंढें।

http://localhost:9411/zipkin/traces/{traceid}/