해당 포스팅은 EC2의 Ubuntu 16.04 버전에서 수행하였습니다.
그리고 라즈베리파이 3에서도 설치 및 동작 확인을 완료하였습니다.
본인도 학생으로서 공부하면서 하고있다보니 미흡한 부분이 많아요... 잘못된 내용이 있으면 댓글 부탁드립니다~
우분투에 NodeJS를 설치하는 아주 간단한 작업을 한 번 수행해 볼 예정입니다.
설치하기 전에 NodeJS가 뭔지를 한 번 간단히 확인해 볼까요 ㅎㅎ
Node.js는 확장성 있는 네트워크 애플리케이션(특히 서버 사이드) 개발에 사용되는 소프트웨어 플랫폼이다. 작성 언어로 자바스크립트를 활용하며 Non-blocking I/O와 단일 스레드 이벤트 루프를 통한 높은 처리 성능을 가지고 있다.
내장 HTTP 서버 라이브러리를 포함하고 있어 웹 서버에서 아파치 등의 별도의 소프트웨어 없이 동작하는 것이 가능하며 이를 통해 웹 서버의 동작에 있어 더 많은 통제를 가능케 한다.
출처 : 위키피디아
즉.... 자바스크립트를 서버 쪽에서 개발할 수 있게 만든건데, 단일 스레드 형식으로 하드웨어 비용 부담을 절감하면서도 비동기식 IO 처리로 인해 높은 성능을 유지할 수 있는 완소 언어이고 많이 사용하는 언어죠 ㅎㅎ
한번에 동시다발적인 요청을 처리할 때 좋은 언어입니다.
대신 단일 스레드라 만약 어떠한 작업을 처리하는데 있어서 시간이 오래 걸리는 작업일 경우 문제가 발생할 수 있어요.
즉, 해당 요청에 대한 응답이 무거운 기능을 돌리는 거라면, 성능 저하가 발생할 요지가 엄청 높다는 뜻이죠 ㅎㅎ
(아 그리고 비동기식으로 코드를 구현하다 보니깐 가독성이 떨어진다는 단점도 있다고 하네요 ㅎㅎ)
출처 : Stack Overflow's developer survey for 2017
하지만 요즘 이렇게 많이 사용하는 언어..ㅎㅎ
Nodejs는 npm이라는 이름의 패키지 관리자를 사용해요. Ubuntu의 apt-get과 같은 역할을 하고, 다양한 모듈들을 npm을 이용해서 아주! 쉽게! 다운로드 받고 사용할 수 있답니다! ( 개 꿀 )
그리고 하나 더 Nodejs를 이용하여 제대로 개발을 하기 위한 또 하나의 필수 아이템.
바로 express라는 프레임워크인데요.
프레임 워크란 네트워크 어플리케이션 개발을 함에 있어서 개발을 조금 더 쉽게 해주는 프레임워크! 즉, 틀을 제공해주는 건데요.
express를 명령어를 통해 생성하기만 하면! 아주 쉽게 서버를 개발할 수 있습니다.
일단 NodeJS 먼저 설치해볼께요.
명령어 단 3줄이면 됩니다. ㅎㅎㅎ
NodeJS & NPM 설치 및 설치 확인
$ curl -sL https://deb.nodesource.com/setup_8.x | sudo -E bash -
가장 먼저 어떤 버전을 설치할지를 결정해줍니다. 여기서는 8.x버전을 설치해줄 거에요. 만약 다른 버전을 설치하고 싶다면 저 숫자만 바꿔주면 됩니다.
오늘(2018.8.1) 기준으로 LTS(Long Term Support)는 8.11.3버전까지 나와있고 최신 버전은 10.7.0까지 나와있네요.
최신 중에서도 지원을 길~게 해주는 LTS 버전을 설치하는 게 낫겠죠?ㅎㅎ
$ sudo apt-get update
그 다음 update를 한 번 수행해줍니다.
$ sudo apt-get install -y nodejs
그 후 nodejs를 apt-get 명령어를 통해 설치해주면 끗!
nodejs를 설치하게 되면 npm 역시 자동으로 설치해주니 당황하지 않습니다 ㅎㅎ
자 이제 nodejs가 제대로 설치가 되었는지 한 번 확인해보겠습니다.
$ node -v
$ npm -v
요로코롬 버전이 확인된다면 깔끔하게 깔린겁니다.
자. 이제 NodeJS를 설치했으니 개발에 앞서 가장 유명한! 프레임워크인 express 프레임워크를 한 번 설치해볼까요 ㅎㅎ
Express framework는 NodeJS와 관련된 것이므로 npm을 이용해 설치를 진행해볼 꺼에요 ㅎㅎ
Express Framework 설치하기
Express도 정말 설치가 느무느무 간단합니다..... 하.... 이렇게 간단해도 되는거니..ㅠㅜ
단 2줄이면 끗!
$ sudo npm install -g express
npm 패키지 관리자를 이용하여 express를 설치해주는데! global(어디서든 express를 사용하겠다!) 옵션을 두고 설치를 진행합니다.
$ sudo npm install -g express-generator@4
이제 설치한 express를 자동으로 생성시켜주는 express-generator를 설치하는데 4.x버전을 설치합니다.
현재(2018.8.1) express 최신버전이 4.16.0버전이네요. ㅎㅎㅎ
express Framework 설치 끗!
설치를 완료했으니 간단히 사용법을 알아볼께요.
Express Framework 사용해보기
http://cinema4dr12.tistory.com/741의 글을 참고하였습니다 ㅎㅎ
Express Framework를 생성하게 되면 막 파일이랑 폴더가 생깁니다.
따라서 Express Framework를 만들고, 작업할 폴더를 하나 만든뒤 들어가줍니다.
$ sudo mkdir express_test
$ cd express_test
그 다음 express 생성!!
$ sudo express -e
하면
위와 같이 파일들이 생성되고 안내 메세지가 나오는 것을 확인할 수 있습니다.
파일의 구조는
이런 식으로 구성이 되어있습니다. ㅎㅎ
가장 기본적으로 http 서버를 하나 동작시키기 위해서는 app.js 파일을 열어 내용을 조금 추가해주면 됩니다.
저는 vs code의 ftp-simple이라는 확장 프로그램을 이용하여 파일을 열었습니다.
ftp-simple 사용 방법도 후에 업로드 진행할께요 ㅎㅎ
vi editor를 이용하여 app.js 파일을 열어 수정하셔도 무방합니다~
파일을 열어 내용 2가지를 추가해줍니다.
빨간색 네모친 부분이 추가해준 내용입니다.
// port setup
app.set('port', process.env.PORT || 3000);
//////////////////////////////////////////////////////
// ------- creates Server -------
module.exports = app;
var server = app.listen(app.get('port'), function() {
console.log('Express server listening on port ' + server.address().port);
});
첫번째는 몇 번 포트로 접근할지를 결정해주는 부분이고
두번째는 해당 포트에 서버를 개설하는 부분입니다.
저장!
그리고 package.json 파일을 약간 수정해줄겁니다.
이렇게 node ./bin/www로 되어있는 부분을 위와같이 수정해줍니다.
이제 거의 다 끝났습니다~
아까 sudo express -e 명령어를 친 폴더에서
$ sudo npm install
를 입력해줍니다.
해당 명령어는 package.json 파일에 입력되어있는 모듈들을 설치해주는 명령어입니다.
만약 추가적으로 module을 다운로드 받아 사용하였다면 위의 명령어를 꼭 실행시켜 주셔야겠죠? ㅎㅎ
자 이제 다 끝났습니다.
$ sudo npm start
을 입력해주면!
Express Server가 3000번 포트에서 동작하고 있다고 뜨네요.
그럼 이제 3000번 포트로 들어가볼까요.
아! 들어가기 전에 localhost라면 상관이 없지만 저같은 경우는 AWS 서버에다가 express 서버를 실행시켰기 때문에 해당 포트로 접속하기 위해서는 방화벽을 해제해줘야 해요.
AWS같은 경우는 해당 인스턴스의 보안그룹으로 들어가 인바운드 -> 편집을 누르게 되면 인바운드 규칙 편집이라는 창이 뜹니다. 거기서 규칙 추가를 누르고
유형 : 사용자 지정 TCP규칙
포트 번호 : 3000 (아까 우리가 설정한 포트 번호)
소스 : 위치 무관
설명 : 아무거나(대신 한글 입력 하면 오류나요 ㅎㅎ)
추가해주면 해당 포트로 접속이 가능합니다.
자 이제 웹브라우저(크롬, internet explorer 등등) 본인의 Public IP주소를 입력해주고 땡땡을 입력한 다음 3000(포트 번호를 입력해주면
Express Framework로 만든 창이 뜨는 것을 확인할 수 있답니드아아앗
본인의 IP 주소:3000
만약 내 컴퓨터가 Ubuntu다! 또는 Virtual Box(or VMWare)에서 만들었다! 그러면 localhost:3000 치면 될거에요 ㅎㅎ
그리고 이렇게 접속을 하고 다시 리눅스 창으로 가보면
이렇게 GET 요청이 들어왔다는 걸 확인할 수 있답니다. ㅎㅎㅎ
(favicon.ico get 요청은 404 error가 떳네요..하핳 무슨 일일까..ㅎ)
이렇게 NodeJS 설치부터 Express Framework를 이용한 아주 초기의 서버 개설까지 마쳤습니다!!!
개발을 어떻게 진행할지는.... 차차 프로젝트 진행해보면서 하나씩 해볼게요 ㅎㅎㅎ(저도 공부하고 있는 입장이라..ㅋ)