카테고리 없음
Github action 관련 구글드라이브 연동
공.대.남
2023. 12. 3. 20:17
반응형
배경
GitHub Actions를 통해서 개발 결과물 배포를 자동화할 수 있습니다. 파일 형태로 개발 결과물을 배포를 해야 하는 경우에는 배포 용이성과 배포 버전 관리를 고려하여 클라우드 저장소를 사용하는 것이 좋습니다.
본 문서에서는 GitHub Actions와 Google Cloud를 사용하여 Google Drive에 개발 결과물을 배포하는 방법에 대해서 소개합니다.
사용할 GitHub Actions 라이브러리
google-drive-upload-git-action
Google Cloud 세팅
먼저 Google Cloud Console에 접속합니다.
data:image/s3,"s3://crabby-images/37b01/37b018820ca400e76f2ff8e48ef81e5617b71278" alt=""
새 프로젝트를 하나 생성합니다.
data:image/s3,"s3://crabby-images/e4998/e49980f6c4cbe7ea8917ba3c10a8745a46067fac" alt=""
생성한 프로젝트로 전환합니다.
data:image/s3,"s3://crabby-images/91e55/91e552a04df08277685e2616a42c87ab38540423" alt=""
Google Cloud 관리 콘솔 검색창에서 Google Drive API를 검색하고 선택합니다.
data:image/s3,"s3://crabby-images/5effd/5effd78daf161fdd998883f87b0233a727a2e3cb" alt=""
Google Drive API [사용]을 누릅니다.
data:image/s3,"s3://crabby-images/04283/04283ac2674495a8cf6faf117d1edeec1fed41ee" alt=""
[IAM 및 관리자] - [서비스 계정]에서 서비스 계정을 추가합니다.
data:image/s3,"s3://crabby-images/990cb/990cb7955cb295f7df10e49f6f1cd3389eda0fb4" alt=""
위와 같이 원하는 이름과 계정 설명을 입력합니다.
data:image/s3,"s3://crabby-images/3c583/3c58302b328402aaee0ce175e3ea3126fa8f4b34" alt=""
나머지 설정은 무시하고 [완료] 버튼을 누릅니다.
data:image/s3,"s3://crabby-images/4b61b/4b61bc755eb0a861a2a9ea0c3202f3c42c89e214" alt=""
추가한 계정의 가장 오른쪽의 작업 메뉴을 열어서 [키 관리] 항목을 클릭합니다.
data:image/s3,"s3://crabby-images/124f8/124f8e7be48c8d63609299d50bf179c9df0e2264" alt=""
[키 추가] 메뉴를 열어서 [새 키 만들기]를 클릭합니다.
data:image/s3,"s3://crabby-images/80b51/80b5119b6dc0f4f4809157ee3ce29ef62d3e41c7" alt=""
JSON 유형으로 키를 만듭니다.
data:image/s3,"s3://crabby-images/0653f/0653f8c9607470a5ea03c27ba0021c8d279d1c92" alt=""
안내 문구와 함께 비공개 키가 json 형식으로 로컬에 저장됩니다. 저장된 json 키 파일은 잘 보관해야 합니다.
Google Drive 세팅
Google Cloud 관리 콘솔에 로그인했던 계정으로 Google Drive에 접속하여 공유할 폴더를 하나 생성합니다.
data:image/s3,"s3://crabby-images/28ac8/28ac8b49350a13f1623bc97ea49f893661263702" alt=""
화면 오른쪽의 [액세스 관리] 버튼을 클릭합니다.
data:image/s3,"s3://crabby-images/9401d/9401d2c80ae00e38a09d5c8ae93799cf529e29f4" alt=""
[사용자 및 그룹 추가] 란에 Google Cloud 관리 콘솔에서 생성했던 서비스 계정 이메일을 추가합니다. 이메일 형식은 보통 google-drive-access@xxxxx-xxxxx-xxxxx.iam.gserviceaccount.com 과 같습니다.
data:image/s3,"s3://crabby-images/d9730/d9730467ee94d90cb95a760c3663db1b63920b25" alt=""
위 그림과 같이 서비스 계정 이메일 주소가 등록되었으면, 권한을 “편집자”로 설정하고, 이메일 알림 보내기 옵션은 체크 해제합니다. 그리고 [공유] 버튼을 누릅니다.
data:image/s3,"s3://crabby-images/86cbb/86cbbd6725163bc528eee88d274ce3df822667dd" alt=""
공유 결과 위 그림 오른쪽 부분과 같이 액세스 권한이 있는 사용자에 서비스 계정이 등록된 것을 확인할 수 있습니다.
data:image/s3,"s3://crabby-images/5e5c2/5e5c2fc9c6bbb560751dc180c366f8872d81cc36" alt=""
마지막으로 공유 설정된 폴더의 url에서 폴더 ID를 가져와야 합니다. url 형식은 일반적으로 drive.google.com/drive/folders/<folderId> 위 그림의 붉은 색 네모 칸 영역이 folderId입니다. 이 부분만 복사해서 어딘가 기록해둡니다.
GitHub Actions 설정
앞서 Google Cloud 설정과 Google Drive 설정을 통해 두 가지 정보를 얻었습니다.
- Google Cloud 서비스 계정 JSON 키
- Google Drive 폴더 ID
이 두 가지 정보는 보안상 중요한 정보이므로, GitHub Actions의 yaml에서 바로 사용하지 않고 secrets에 등록합니다.
data:image/s3,"s3://crabby-images/4830f/4830fd06f85fb9cd5d5320e096510f13b115fbc8" alt=""
브라우저에서 GitHub Actions를 수행할 저장소에 접속한 뒤, [Settings] 페이지에서 [Secrets and variables]-[Actions] 메뉴를 클릭합니다. 그리고 [New repository secret] 버튼을 누릅니다.
data:image/s3,"s3://crabby-images/f0445/f044539f533078fe676a17399fff7676049139d9" alt=""
먼저 Google Drive 폴더 ID부터 등록합니다. Name은 GOOGLE_DRIVE_FOLDER_ID로 설정하였으나, 다른 이름을 사용해도 문제는 없습니다. secret에는 Google Drive를 설정할 때 기록해둔 폴더 ID를 입력합니다. [Add secret] 버튼을 누르면 Google Drive 폴더 ID가 등록됩니다.
다음으로 JSON 키를 등록해야 하는데, base64로 인코딩해야 합니다. 인코딩하는 방법은 다음과 같습니다.
# 실행 환경에 따라서 -i와 -o가 생략될 수 있음
# base64 -i <input file> -o <output file>
$ base64 -i xxxxxxxxx-xxxx-xxxxxx-xxxxxxxxxxx.json -o encoded_json
data:image/s3,"s3://crabby-images/08a57/08a573db31fe7767179d3516ebc5bc1bb9b7009f" alt=""
인코딩된 데이터를 위 그림과 같이 입력한 후 secrets에 등록합니다.
data:image/s3,"s3://crabby-images/4f9f3/4f9f36642e21690d43698a4a5350fee432b4d674" alt=""
추가가 완료되면 위와 같이 Repository secrets 리스트에 추가된 secrets 이름들을 확인할 수 있습니다.
이제 workflow yml 파일에 아래와 같은 코드를 추가합니다.
- name: Upload a file to Google Drive
uses: willo32/google-drive-upload-action@v1
with:
target: '업로드할 파일 경로'
credentials: ${{ secrets.GOOGLE_SERVICE_ACCOUNT_CREDENTIALS }}
parent_folder_id: ${{ secrets.GOOGLE_DRIVE_FOLDER_ID }}
이것으로 설정이 모두 마무리되었습니다.
728x90
반응형