728x90
개요
- 라이브러리 업데이트와 버전 관리는 프로젝트에서 중요한 부분입니다. 의존성 모듈과 개발 환경 모듈을 명확하게 구분하는 것이 중요합니다.
- Node.js 버전은 프로젝트에서 확실히 정의해야 하며, 라이브러리는 신중하게 추가하고 필요할 때만 정기적으로 업데이트하는 것이 좋습니다.
- 라이브러리가 많아질수록 관리가 어려워지므로, 의존성 관리에 신경을 써야 합니다.
[Node.js] Node.js 기본 개념 및 환경 설정: package.json 파일 구성 방법
https://sillimmouse.tistory.com/82
패키지 유형
실제로 어플리케이션 운용에 필요한 의존성 여부
- dependencies: 실제 런타임에서 사용되는 패키지
- devDependencies: 개발 모드일 때만 의존하고 있는 패키지
- peerDependencies: 특정 버전의 다른 라이브러리와 호환되는 패키지를 정의합니다. 주로 플러그인 형태의 라이브러리에서 사용됩니다.
- optionalDependencies: 선택적으로 설치되는 패키지로, 설치가 실패해도 애플리케이션 실행에는 문제가 없는 경우에 사용됩니다.
{
"dependencies": {
"dayjs": "1.11.1"
},
"devDependencies": {
"@types/node": "17.0.25"
}
}
npm install
$ npm install
플래그 | 효과 |
package.json 에 포함된 의존성 패키지들이 일괄적으로 설치 | |
-P | 패키지를 설치하고 프로젝트의 dependencies 목록에 추가한다. |
—save-prod | 패키지를 설치하고 프로젝트의 dependencies 목록에 추가한다. |
-D | 패키지를 설치하고 프로젝트의 devDependencies 목록에 추가한다. |
—save-dev | 패키지를 설치하고 프로젝트의 devDependencies 목록에 추가한다. |
-g | 패키지를 프로젝트가 아닌 시스템의 node_modules 폴더에 설치한다. |
--save | 파일의 종속성 항목을 설치 |
--force | 디스크에 존재하는 경우 원격 항목을 가져 오기 |
--force-latest | 충돌시 최신 버전 |
--production | 프로젝트 devddependencies를 설치하지 마십시오 |
--no-color | 색상을 인쇄하지 마십시오 |
패키지 글로벌 관리
설치된 글로벌 모듈 확인
$ npm list -g --depth=0
글로벌 모듈 설치
$ npm install -g [패키지명]
글로벌 모듈 삭제
$ npm uninstall -g [패키지명]
$ npm un -g [패키지명]
패키지 버전 및 호환성 관리
호환성 모듈의 의존성 버전 확인
$ npm info "module@version" peerDependencies
모듈의 호환성 의존성 모듈 설치
$ npx install-peerdeps --dev eslint-config-airbnb
npm outdated을 사용하여 최신버전 조회
- 의존성 모듈의 새로운 버전을 일일히 확인하지 않아도 된다.
- 버전 업데이트가 필요한 모듈만 조회 된다.
- 빨간색: 메이저 버전 일치
- 노란색: 메이저 불일치
npm outdated
ncu을 사용하여 최신버전 일괄 업데이트
// dependencies , devdependencies 을 대상으로 버전 업데이트가 필요한 모듈을 최신 버전으로 업데이트 해준다.
$ npm i -g npm-check-updates
$ ncu -u
모듈 개별 업데이트
// 해당 모듈을 특정 버전으로 업데이트
$ npm install @eslint/js@^18.2.0
$ 해당 모듈을 최신버전으로 업데이트
$ npm install @eslint/js@latest
패키지 종속성 유형 관리
omit
- 정의 : --omit 옵션은 설치 시 특정 유형의 종속성을 생략하는 옵션, 생략된 종속성은 package-lock.json이나 npm-shrinkwrap.json에는 기록되지만, 실제로 디스크에는 설치되지 않습니다.
- default : NODE_ENV환경 변수가 'production'으로 설정된 경우 'dev', 그렇지 않으면 비어 있음.
- type : "dev", "optional" 또는 "peer"(여러 번 설정 가능)
include
- 정의 : --include 옵션은 특정 유형의 종속성만 포함할 수 있게 해주는 옵션
- default :
- type : "prod", "dev", "optional" 또는 "peer"(여러 번 설정 가능)
두 옵션을 함께 사용하면, 포함과 생략 규칙이 충돌할 수 있습니다. 이 경우 포함 목록에 있는 종속성 유형이 우선 적용
예를 들어 --omit=dev와 --include=prod를 함께 사용하면 개발 종속성은 제외하고 일반 종속성만 설치
npm WRAN config production Use `--omit=dev` instead.
- 2024-11-08 기준, npm 최신 버전인 v10.9.0을 기준으로 작성
- Node.js v18.19.0 (npm v10.2.3)
// v10.9.0 이상
$ npm install --omit=dev
$ npm install --include=prod
// v7.24.4 - 9.9.3 이상
$ npm install --omit=dev
$ NODE_ENV=production npm install --include=prod
// #9 1.042 npm WARN config only Use `--omit=dev` to omit dev dependencies from the install.
// v6 - v7, npm v7부터는 이 옵션이 더 이상 권장되지 않음
// --only={prod[uction]|dev[elopment]}
$ npm install --only=prod
$ npm install --only=dev
// v3.3.0-v6.14.18 이상 (2011년)
$ npm install --production
$ npm install --development
노드 버전 강제하여 모듈 버전 정의 방법
1. engines에 노드 버전 명시
- package.json 에 engines 버전을 명시한다.
- 버전과 맞지 않는 경우 프로젝트 npm install 할때 버전이 맞지 않으면 에러 메세지가 표출된다.
// package.json
"engines": {
"node": "12.22.6",
"npm" : ">=8.0.0 <9.0.0"
},
2. .nvmrc 설정 파일 추가하여 프로젝트 버전 관리
- package.json 경로에 .nvmrc 파일 추가
// .nvmrc
v16.20.2
- .nvmrc 실행
// .nvmrc가 없을 시
$ nvm use 10.22.1
// 프로젝트 경로에 .nvmrc가 있을 시
$ nvm use
// package.json
"scripts": {
“prestart” : “nvm use”
}
- window에서는 .nvmrc 파일이 실행안된다. 비슷환 기능을 하고 싶다면 아래 스크립트를 사용하면 된다.
$ nvm use `cat .nvmrc`
$ nvm use $(cat .nvmrc)
참고문헌
https://docs.npmjs.com/cli/v8/commands/npm-install/
npm-install | npm Docs
Install a package
docs.npmjs.com
728x90
'frontend > Node.js' 카테고리의 다른 글
[Node.js] NPM, CDN 차이 (2) | 2024.11.08 |
---|---|
[Node.js] Node.js 기본 개념 및 환경 설정: package.json 파일 구성 방법 (0) | 2024.05.03 |
[Node.js] CORS란? Express 서버에서 CORS 우회 및 Proxy 설정 방법 - http-proxy-middleware 1,2,3 버전 비교 (0) | 2024.01.24 |