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)
자습형 환경 설정
- 아직 Google 계정이 없다면 계정을 만들어야 합니다. Cloud 콘솔에 로그인하고 새 프로젝트를 만듭니다.
모든 Google Cloud 프로젝트에서 고유한 이름인 프로젝트 ID를 기억하세요 (이미지의 이름은 이미 사용되었으므로 사용할 수 없습니다). 이 이름은 나중에 Codelab에서 PROJECT_ID
로 참조됩니다.
- 다음으로 Google Cloud 리소스를 사용하려면 Cloud 콘솔에서 결제를 사용 설정해야 합니다. Codelab을 실행하는 과정에는 많은 비용이 들지 않지만 더 많은 리소스를 사용하려고 하거나 실행 중일 경우 비용이 더 들 수 있습니다.
Google Cloud 신규 사용자는 $300 상당의 무료 체험판을 사용할 수 있습니다.
Cloud Shell
이 Debian 기반 가상 머신에는 필요한 모든 개발 도구가 로드되어 있습니다. 영구적인 5GB 홈 디렉터리를 제공하고 Google Cloud에서 실행되므로 네트워크 성능과 인증이 크게 개선됩니다. 즉, 이 Codelab에 필요한 것은 브라우저뿐입니다(Chromebook에서도 작동 가능).
- Cloud 콘솔에서 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
다양한 영역을 선택할 수 있습니다. 자세한 내용은 리전 및 영역을 참고하세요.
Spring Boot 명령줄 도구를 설치한 후 새 'Hello, World' 웹 앱을 초기화하고 부트스트랩할 수 있습니다.
$ curl https://start.spring.io/starter.tgz \ -d dependencies=web -d baseDir=helloworld | tar -xzvf -
그러면 Maven의 pom.xml
, Maven 래퍼, 앱 진입점과 함께 새 Maven 프로젝트가 포함된 새 디렉터리가 생성됩니다.
- Cloud Shell 메뉴에서 편집기 실행
을 클릭하여 코드 편집기를 엽니다.
- 편집기가 열리면
helloworld/src/main/java/com/example/demo/DemoApplication.java
파일을 찾습니다.
- 코드가 열리면
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!";
}
}
- 파일을 저장합니다.
- Spring Boot 플러그인을 사용하여 Spring Boot 앱을 정상적으로 시작할 수 있습니다.
$ cd $HOME/helloworld $ ./mvnw -DskipTests spring-boot:run
- 앱이 시작되면 Cloud Shell 툴바에서 웹 미리보기
를 클릭한 다음 포트 8080에서 미리보기를 클릭합니다.
브라우저의 탭이 열리면서 시작한 서버에 연결됩니다.
Cloud Shell에서 직접 새 Spring Boot Java 웹 앱을 빌드하고 실행하는 방법을 배웠습니다.