5.1 npm 알아보기
1) npm이란 (Node Package Manager)
- 노드의 패키지 매니저
- 다른 사람들이 만든 소스 코드들을 모아둔 저장소
- 남의 코드를 사용하여 프로그래밍 가능
- 이미 있는 기능을 다시 구현할 필요가 없어 효율적
- 오픈 소스 생태계를 구성중
- 패지키 : npm에 업로드 된 노드 모듈
- 모듈이 다른 모듈을 사용할 수 있듯 패키지도 다른 패키지를 사용할 수 있음
- 의존 관계라고 부름
5.2 package.json으로 패키지 관리하기
1) package.json
- 현재 프로젝트에 대한 정보와 사용 중인 패키지에 대한 정보를 담은 파일
- 같은 패키지라도 버전별로 기능이 다를 수 있으므로 버전을 기록해두어야 함
- 동일한 버전을 설치하지 않으면 문제가 생길 수 있음
- 노드 프로젝트 시작 전 package.json부터 만들고 시작함 (npm init)
2) package.json 속성들
- package name : 패키지의 이름. package.json의 name 속성에 저장됨
- version : 패키지의 버전. npm의 버전은 다소 엄격하게 관리됨.
- entry point : 자바스크립트 실행 파일 진입점. 보통 마지막으로 module.exports를 하는 파일을 지정. package.json의 main 속성에 저장됨.
- test command : 코드를 테스트할 때 입력할 명령어를 의미. package.json scripts 속성 안의 test 속성에 저장됨.
- git repository : 코드를 저장해둔 Git 저장소 주소를 의미합니다. 나중에 소스에 문제가 생겼을 때 사용자들이 이 저장소에 방문해 문제를 제기할 수도 있고, 코드 수정본을 올릴 수도 있습니다. package.json의 repository 속성에 저장됩니다.
- keywords : 키워드는 npm 공식 홈페이지(https://npmjs.com)에서 패키지 쉽게 찾을 수 있게 해줍니다. package.json의 keywords 속성에 저장됩니다.
- license : 해당 패키지의 라이선스를 넣어주면 됩니다.
3) npm 스크립트
{
"name": "npmtest",
"version": "1.0.0",
"description": "hello package.json",
"main": "index.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
"start": "node index"
},
"author": "yeobi01",
"license": "MIT"
}
4) 패키지 설치하기
- express, body-parser, cookie-parser 설치하기
$ npm install express
$ npm install cookie-parser body-parser
"dependencies": {
"body-parser": "^1.20.1",
"cookie-parser": "^1.4.6",
"express": "^4.18.2"
}
5) node_modules
- npm install 시 node_modules 폴더 생성
- 내부에 설치한 패키지들이 있음
- express 외에도 express와 의존 관계가 있는 패키지들이 모두 설치됨
- package-lock.json도 생성되어 패키지 간 의존 관계를 명확하게 표시함
6) 개발용 패키지
- npm install --save-dev 패키지명 또는 npm i -D 패키지명
- devDependencies에 추가됨
7) 글로벌(전역) 패키지
- npm intall --global 패키지명 또는 npm i -g 패키지명
- 모든 프로젝트와 콘솔에서 패키지를 사용할 수 있음
- 예제는 rm -rf(리눅스의 삭제 명령)을 흉내내는 rimraf 패키지의 글로벌 설치
- npx로 글로벌 설치 없이 글로벌 명령어 사용 가능
$ npm install --global rimraf
$ rimraf node_modules
-----------------------------------
$ npm install --save-dev rimraf
$ npx rimraf node_modules
5.3 패키지 버전 이해하기
1) SemVer 버저닝
- 노드 패키지의 버전은 SemVer(유의적 버저닝) 방식을 따름
- Major(주 버전), Minor(부 버전), Path(수 버전)
- 노드에서는 배포를 할 때 항상 버전을 올려야 함
- Major는 하위 버전과 호환되지 않은 수정 사항이 생겼을 때 올림
- Minor는 하위 버전과 호환되는 수정 사항이 생겼을 때 올림
- Patch는 기능에 버그를 해결했을 때 올림
2) 버전 기호 사용하기
- 버전 앞에 기호를 붙여 의미를 더함
- ^1.1.1 : 패키지 업데이트 시 minor 버전까지만 업데이트 됨(2.0.0 버전은 안 됨)
- ~1.1.1 : 패키지 업데이트 시 patch 버전까지만 업데이트 됨(1.2.0 버전은 안 됨)
- 1.1.1 : 완전히 고정
- @latest는 최신을 의미
- @next로 가장 최신 배포판 사용 가능(불안정함/정식출시 X)
- 알파/베타/RC 버전이 존재할 수도 있음(1.1.1-alpha.0, 2.0.0-beta.1, 2.0.0-rc.0)
5.4 기타 npm 명령어
1) 기타 명령어
- npm outdated : 어떤 패키지에 기능 변화가 생겼는지 알 수 있음
- npm uninstall 패키지명 : 패키지 삭제(npm rm 패키지명으로도 가능)
- npm search 검색어 : npm 패키지를 검색할 수 있음(npmjs.com에서도 가능)
- npm info 패키지명 : 패키지의 세부 정보 파악 가능
- npm adduser/login : npm에 로그인을 하기 위한 명령어(npmjs.com에서 회원가입)
- npm whoami : 현재 사용자가 누구인지 알려줌
- npm logout : 로그인한 계정을 로그아웃
- npm version 버전 : package.json의 버전올림
- npm deprecate [패키지명][버전][메시지] : 패키지를 설치할 때 경고 메시지를 띄우게 함(오류가 있는 패키지에 적용)
- npm publish : 자신이 만든 패키지를 배포
- npm unpublish : 자신이 만든 패키지를 배포 중단)배포 후 72시간 내에만 가능)
- 다른 사람이 내 패지키를 사용하고 있는데 배포가 중단되면 문제가 생기기 때문
- 기타 명령어는 https://docs.npmjs.com 의 CLI Commands에서 확인
5.5 npm 배포하기
1) npm 회원가입
- npmjs.com 접속해서 회원가입
2) 배포할 패키지 작성
- package.json과 main 부분과 배포할 파일 경로명이 일치해야 함
3) 배포 시도하기
$ npm publish
5) 배포 취소하기
- 72시간 내에 npm unpublish 패키지명 --force입력
$ npm unpublish npmtest-1234 --force
$ npm info npmtest-1234