Next.js GCP App Engine 배포 시 환경변수 분기
1064
작성한 질문수 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 모두 끈질기게 시도해봤지만
능력부족 탓인지 성공하지 못했습니다..
능력자분들께서 도움주시면 잊지않겠습니다!!
답변 2
0
저도 같은 문제로 해맸는데요
@next/env 디펜던시 를 추가 후 설정했더니 작동되었습니다.
https://nextjs.org/docs/pages/building-your-application/configuring/environment-variables
0
안녕하세요, 인프런 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 파일이 정확히 프로젝트 루트 디렉토리에 위치해 있는지 확인해 주세요.
문제가 계속되면 추가 질문 남겨주시면 도움을 드리겠습니다. 좋은 결과 있으시길 바래요!
0
아쉽게도 이미 해당 스크립트가 적용되어 있는 상태입니다.
{
deploy:dev: "npm run build:dev && gcloud app deploy --project='development' -q --appyaml=dev_app.yaml"
}
claude code가 작업중일때 ctrl t 눌러서 진행상황 확인 불가
0
13
0
메타프롬프트 관련
0
13
1
mcp관련 질문입니다!
0
12
0
side bar positon. 어떻게 해도 안돼요..;
0
12
1
모델 고정방법 문의
0
12
1
98강. 1인 사이드프로젝트 시 질문
0
16
1
state 객체로 묶기
0
8
0
강의화면과 Cursor프로그램 화면이 달라서요..
0
13
1
커서 설치했는데 이해 안되네요
0
17
1
공식사이트 관련과 workspace
0
16
1
수업 잘 들었습니다.
2
17
2
강의와는 별개로...
0
17
3
user-memory-setup 저장 관련
0
12
1
user-memory-setup 작성하고 클로드 코드로 돌아가는 방법
0
12
1
에러화면 질의
0
14
1
[미션6] output-style 위치 변경
0
13
1
아래 에러가 나는 경우의 대처법
0
13
1
이전 커밋으로 롤백을 하고 다시 롤백하기 전 커밋으로 돌아가려고 하는데 그래프 패널에서 main이 사라져 버립니다.
0
15
1
CLAUDE.md 에 import 문법 질문
0
19
1
BFF의 필요성
0
11
0
Github 404 Error
0
22
1
안녕하세요 유튜브 보고 재밌을꺼 같아서 강의 결제해서 보고잇습니다.
0
20
2
/update-roadmap 는 언제 어떻게 사용하는건지요?
0
25
2
깃 관련질문입니다!
0
27
2





