App Engine 표준 환경에 Spring Boot 앱 배포

App Engine 앱은 만들기 쉽고, 유지관리가 용이하며, 트래픽 및 데이터 스토리지 요구의 변화에 따라 확장이 가능합니다. App Engine을 사용하면 유지할 서버가 없습니다. 앱을 업로드하기만 하면 바로 사용할 수 있습니다.

App Engine 앱은 수신 트래픽에 따라 자동으로 확장됩니다. 부하 분산, 마이크로서비스, 승인, SQL 및 NoSQL 데이터베이스, 메모리 캐싱, 트래픽 분할, 로깅, 검색, 버전 관리, 출시, 롤백, 보안 스캔이 모두 기본적으로 지원되며 맞춤설정이 매우 쉽습니다.

App Engine 표준 환경App Engine 가변형 환경은 자바, Python, PHP, NodeJS, Go를 비롯한 다양한 프로그래밍 언어를 지원합니다. 이 두 가지 환경을 통해 개발자는 앱 동작 방식의 유연성을 극대화할 수 있습니다. 환경마다 고유한 강점이 있습니다. 자세한 내용은 App Engine 환경 선택을 참조하세요.

Spring Boot 앱을 App Engine 표준 환경에 배포하는 방법을 알아봅니다. 표준 환경은 아무도 사용하지 않을 때 0개로 축소되어 자동으로 확장됩니다.

기본 요건

  • 자바 프로그래밍 언어 및 도구에 관한 기본 지식
  • Vim, Emacs, nano와 같은 표준 Linux 텍스트 편집기에 대한 지식

실행할 작업

  • App Engine에서 Spring Boot 자바 앱을 만드는 방법

필요한 항목

  • Google Cloud 프로젝트
  • 브라우저(예: Chrome)

자습형 환경 설정

  1. Cloud Console에 로그인한 후 새 프로젝트를 만들거나 기존 프로젝트를 재사용합니다. Gmail 또는 G Suite 계정이 아직 없다면 계정을 만들어야 합니다.

모든 Google Cloud 프로젝트에서 고유한 이름인 프로젝트 ID를 기억하세요(위의 이름은 이미 사용되었으므로 사용할 수 없습니다). 이 ID는 나중에 이 Codelab에서 PROJECT_ID라고 부릅니다.

  1. 다음으로 Google Cloud 리소스를 사용하려면 Cloud Console에서 결제를 사용 설정해야 합니다.

이 Codelab을 진행하는 데는 비용이 몇 달러 이상 들지 않지만 더 많은 리소스를 사용하기로 결정하거나 계속 실행하는 경우 비용이 더 많이 들 수 있습니다.

Google Cloud 신규 사용자는 $300 무료 체험판을 사용할 수 있습니다.

Cloud Shell

Google Cloud에서 실행되는 명령줄 환경인 Cloud Shell을 사용합니다.

Cloud Shell 활성화

  1. Cloud Console에서 Cloud Shell 활성화 를 클릭합니다.

이전에 Cloud Shell을 시작하지 않았으면 설명이 포함된 중간 화면(스크롤해야 볼 수 있는 부분)이 제공됩니다. 이 경우 계속을 클릭합니다(이후 다시 표시되지 않음). 이 일회성 화면은 다음과 같습니다.

Cloud Shell을 프로비저닝하고 연결하는 데 몇 분 정도만 걸립니다.

가상 머신에는 필요한 개발 도구가 모두 들어있습니다. 영구적인 5GB 홈 디렉터리를 제공하고 Google Cloud에서 실행되므로 네트워크 성능과 인증이 크게 개선됩니다. 이 Codelab에서 대부분의 작업은 브라우저나 Chromebook만 사용하여 수행할 수 있습니다.

Cloud Shell에 연결되면 인증이 완료되었고 프로젝트가 해당 프로젝트 ID로 이미 설정된 것을 볼 수 있습니다.

  1. Cloud Shell에서 다음 명령어를 실행하여 인증되었는지 확인합니다.
