Node.js
Node.js 관련 문제 해결 가이드
준비 및 확인사항
- 8, 10, 12, 14, 16, 18, 20
로컬/테스트 환경과 클라우드타입에서 설정한 Node 버전이 상이한 경우 정상적으로 빌드되지 않을 수 있습니다.
클라우드타입은 배포할 GitHub 저장소의
yarn.lock,package-lock.json,package.json의 순서대로 파일을 탐색하여 패키지를 설치합니다. 만약 이 3개의 파일이 모두 누락되어 있다면 설치할 패키지를 특정할 수 없기 때문에 정상적으로 배포가 진행되지 않습니다. GitHub 저장소의 필요 파일 누락 여부를 확인해주세요.
yarn.lock,package-lock.json,package.json파일이 GitHub 저장소에 정상적으로 반영되어 있다면 node 버전과 Install Command를 확인해주세요.- node의 경우 v14와 v16 간 호환이 불가능한 패키지가 적지 않기 때문에 로컬에서 개발을 진행할 때 사용하던 node 버전을 확인하여 적용 부탁드립니다.
- Install Command 의 경우 기본적으로
npm ci명령어가 적용되며, 프로젝트의 환경에 맞게 변경이 가능합니다.
클라우드타입에서 서비스가 배포되는 환경인 리눅스 운영체제에서는 root 권한이 없는 상태에서 1024번 이하의 포트를 사용할 수 없습니다. 클라우드타입의 어플리케이션은 보안 및 취약점 노출 방지를 위해 root가 아닌 사용자로 서비스를 구동하고 있기 때문에 다른 포트를 설정하여 서비스 재배포 부탁드립니다.
서비스 배포 후 50X 발생 시, 실행 로그 결과에 따라 다음과 같은 케이스로 나눠 살펴볼 수 있습니다.
1️⃣ 어플리케이션이 정상적으로 구동되지 않고 예외가 발생하거나 서버가 종료된 경우
어플리케이션 구동에 필요한 패키지가 정상적으로 설치되지 않았거나 데이터베이스 연결이 실패했을 수 있습니다. 실행 로그의 에러 메세지를 기반으로 소스 내용 및 환경 변수 등을 확인해주세요.
2️⃣ 서버는 정상적으로 구동됐는데 권한과 관련된 에러가 발생하는 경우
언어 및 프레임워크 중 특정 도메인 규칙에 대하여 CORS 허용 규칙을 적용해주어야 접속가능한 것이 있습니다. 리버스 프록시 페이지를 참고해주세요.
3️⃣ 빌드가 정상적으로 완료 되었는데 상태가 ‘시작중’에서 바뀌지 않고 생성된 URL에 접속해도 503 페이지만 뜨는 경우
루트 디렉토리가 아닌 서브디렉토리에 코드가 존재하는 경우 이러한 상황이 발생할 수 있습니다. 사용자의 저장소를 디렉토리를 확인하고, 해당되는 경우 서브디렉토리 설정을 추가해주세요.
4️⃣ 서버는 정상적으로 구동됐는데 접속시 에러창이 뜨고 실행 로그에 아무런 반응이 없는 경우
소스 코드에 설정된 포트가 배포시에 작성하신 포트와 불일치할 경우일 확률이 높습니다. 입력한 포트를 확인해주세요.