Next.js GCP App Engine 배포 시 환경변수 분기
1074
작성한 질문수 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"
}
플랜모드에 대해 업데이트 내용이 있었던 것 같습니다!
0
1
1
서브에이전트 질문입니다.
0
2
1
거래대금에 대한 필터링 문제
0
5
0
41강에 vcp 결과가 다르게 나옵니다.
0
7
2
PRD 파일에 대해서
0
5
1
뉴스 검색에서 날짜 필터링
0
16
2
user memory 들어가면 이상하게 나와요
0
10
1
MCP사용시 보안 문제
0
9
0
작업 순서
0
16
1
scorer.py 에 뉴스/재료 점수 부분이 없어요.
0
18
2
cursor command 실행 안됨
0
14
1
call stack 표현이 잘못표현된것이 아닌가요?
0
22
2
스킬과 서브에이전트 활용 관련
0
9
1
mcp 문의드립니다.
0
16
1
제가 만든 파일로 강의 수강을 이어가도 되나요?
0
24
2
클로드 설치도 안된상태에서 에러문구 나옵니다.
0
24
3
에이전트 정상 작동 관련 확인
0
25
2
토큰 사용량 초과 시 agent 종료
0
24
3
cd workspace 명령 시 알아듣지 못해요
0
24
2
tasks 명령어 관련
0
25
1
작업내용 보기 Ctrl+R
0
29
1
agent model 질문
0
45
2
[MISSION 3] 질문입니다.
0
29
1
🔥[MISSION 7] 프로필 웹 Github 링크 제출하기🔥질문
0
30
2