gcloud auth list

명령어 결과

 Credentialed Accounts
ACTIVE  ACCOUNT
*       <my_account>@<my_domain.com>

To set the active account, run:
    $ gcloud config set account `ACCOUNT`
gcloud config list project

명령어 결과

[core]
project = <PROJECT_ID>

또는 다음 명령어로 설정할 수 있습니다.

gcloud config set project <PROJECT_ID>

명령어 결과

Updated property [core/project].

Cloud Shell이 출시된 후에는 명령줄을 사용하여 Spring Initializr로 새 Spring Boot 앱을 생성할 수 있습니다.

$ curl https://start.spring.io/starter.tgz \
  -d bootVersion=2.1.8.RELEASE \
  -d dependencies=web \
  -d baseDir=gae-standard-example | tar -xzvf -
$ cd gae-standard-example

자바 서버 앱을 배포하는 방법에는 두 가지가 있습니다. Maven App Engine 플러그인 또는 Gradle App Engine 플러그인을 사용하거나 war 패키지 디렉터리를 배포하는 것입니다. Maven App Engine 플러그인을 사용하여 앱을 배포합니다.

Maven App Engine 플러그인 추가

pom.xml을 업데이트하여 배포 프로세스를 간소화하는 Google Cloud 플러그인을 포함합니다. Vim, nano 또는 Emacs를 사용하여 파일을 수정할 수 있습니다.

pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" ...>
  ...
  <build>
    <plugins>
      ...
      <plugin>
        <groupId>com.google.cloud.tools</groupId>
        <artifactId>appengine-maven-plugin</artifactId>
        <version>2.1.0</version>
        <configuration>
          <version>1</version>
          <projectId>GCLOUD_CONFIG</projectId>
        </configuration>
      </plugin>
      ...
    </plugins>
  </build>
</project>
  1. 앱을 App Engine 표준 환경에 배포하려면 새 src/main/appengine/app.yaml 설명자 파일을 만들어야 합니다.
$ mkdir -p src/main/appengine/
$ touch src/main/appengine/app.yaml
  1. src/main/appengine/app.yaml 파일을 수정하고 다음 콘텐츠를 추가합니다.

src/main/appengine/app.yaml

runtime: java11
instance_class: F4

DemoApplication.java"hello world!"를 반환하는 새 컨트롤러를 추가합니다.

src/main/java/com/example/demo/DemoApplication.java

package com.example.demo;

...

// Add imports
import org.springframework.web.bind.annotation.*;

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

  @GetMapping("/")
  public String hello() {
    return "hello world!";
  }
}
  1. Spring Boot 플러그인으로 Spring Boot 앱을 시작할 수 있습니다.
$ ./mvnw -DskipTests spring-boot:run
  1. 앱이 시작되면 Cloud Shell 툴바에서 웹 미리보기 를 클릭하고 포트 8080에서 미리보기를 선택합니다.

브라우저에 탭이 열리고 시작한 서버에 연결됩니다.

  1. 먼저 App Engine 앱을 실행할 수 있도록 프로젝트를 초기화합니다. 또한 미국 중부 리전에서 실행되도록 프로젝트를 초기화하세요.
$ gcloud app create --region us-central
You are creating an app for project [...].
WARNING: Creating an App Engine application for a project is irreversible and the region
cannot be changed. More information about regions is at
https://cloud.google.com/appengine/docs/locations
  1. 그런 다음 mvn appengine:deploy를 실행하여 앱을 App Engine 표준 환경에 배포합니다.
$ ./mvnw -DskipTests package appengine:deploy
... first time deploy may take a couple of minutes
  1. 앱이 배포된 후 웹브라우저에서 http://<project-id>.appspot.com을 열어 Cloud Shell에서 다음 명령어를 사용할 수 있습니다.
$ gcloud app browse
... [It may print out the URL for your app]

첫 App Engine 웹 앱을 작성하는 방법을 배웠습니다.

자세히 알아보기