स्प्रिंग बूट - ज़ूल प्रॉक्सी सर्वर और रूटिंग
ज़ूल सर्वर एक गेटवे एप्लिकेशन है जो सभी अनुरोधों को संभालता है और माइक्रोसर्विस एप्लिकेशन की डायनेमिक रूटिंग करता है। Zuul सर्वर को एज सर्वर के रूप में भी जाना जाता है।
उदाहरण के लिए, /api/user उपयोगकर्ता सेवा के लिए मैप किया गया है और / एपीआई / उत्पादों को उत्पाद सेवा के लिए मैप किया गया है और ज़ुअल सर्वर गतिशील रूप से संबंधित बैकएंड एप्लिकेशन के अनुरोधों को रूट करता है।
इस अध्याय में, हम विस्तार से देखने जा रहे हैं कि स्प्रिंग बूट में ज़ूल सर्वर सर्वर कैसे बनाया जाए।
Zuul सर्वर अनुप्रयोग बनाना
ज़ूल सर्वर को स्प्रिंग क्लाउड निर्भरता के साथ बंडल किया गया है। आप स्प्रिंग बूटर प्रोजेक्ट को स्प्रिंग इनिशिएटिव पेज से डाउनलोड कर सकते हैंhttps://start.spring.io/ और Zuul सर्वर निर्भरता चुनें।
अपने मुख्य स्प्रिंग बूट एप्लिकेशन पर @EnableZuulProxy एनोटेशन जोड़ें। @EnableZuulProxy एनोटेशन का उपयोग आपके स्प्रिंग बूट एप्लिकेशन को Zuul प्रॉक्सी सर्वर के रूप में कार्य करने के लिए किया जाता है।
package com.tutorialspoint.zuulserver;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.zuul.EnableZuulProxy;
@SpringBootApplication
@EnableZuulProxy
public class ZuulserverApplication {
public static void main(String[] args) {
SpringApplication.run(ZuulserverApplication.class, args);
}
}
आपको हमारी बिल्ड कॉन्फ़िगरेशन फ़ाइल में स्प्रिंग क्लाउड स्टार्टर ज़ूल निर्भरता को जोड़ना होगा।
मावेन उपयोगकर्ताओं को आपके ऊपर निम्नलिखित निर्भरता को जोड़ना होगा pom.xml फ़ाइल -
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-zuul</artifactId>
</dependency>
ग्रेडल उपयोगकर्ताओं के लिए, अपनी build.gradle फ़ाइल में नीचे की निर्भरता जोड़ें
compile('org.springframework.cloud:spring-cloud-starter-zuul')
ज़ूल राउटिंग के लिए, अपने एप्लिकेशन में निम्न गुण जोड़ें।
spring.application.name = zuulserver
zuul.routes.products.path = /api/demo/**
zuul.routes.products.url = http://localhost:8080/
server.port = 8111
इसका मतलब है कि http को कॉल करता है /api/demo/उत्पादों की सेवा के लिए भेज दिया। उदाहरण के लिए,/api/demo/products को अग्रेषित किया जाता है /products।
yaml फ़ाइल उपयोगकर्ता नीचे दिखाए गए application.yml फ़ाइल का उपयोग कर सकते हैं -
server:
port: 8111
spring:
application:
name: zuulserver
zuul:
routes:
products:
path: /api/demo/**
url: http://localhost:8080/
Note - http://localhost:8080/ आवेदन Zuul प्रॉक्सी के माध्यम से रूट करने से पहले ही चलना चाहिए।
पूर्ण बिल्ड कॉन्फ़िगरेशन फ़ाइल नीचे दी गई है।
मावेन उपयोगकर्ता नीचे दी गई 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>zuulserver</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>zuulserver</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-zuul</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>
ग्रेडल उपयोगकर्ता नीचे दी गई 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-zuul')
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 पोर्ट 8111 पर शुरू हो गया है।
अब, URL को हिट करें http://localhost:8111/api/demo/products आपके वेब ब्राउज़र में और आप का आउटपुट देख सकते हैं /products नीचे दिखाए गए अनुसार अंतिम बिंदु -