स्प्रिंग बूट - Google क्लाउड प्लेटफ़ॉर्म
Google क्लाउड प्लेटफ़ॉर्म क्लाउड कंप्यूटिंग सेवाएँ प्रदान करता है जो क्लाउड वातावरण में स्प्रिंग बूट एप्लिकेशन चलाती हैं। इस अध्याय में, हम यह देखने जा रहे हैं कि जीसीपी ऐप इंजन प्लेटफॉर्म में स्प्रिंग बूट एप्लिकेशन को कैसे तैनात किया जाए।
सबसे पहले, ग्रैडल को स्प्रिंग इनिशिएटिव पेज www.start.spring.io से स्प्रिंग बूट एप्लिकेशन डाउनलोड करें । निम्नलिखित स्क्रीनशॉट को देखें।
अब, build.gradle फ़ाइल में, Google क्लाउड एपेंगिन प्लगइन और एपेंगाइन क्लासपाथ निर्भरता जोड़ें।
Build.gradle फ़ाइल का कोड नीचे दिया गया है -
buildscript {
ext {
springBootVersion = '1.5.9.RELEASE'
}
repositories {
mavenCentral()
}
dependencies {
classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
classpath 'com.google.cloud.tools:appengine-gradle-plugin:1.3.3'
}
}
apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'
apply plugin: 'com.google.cloud.tools.appengine'
group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8
repositories {
mavenCentral()
}
dependencies {
compile('org.springframework.boot:spring-boot-starter-web')
testCompile('org.springframework.boot:spring-boot-starter-test')
}
अब, एक सरल HTTP समापन बिंदु लिखें और यह स्ट्रिंग की सफलता को दिखाए गए अनुसार दिखाया गया है -
package com.tutorialspoint.appenginedemo;
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 AppengineDemoApplication {
public static void main(String[] args) {
SpringApplication.run(AppengineDemoApplication.class, args);
}
@RequestMapping(value = "/")
public String success() {
return "APP Engine deployment success";
}
}
अगला, src / main / appengine निर्देशिका के तहत app.yml फ़ाइल को दिखाए अनुसार जोड़ें -
runtime: java
env: flex
handlers:
- url: /.*
script: this field is required, but ignored
अब, Google क्लाउड कंसोल पर जाएं और पृष्ठ के शीर्ष पर सक्रिय Google क्लाउड शेल पर क्लिक करें।
अब, Google क्लाउड शेल का उपयोग करके अपनी स्रोत फ़ाइलों और ग्रेड फ़ाइल को अपनी Google क्लाउड मशीन की होम निर्देशिका में ले जाएं।
अब, कमांड ग्रेड एपेंगाइनडेप्ल को निष्पादित करें और यह आपके एप्लिकेशन को Google क्लाउड एपेंगाइन में तैनात करेगा।
Note - जीसीपी को बिलिंग सक्षम होना चाहिए और अपने आवेदन को एपेन्गाइन में तैनात करने से पहले, आपको जीसीपी में एपेंगाइन प्लेटफॉर्म बनाना चाहिए।
आपके एप्लिकेशन को GCP एपेंग्नेइन प्लेटफ़ॉर्म पर लागू करने में कुछ मिनट लगेंगे।
सफल बनाने के बाद आप कंसोल विंडो में सर्विस यूआरएल देख सकते हैं।
अब, सेवा URL को हिट करें और आउटपुट देखें।
Google क्लाउड एसक्यूएल
Google क्लाउड एसक्यूएल को अपने स्प्रिंग बूट एप्लिकेशन में जोड़ने के लिए, आपको अपने एप्लिकेशन में निम्नलिखित गुण जोड़ना चाहिए।
JDBC URL प्रारूप
jdbc:mysql://google/<DATABASE-NAME>?cloudSqlInstance = <GOOGLE_CLOUD_SQL_INSTANCE_NAME> &socketFactory = com.google.cloud.sql.mysql.SocketFactory&user = <USERNAME>&password = <PASSWORD>
Note - स्प्रिंग बूट एप्लिकेशन और Google क्लाउड SQL एक ही GCP प्रोजेक्ट में होने चाहिए।
Application.properties फ़ाइल नीचे दी गई है।
spring.dbProductService.driverClassName = com.mysql.jdbc.Driver
spring.dbProductService.url = jdbc:mysql://google/PRODUCTSERVICE?cloudSqlInstance = springboot-gcp-cloudsql:asia-northeast1:springboot-gcp-cloudsql-instance&socketFactory = com.google.cloud.sql.mysql.SocketFactory&user = root&password = rootspring.dbProductService.username = root
spring.dbProductService.password = root
spring.dbProductService.testOnBorrow = true
spring.dbProductService.testWhileIdle = true
spring.dbProductService.timeBetweenEvictionRunsMillis = 60000
spring.dbProductService.minEvictableIdleTimeMillis = 30000
spring.dbProductService.validationQuery = SELECT 1
spring.dbProductService.max-active = 15
spring.dbProductService.max-idle = 10
spring.dbProductService.max-wait = 8000
YAML फ़ाइल उपयोगकर्ता आपके application.yml फ़ाइल के नीचे के गुण जोड़ सकते हैं।
spring:
datasource:
driverClassName: com.mysql.jdbc.Driver
url: "jdbc:mysql://google/PRODUCTSERVICE?cloudSqlInstance=springboot-gcp-cloudsql:asia-northeast1:springboot-gcp-cloudsql-instance&socketFactory=com.google.cloud.sql.mysql.SocketFactory&user=root&password=root"
password: "root"
username: "root"
testOnBorrow: true
testWhileIdle: true
validationQuery: SELECT 1
max-active: 15
max-idle: 10
max-wait: 8000