Next.js GCP App Engine 배포 시 환경변수 분기

23.08.10 14:35 작성 23.08.10 14:49 수정 조회수 561

1

Next.js로 Google Cloud Platform에 App Engine 서비스 배포를 진행하고 있습니다.

문제는 production ( 실 서비스 )와 development ( 개발용 )으로 나누어서
.env.development, .env.production의 두개의 환경변수를 가지고있습니다.

배포 시 실서비스 에서는 .env.production을 사용하도록
개발용 에서는 .env.development를 사용하도록 설정하려는데 이것저것 만져보아도 production만 사용하는 문제가 발생해버리네요.

 

현재 프로젝트구조와 설정코드는 이렇습니다.

project
├── local
  └── Dockerfile
  └── docker-compose.yml 
├── resource
  └── .next 
    └── ... (Next.js 빌드 파일) 
  └── node_modules 
  └── package.json
  └── dev_app.yaml
  └── prd_app.yaml
  └── .env.development
  └── .env.production
  └── next.config.js
  └── ... (기타 Next.js 프로젝트 파일) 


여기서 package.json의 script설정은 다음과 같습니다.

{
dev: "next dev", 
start: "next start", 
lint: "next lint", 
deploy: "npm run build && gcloud app deploy --project='production' -q --appyaml=prd_app.yaml", 
deploy:dev: "npm run build:dev && gcloud app deploy --project='development' -q --appyaml=dev_app.yaml", 
build: "dotenv -e .env.production next build", 
build:dev: "dotenv -e .env.development next build" 
}   


next.config.js는 특별히 건드리지 않았습니다.

dev_app.yaml, prd_app.yaml파일은 서비스명만 각각 설정해 주었습니다.

runtime: nodejs20 # or another supported version
service: development

 

질문 1.
현재 app engine 업로드된 용량, 로직을 보니 빌드파일이 아닌 프로젝트 그대로 들어가는 것 같습니다.
빌드는 환경변수파일도 정상적으로 분기되는데 앱엔진에서 해당문제가 발생하는 것으로보아
혹시 Next.js에서 빌드된 파일로 app engine에 배포할 수 있는지 궁금합니다.

질문 2.
빌드파일만 올릴수 없다 라고 하더라도 프로젝트 그대로 올리면서 환경변수를 분기할 방법이 있는지 궁금합니다.

정말 문서건 블로그건 구글서칭, 깃허브검색, GPT 모두 끈질기게 시도해봤지만
능력부족 탓인지 성공하지 못했습니다..
능력자분들께서 도움주시면 잊지않겠습니다!!

답변 1

답변을 작성해보세요.

0

인프런 AI 인턴님의 프로필

인프런 AI 인턴

23.08.11 14:41

안녕하세요, 인프런 AI 인턴이에요. Next.js로 Google Cloud Platform에 App Engine 서비스 배포하실 때, 환경변수를 분기해서 사용하고자 하는 것 같네요. 현재 프로젝트 구조와 설정 코드를 보니, 설정이 잘못된 부분이 있는 것 같아 보입니다.

우선, package.json의 script 설정을 살펴보겠습니다.

"deploy": "npm run build && gcloud app deploy --project='production' -q --appyaml=prd_app.yaml",
"deploy:dev": "npm run build:dev && gcloud app deploy --project='development' -q --appyaml=dev_app.yaml",
"build": "dotenv -e .env.production next build"

여기서 문제가 있는 부분은 deploy:dev 스크립트입니다. 현재 설정 상태에서는 deploy:dev 스크립트가 deploy 스크립트와 같은 명령어를 수행하고 있습니다. 따라서 production만 사용하는 문제가 발생한 것 같습니다.

.env.development 파일을 사용하려면 deploy:dev 스크립트에서 build 스크립트 대신 build:dev 스크립트를 실행하도록 수정해야 합니다. 그리고 --project 옵션에도 'development'을 사용하도록 수정할 필요가 있습니다.

수정된 deploy:dev 스크립트는 다음과 같이 되어야 합니다.

"deploy:dev": "npm run build:dev && gcloud app deploy --project='development' -q --appyaml=dev_app.yaml"

위의 수정사항을 반영하고 배포를 다시 시도해 보세요. 그리고 환경변수를 올바르게 사용하고 있는지 확인해 보세요. 문제가 계속되면 Next.js의 환경변수 설정에 문제가 있을 수 있으니 해당 부분도 확인해 보시기 바랍니다.

추가로, .env.development.env.production 파일이 정확히 프로젝트 루트 디렉토리에 위치해 있는지 확인해 주세요.

문제가 계속되면 추가 질문 남겨주시면 도움을 드리겠습니다. 좋은 결과 있으시길 바래요!

장준수님의 프로필

장준수

질문자

23.08.13 18:21

아쉽게도 이미 해당 스크립트가 적용되어 있는 상태입니다.

{
deploy:dev: "npm run build:dev && gcloud app deploy --project='development' -q --appyaml=dev_app.yaml"
}