빠른 시작: IntelliJ용 Cloud Code를 사용하여 Kubernetes 앱 배포

IntelliJ용 Cloud Code를 사용하여 Kubernetes 앱 배포

이 페이지에서는 Cloud Code를 시작하는 방법을 보여줍니다.

이 빠른 시작에서는 시작 Hello World 템플릿을 사용하여 새 Kubernetes 애플리케이션 설정, 선택한 클러스터에서 앱 실행, 앱을 반복적으로 개발할 수 있도록 꾸준히 재빌드 촉진, 실행 중인 코드 디버깅 수행, 라이브 애플리케이션에서 로그 스트리밍을 쉽게 확인할 수 있습니다.

시작하기 전에

  1. Google Cloud를 사용하려면 Google Cloud 프로젝트를 만들거나 선택하고 프로젝트에 결제를 사용 설정해야 합니다.

    또는 다른 Cloud Platform에서 호스팅되는 클러스터 또는 로컬 Kubernetes 클러스터를 minikubeDocker Desktop과 같은 도구와 함께 사용할 수 있습니다.

  2. Cloud Code가 샘플 클론과 같은 Git 작업을 수행할 수 있도록 Git을 설치합니다.

플러그인 설치

Cloud Code 플러그인을 설치하는 방법은 다음과 같습니다.

  1. 아직 설치하지 않았다면 JetBrains IDE 버전 2020.3 이상(예: IntelliJ Ultimate/Community, PyCharm Professional/Community, WebStorm, GoLand)을 설치합니다.

  2. 모든 Cloud Platform의 경우 Docker 클라이언트(Docker 레지스트리로 인증됨)가 머신의 PATH에 설치되어 있는지 확인합니다(폴더는 PATH의 디렉터리 아래에 표시되어야 함). docker -v를 실행하여 Docker가 이미 설치되어 있는지 확인합니다.

    Cloud Code는 IDE에서 minikube, kubectl, Skaffold, Google Cloud SDK 종속 항목을 자동으로 설치 및 관리합니다.

  3. IntelliJ IDEA 또는 기타 지원되는 JetBrains IDE를 엽니다.

  4. IDE가 열리면 이 페이지를 새로고침하세요.

  5. 다음 버튼을 클릭하여 Cloud Code 플러그인을 설치합니다.

  6. IDE에서 열리는 설치 대화상자에서 확인을 클릭하여 Cloud Code를 설정합니다.

  7. Apple M 시리즈 실리콘에서 Cloud Code를 실행하면 Rosetta 2를 설치하라는 메시지가 표시됩니다. 그러면 Cloud Code가 관리형 종속 항목으로 kubectl을 설치할 수 있습니다.

    Rosetta 2를 설치하지 않으려면 관리형 종속 항목을 해제하고(IntelliJ IDEA > 환경설정 > 도구 > Cloud Code > 종속 항목) 종속 항목 커스텀 버전에 설명된 대로 kubectl의 고유 ARM 버전을 설치합니다.

애플리케이션 만들기

기존 샘플을 사용하여 새 애플리케이션을 만들려면 다음 단계를 따릅니다.

  1. IDE에서 File(파일) > New Project(새 프로젝트)를 열고 Cloud Code: Kubernetes를 선택합니다.

  2. 시작 애플리케이션 목록에서 Hello World 템플릿을 선택합니다. 사용 가능한 템플릿 목록: Python, Go, NodeJS, 자바 hello world, 방명록 애플리케이션

  3. 프로젝트 이름을 선택합니다.

    마침을 클릭하면 Cloud Code에서 선택한 템플릿을 클론하여 사용할 새로 만든 프로젝트를 엽니다.

    자바 템플릿의 경우 필요한 Maven 프로젝트를 가져와서 pom.xml을 동기화하라는 메시지가 표시됩니다. Add as Maven project(Maven 프로젝트로 추가)를 클릭한 다음 Import Changes(변경사항 가져오기)를 클릭합니다.

클러스터 선택

애플리케이션을 개발하려면 Minikube에서 로컬로 호스팅되거나 Google Kubernetes Engine 클러스터와 같은 클라우드 플랫폼을 사용하는 연결된 Kubernetes 클러스터가 필요합니다.

로컬 클러스터

이 빠른 시작에서 사용할 클러스터가 없는 경우 Cloud Code 관리형 로컬 Minikube 클러스터로 애플리케이션을 실행할 수 있습니다. Cloud Code는 애플리케이션 실행을 위해 Minikube 클러스터를 시작하고, 배포가 중지되면 클러스터를 중지합니다. Minikube 클러스터가 이미 실행 중인 경우, Cloud Code는 배포를 위해 기존 Minikube 클러스터를 재사용합니다.

다음 단계인 애플리케이션 개발에서 배포 환경설정으로 설정하여 이 Cloud Code 관리형 Minikube 클러스터를 사용할 수 있습니다.

클라우드 플랫폼 기반 클러스터

kubectl과 같이 이 빠른 시작에 사용할 수 있는 Kubernetes 도구를 사용하도록 구성된 클러스터가 이미 있으면 Cloud Code가 이를 자동으로 배포합니다. 애플리케이션 개발로 이동하여 원하는 클러스터가 현재 컨텍스트로 설정되었는지 확인할 수 있습니다.

그렇지 않으면 해당 클라우드 플랫폼의 특정 안내에 따라 만들 수 있습니다. GKE의 경우 클러스터 만들기 가이드를 따를 수 있습니다.

애플리케이션 개발

