Spring Boot - Google Cloud-Plattform

Google Cloud Platform bietet Cloud-Computing-Dienste, mit denen die Spring Boot-Anwendung in der Cloud-Umgebung ausgeführt wird. In diesem Kapitel erfahren Sie, wie Sie die Spring Boot-Anwendung in der GCP App Engine-Plattform bereitstellen.

Laden Sie zunächst die Gradle Build Spring Boot-Anwendung von der Spring Initializer-Seite www.start.spring.io herunter . Beachten Sie den folgenden Screenshot.

Fügen Sie nun in der Datei build.gradle das Google Cloud-Appengine-Plugin und die Appengine-Klassenpfadabhängigkeit hinzu.

Der Code für die Datei build.gradle ist unten angegeben -

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')
}

Schreiben Sie nun einen einfachen HTTP-Endpunkt und er gibt den String-Erfolg wie gezeigt zurück -

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";
   }
}

Fügen Sie als Nächstes die Datei app.yml wie gezeigt im Verzeichnis src / main / appengine hinzu.

runtime: java
env: flex

handlers:
- url: /.*
   script: this field is required, but ignored

Gehen Sie jetzt zur Google Cloud-Konsole und klicken Sie oben auf der Seite auf die Google Cloud-Shell aktivieren.

Verschieben Sie nun Ihre Quelldateien und Gradle-Dateien mithilfe der Google Cloud Shell in das Ausgangsverzeichnis Ihres Google Cloud-Computers.

Führen Sie nun den Befehl gradle appengineDeploy aus, und Ihre Anwendung wird in der Google Cloud-Appengine bereitgestellt.

Note - GCP sollte für die Abrechnung aktiviert sein. Bevor Sie Ihre Anwendung in Appengine bereitstellen, sollten Sie eine Appengine-Plattform in GCP erstellen.

Die Bereitstellung Ihrer Anwendung auf der GCP-Appengine-Plattform dauert einige Minuten.

Nach erfolgreicher Erstellung wird die Service-URL im Konsolenfenster angezeigt.

Klicken Sie nun auf die Service-URL und sehen Sie die Ausgabe.

Google Cloud SQL

Um Google Cloud SQL mit Ihrer Spring Boot-Anwendung zu verbinden, sollten Sie der Datei application.properties die folgenden Eigenschaften hinzufügen.

JDBC-URL-Format

jdbc:mysql://google/<DATABASE-NAME>?cloudSqlInstance = <GOOGLE_CLOUD_SQL_INSTANCE_NAME> &socketFactory = com.google.cloud.sql.mysql.SocketFactory&user = <USERNAME>&password = <PASSWORD>

Note - Die Spring Boot-Anwendung und Google Cloud SQL sollten sich im selben GCP-Projekt befinden.

Die Datei application.properties ist unten angegeben.

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

Benutzer von YAML-Dateien können die folgenden Eigenschaften zu Ihrer application.yml-Datei hinzufügen.

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