Cloud Shell에서 Spring Boot Java 앱 빌드 및 실행

Cloud Shell은 Google Cloud 리소스에 액세스할 수 있는 브라우저 기반 명령줄 도구입니다. Cloud Shell을 사용하면 시스템에 Cloud SDK 및 기타 도구를 설치할 필요 없이 쉽게 Cloud Console 프로젝트 및 리소스를 관리할 수 있습니다.

브라우저를 나가지 않고 Cloud Shell을 사용하여 Spring Boot 앱을 빌드하고 실행합니다. 이렇게 하려면 Spring Boot로 앱 빌드의 샘플 코드를 사용합니다.

기본 요건

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

실행할 작업

  • Cloud Shell을 사용합니다.
  • Cloud Shell에서 간단한 Spring Boot 앱을 만듭니다.
  • Cloud Shell의 코드 편집기를 사용하여 앱을 수정합니다.
  • Cloud Shell에서 앱을 실행합니다.

필요한 항목

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

자습형 환경 설정

  1. 아직 Google 계정이 없다면 계정을 만들어야 합니다. Cloud 콘솔에 로그인하고 새 프로젝트를 만듭니다.

Screenshot from 2016-02-10 12:45:26.png

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

  1. 다음으로 Google Cloud 리소스를 사용하려면 Cloud 콘솔에서 결제를 사용 설정해야 합니다. Codelab을 실행하는 과정에는 많은 비용이 들지 않지만 더 많은 리소스를 사용하려고 하거나 실행 중일 경우 비용이 더 들 수 있습니다.

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

Cloud Shell

이 Debian 기반 가상 머신에는 필요한 모든 개발 도구가 로드되어 있습니다. 영구적인 5GB 홈 디렉터리를 제공하고 Google Cloud에서 실행되므로 네트워크 성능과 인증이 크게 개선됩니다. 즉, 이 Codelab에 필요한 것은 브라우저뿐입니다(Chromebook에서도 작동 가능).

  1. Cloud 콘솔에서 Cloud Shell을 활성화하려면 Cloud Shell 활성화를 클릭합니다. 환경을 프로비저닝하고 연결하는 데 몇 분 정도만 소요됩니다.

Screen Shot 2017-06-14 at 10.13.43 PM.png

Cloud Shell에 연결되면 사용자 인증이 이미 완료되었고 프로젝트가 내 PROJECT_ID에 설정되어 있음을 확인할 수 있습니다.

gcloud auth list

명령어 결과

Credentialed accounts:
 - <myaccount>@<mydomain>.com (active)
gcloud config list project

명령어 결과

[core]
project = <PROJECT_ID>

또한 Cloud Shell은 기본적으로 이후 명령어를 실행할 때 유용할 수 있는 몇 가지 환경 변수를 설정합니다.

echo $GOOGLE_CLOUD_PROJECT

명령어 결과

<PROJECT_ID>

어떤 이유로든 프로젝트가 설정되지 않았으면 다음 명령어를 실행하면 됩니다.

gcloud config set project <PROJECT_ID>

PROJECT_ID를 찾고 계신가요? 설정 단계에서 사용한 ID를 확인하거나 Cloud Console 대시보드에서 확인하세요.

Project_ID.png

  1. 마지막으로 기본 영역 및 프로젝트 구성을 설정합니다.
gcloud config set compute/zone us-central1-f

다양한 영역을 선택할 수 있습니다. 자세한 내용은 리전 및 영역을 참고하세요.

Spring Boot 명령줄 도구를 설치한 후 새 'Hello, World' 웹 앱을 초기화하고 부트스트랩할 수 있습니다.

$ curl https://start.spring.io/starter.tgz \
  -d dependencies=web -d baseDir=helloworld | tar -xzvf -

그러면 Maven의 pom.xml, Maven 래퍼, 앱 진입점과 함께 새 Maven 프로젝트가 포함된 새 디렉터리가 생성됩니다.

  1. Cloud Shell 메뉴에서 편집기 실행 을 클릭하여 코드 편집기를 엽니다.
  2. 편집기가 열리면 helloworld/src/main/java/com/example/demo/DemoApplication.java 파일을 찾습니다.

  1. 코드가 열리면 Hello에 응답하는 새 RESTful 컨트롤러를 만듭니다. DemoApplication.java 파일에서 현재 클래스 정의 외에 새 Helloworld 클래스 정의를 추가합니다.

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

package com.example;

...

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

@SpringBootApplication
public class DemoApplication {
...
}

// Add the controller
@RestController
class Helloworld {
        @GetMapping("/")
        public String greet() {
                return "Hello!";
        }
}
  1. 파일을 저장합니다.
  1. Spring Boot 플러그인을 사용하여 Spring Boot 앱을 정상적으로 시작할 수 있습니다.
$ cd $HOME/helloworld
$ ./mvnw -DskipTests spring-boot:run

  1. 앱이 시작되면 Cloud Shell 툴바에서 웹 미리보기를 클릭한 다음 포트 8080에서 미리보기를 클릭합니다.

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

Cloud Shell에서 직접 새 Spring Boot Java 웹 앱을 빌드하고 실행하는 방법을 배웠습니다.

자세히 알아보기