Kubernetes에서 애플리케이션 개발을 시작하려면 다음 안내를 따릅니다.

  1. Cloud Platform에서 호스팅된 클러스터에서 실행 중인 경우 Kubernetes에서 개발에 대한 컨테이너 이미지가 저장되는 위치를 정의했는지 확인합니다.

    IDE에서 Google Cloud에 로그인하고 기본 프로젝트가 정의된 경우 Cloud Code는 자동으로 기본 컨테이너 이미지 저장소({project_id}가 기본 프로젝트를 참조하는 경우 gcr.io/{project_id})를 사용합니다.

  2. 원하는 Kubernetes 컨텍스트가 설정되었는지 확인합니다. 이는 실행 탭 및 배포 환경설정 섹션에 있는 Develop on Kubernetes 구성에서 지정할 수 있습니다(실행 > 구성 수정 > Develop on Kubernetes를 통해 액세스 가능).

    현재 컨텍스트(기본값), Minikube 클러스터에 로컬로, 또는 사용 가능한 다른 컨텍스트에 배포하도록 선택할 수 있습니다.

    기본적으로 Kubernetes 애플리케이션은 주문형으로 선택된 주문형 모드에서 실행됩니다. 원하는 경우 파일 저장 시 옵션을 대신 선택할 수 있습니다.

  3. 탐색 메뉴의 실행/디버그 구성 선택기에서 Kubernetes에서 개발 실행 대상을 선택합니다.

    Kubernetes 배포 실행 구성

    이렇게 하면 모든 코드 변경사항이 자동으로 새 버전의 애플리케이션에 빌드, 푸시, 배포됩니다.

  4. Kubernetes 클러스터에서 개발 주기를 시작하려면 Kubernetes에서 개발

  5. 출력 창로그 탭에서 수신되는 애플리케이션 로그를 확인합니다.

    배포가 시작되면 배포된 애플리케이션에 전달된 포트 목록이 표시됩니다.

  6. 배포가 성공하면 새로운 서비스 URL을 사용할 수 있다는 알림이 표시됩니다. 서비스 URL 탭을 클릭하여 URL을 확인한 후 URL 링크를 클릭하여 실행 중인 애플리케이션으로 브라우저를 엽니다.

    서비스 URL 탭에서 포트 전달 서비스 보기

    또는 이벤트 로그를 연 후 링크를 클릭하여 실행 중인 애플리케이션으로 브라우저를 열 수 있습니다.

애플리케이션 디버깅

Cloud Code는 디버깅 중 변경사항 적용을 지원합니다.

애플리케이션을 디버깅하는 방법은 다음과 같습니다.

  1. Develop on Kubernetes를 위한 디버그 작업 실행 작업 아이콘을 클릭하여 Kubernetes 클러스터의 디버그 모드에서 개발 주기를 시작합니다.

    디버그 모드에서 Kubernetes 클러스터 개발 주기 시작

  2. Cloud Code에서 디버그 세션을 연결합니다. 성공하면 디버그 도구 창이 열리고 콘솔 탭에서 연결을 확인합니다.

    이제 라이브 Kubernetes 클러스터를 디버깅할 수 있습니다.

  3. 중단점을 추가하려는 코드의 실행줄에서 여백을 클릭합니다.

    붉은색으로 채워진 원은 활성 중단점을 나타내며 윤곽선이 붉고 가운데가 빈 원은 사용하지 않는 중단점을 나타냅니다.

  4. 애플리케이션에 새 요청을 보내면 원하는 행에서 일시중지됩니다.

    Kubernetes 디버거 세션

  5. 디버깅 세션을 종료하려면 Develop on Kubernetes 실행 구성의 중지 아이콘을 클릭합니다.

로그 보기

애플리케이션을 개발하고 실행하는 동안 터미널 출력에서 실행 중인 포드의 실시간 로그 스트림을 보는 것 외에 Kubernetes 탐색기로 이동하여 특정 포드의 로그를 볼 수 있습니다.

특정 포드의 로그를 보려면 다음 단계를 따릅니다.

  1. Kubernetes 탐색기로 이동합니다. 오른쪽 측면 패널에서 또는 Tools(도구) > Cloud Code > Kubernetes > View Cluster Explorer(클러스터 탐색기 보기)를 사용해 액세스할 수 있습니다.

    오른쪽 작업 표시줄의 탭에서 Kubernetes 탐색기 패널이 열립니다.

  2. 로그를 보려는 포드를 선택합니다.

  3. 포드를 마우스 오른쪽 버튼으로 클릭한 다음 스트림 로그를 선택합니다. 또는 포드에서 실행되는 개별 컨테이너의 로그를 스트리밍할 수 있습니다.

    그러면 Kubernetes 탐색기 콘솔에 로그가 출력됩니다.

    마우스 오른쪽 버튼 클릭 메뉴를 사용하여 Kubernetes 탐색기 콘솔에 로그를 출력하는 포드의 스트리밍 로그

삭제

이 빠른 시작에서 사용한 리소스 비용이 계정에 청구되지 않도록 하려면 만든 클러스터와 프로젝트를 삭제해야 합니다.

Google Cloud를 사용 중이며 프로젝트 및 GKE 클러스터를 포함한 관련 리소스를 삭제하려는 경우는 다음을 따릅니다.

  1. Cloud Console의 프로젝트 페이지로 이동합니다.

    프로젝트 페이지로 이동

  2. 이 빠른 시작에서 만든 프로젝트를 선택하고 옆의 휴지통 아이콘을 클릭하여 삭제합니다.

    그러면 프로젝트가 종료되고 삭제 일정이 예약됩니다.

삭제

이 페이지에서 사용한 리소스 비용이 Google Cloud 계정에 청구되지 않도록 하려면 다음 단계를 수행합니다.

다음 단계