이 Codelab 정보
1. 시작하기 전에
Cloud Shell은 Google Cloud 리소스에 액세스할 수 있는 브라우저 기반 명령줄 도구입니다. Cloud Shell을 사용하면 Cloud SDK 프로젝트 및 리소스를 시스템에 관리할 필요 없이 Cloud SDK 및 다른 도구를 쉽게 관리할 수 있습니다.
Cloud Shell을 사용하여 브라우저를 벗어나지 않고도 Spring Boot 앱을 빌드하고 실행합니다. 이를 위해 Spring Boot으로 앱 빌드의 샘플 코드를 사용합니다.
기본 요건
- 자바 프로그래밍 언어 및 도구에 관한 기본 지식
- Vim, Emacs, nano와 같은 표준 Linux 텍스트 편집기에 대한 지식
실행할 작업
- Cloud Shell을 사용합니다.
- Cloud Shell에서 간단한 Spring Boot 앱을 만듭니다.
- Cloud Shell의 코드 편집기를 사용하여 앱을 수정합니다.
- Cloud Shell에서 앱을 실행합니다.
필요한 항목
- Google Cloud 프로젝트
- 브라우저(예: Chrome)
2. 설정 및 요건
자습형 환경 설정
- 아직 Google 계정이 없다면 계정을 만들어야 합니다. Cloud Console에 로그인하여 새 프로젝트를 만듭니다.
죄송합니다. 모든 Google Cloud 프로젝트에서 고유한 이름인 프로젝트 ID를 기억해 주세요. 이미 사용된 이미지이므로 사용할 수 없습니다. 나중에 Codelab에서 PROJECT_ID
라고 합니다.
- 다음으로 Google Cloud 리소스를 사용하려면 Cloud Console에서 결제를 사용 설정해야 합니다. 이 Codelab을 진행하는 데는 비용이 들지 않지만, 더 많은 리소스를 사용하기로 결정하거나 계속 실행하는 경우 비용이 더 많이 들 수 있습니다.
Google Cloud 신규 사용자는 $300 무료 체험판을 사용할 수 있습니다.
Cloud Shell
이 Debian 기반 가상 머신에는 필요한 모든 개발 도구가 로드되어 있습니다. 영구적인 5GB 홈 디렉터리를 제공하고 Google Cloud에서 실행되므로 네트워크 성능과 인증이 크게 개선됩니다. 즉, 이 Codelab에 필요한 것은 브라우저뿐입니다(Chromebook에서도 작동 가능).
- Cloud Console에서 Cloud Shell을 활성화하려면 Cloud Shell 활성화
(단 몇 분이면 환경을 프로비저닝하고 연결할 수 있습니다.)
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 대시보드에서 찾아보세요.
- 마지막으로 기본 영역 및 프로젝트 구성을 설정합니다.
gcloud config set compute/zone us-central1-f
다양한 영역을 선택할 수 있습니다. 자세한 내용은 리전 및 영역을 참고하세요.
3. 새 Spring Boot 앱 초기화
Spring Boot 명령줄 도구가 설치되면 새 "Hello, World" 웹 앱을 초기화하고 부트스트랩할 수 있습니다.
$ curl https://start.spring.io/starter.tgz \ -d dependencies=web -d baseDir=helloworld | tar -xzvf -
그러면 새 Maven 프로젝트와 함께 Maven pom.xml
, Maven 래퍼, 앱 진입점이 포함된 새 디렉터리가 생성됩니다.
4. 코드 편집기로 새 RESTful 서비스 만들기
- Cloud Shell 메뉴에서 편집기 실행
을 클릭하여 코드 편집기를 엽니다.
- 편집기가 열리면
helloworld/src/main/java/com/example/demo/DemoApplication.java
파일을 찾습니다.
- 코드가 열리면 새로운 RESTful 컨트롤러를 만들어
Hello
에 응답합니다.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!";
}
}
- 파일을 저장합니다.
5. 로컬에서 앱 실행
- Spring Boot 플러그인을 사용하여 Spring Boot 앱을 정상적으로 시작할 수 있습니다.
$ cd $HOME/helloworld $ ./mvnw -DskipTests spring-boot:run
- 앱이 시작되면 Cloud Shell 툴바에서 웹 미리보기
를 클릭한 다음 포트 8080에서 미리보기를 클릭합니다.
브라우저에 탭이 열리고 시작한 서버에 연결됩니다.