स्प्रिंग बूट - हिस्ट्रिक्स

हिस्टिक्स नेटफ्लिक्स से लाइब्रेरी है। हिस्टिक्स सेवाओं के बीच पहुंच के बिंदुओं को अलग करता है, उन पर कैस्केडिंग विफलताओं को रोकता है और फ़ॉलबैक विकल्प प्रदान करता है।

उदाहरण के लिए, जब आप 3 rd पार्टी एप्लिकेशन को कॉल कर रहे हैं , तो प्रतिक्रिया भेजने में अधिक समय लगता है। तो उस समय, नियंत्रण फ़ॉलबैक विधि पर जाता है और आपके आवेदन पर कस्टम प्रतिक्रिया देता है।

इस अध्याय में आप यह देखने जा रहे हैं कि स्प्रिंग बूट एप्लिकेशन में हिस्टिक्स को कैसे लागू किया जाए।

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

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

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

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

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

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

मुख्य स्प्रिंग बूट एप्लीकेशन क्लास फाइल कोड नीचे दिया गया है -

package com.tutorialspoint.hystrixapp;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.hystrix.EnableHystrix;

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

अब एक साधारण रेस्ट कंट्रोलर लिखें, जो अनुरोध किए गए समय से 3 सेकंड के बाद स्ट्रिंग लौटाता है।

@RequestMapping(value = "/")
public String hello() throws InterruptedException {
   Thread.sleep(3000);
   return "Welcome Hystrix";
}

अब, रेस्ट API के लिए @Hystrix कमांड और @HystrixProperty जोड़ें और मिलीसेकंड मान में टाइमआउट को परिभाषित करें।

@HystrixCommand(fallbackMethod = "fallback_hello", commandProperties = {
   @HystrixProperty(name = "execution.isolation.thread.timeoutInMilliseconds", value = "1000")
})

अगला, यदि अनुरोध का जवाब देने में लंबा समय लगता है, तो फॉलबैक विधि fallback_hello () को परिभाषित करें।

private String fallback_hello() {
   return "Request fails. It takes long time to response";
}

बाकी रेस्ट कंट्रोलर क्लास फाइल जिसमें REST API और Hystrix प्रॉपर्टीज शामिल हैं, को यहाँ दिखाया गया है -

@RequestMapping(value = "/")
@HystrixCommand(fallbackMethod = "fallback_hello", commandProperties = {
   @HystrixProperty(name = "execution.isolation.thread.timeoutInMilliseconds", value = "1000")
})
public String hello() throws InterruptedException {
   Thread.sleep(3000);
   return "Welcome Hystrix";
}
private String fallback_hello() {
   return "Request fails. It takes long time to response";
}

इस उदाहरण में, REST API मुख्य स्प्रिंग बूट एप्लीकेशन क्लास फाइल में ही लिखा गया है।

package com.tutorialspoint.hystrixapp;

import org.springframework.boot.SpringApplication;
import com.netflix.hystrix.contrib.javanica.annotation.HystrixProperty;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.hystrix.EnableHystrix;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import com.netflix.hystrix.contrib.javanica.annotation.HystrixCommand;

@SpringBootApplication
@EnableHystrix
@RestController
public class HystrixappApplication {
   public static void main(String[] args) {
      SpringApplication.run(HystrixappApplication.class, args);
   }
   @RequestMapping(value = "/")
   @HystrixCommand(fallbackMethod = "fallback_hello", commandProperties = {
      @HystrixProperty(name = "execution.isolation.thread.timeoutInMilliseconds", value = "1000")
   })
   public String hello() throws InterruptedException {
      Thread.sleep(3000);
      return "Welcome Hystrix";
   }
   private String fallback_hello() {
      return "Request fails. It takes long time to response";
   }
}

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

Maven – pom.xml file

<?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>hystrixapp</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>
   <name>hystrixapp</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-hystrix</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-hystrix')
   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>

यह नीचे दिखाए गए अनुसार टॉमकैट पोर्ट 8080 पर आवेदन शुरू करेगा -

अब, URL को हिट करें http://localhost:8080/अपने वेब ब्राउज़र से, और हिस्ट्रिक्स प्रतिक्रिया देखें। API को प्रतिक्रिया देने में 3 सेकंड का समय लगता है, लेकिन Hystrix मध्यांतर 1 सेकंड है।