728x90
node.js 는 구글의 크롬(Chrome) 브라우저가 채택하고 있는 자바스크립트 엔진인 V8 을 기반으로 하고 있다. node.js 개발 환경을 설치한다는 것은 V8 엔진을 설치하고 V8 을 통해 자바스크립트를 브라우저를 통하지 않고도 실행할 수 있다는 것을 의미한다. 현재 제공되고 있는 설치 패키지는 윈도우(Windows) 플랫폼과 맥(Mac) 플랫폼이다. 하지만 github를 통해 소스코드를 제공하고 있고 다양한 리눅스 배포판별로 설치 방법을 가이드 하고 있으니 사실상 제한이 없다고 봐도 되겠다

 
node.js 설치파일을 받기 위해서는 공식 웹사이트인 http://nodejs.org 를 방문하여 가운데 있는 Download 링크를 누르면 된다. NoPD 는 윈도우 플랫폼을 사용하고 있기 때문에 윈도우용 MSI 설치 패키지를 받아서 설치했다. 개발 환경이라고는 하지만 커맨드 라인 기반의 인터페이스를 제공하고 있기 때문에 용량이 그리 크지 않다.
 

윈도우 환경에서 기본 설정으로 node.js 를 설치하고 나면 Program Files 폴더 아래에 nodejs 경로에 node.js 의 관련 파일들이 설치된다. 이미 이야기한 것처럼 node.js 의 구조는 무척 간단하다. 엔진 및 커맨드라인 인터페이스인 node.exe 파일이 있고 node.js 가 제공하는 모듈들은 자바스크립트로 작성되어 node_modules 폴더 아래에 깨알같이 분산되어 있다.

node.js 가 설치된 폴더의 구석구석을 살펴보면 자바스크립트로 만들어진 깨알같은 소스코드들이 많이 들어 있어서 참고하기에 무척 좋다. node.js 를 꼭 사용하지 않더라도 브라우저 기반으로 자바스크립트를 구동시킬 때 참고할만한 소스코드들이 무척 많으니 천군만마를 얻은 것 같은 기분이다. 이러한 구조를 참고하여 나중에 개인적인 모듈을 만들때 많은 도움을 받을 수 있으니 시간이 되면 살펴보는 것도 좋을 것 같다.

 
node.js 가 제공하는 다양한 기능들을 제대로 활용하기 위해서는 기술문서를 꼼꼼히 읽어보는 것이 좋다. node.js 의 공식 웹사이트가 제공하고 있는 Document 를 참고하면 node.js 의 어떤 요소들을 활용하여 무엇을 개발할 수 있을지 생각하는데 큰 도움이 된다. node.js 로 개발을 진행하는 동안 가장 도움을 많이 받을 기술 레퍼런스이니 항상 다른 창으로 띄워 놓도록 하자.

이번 포스팅을 그냥 이렇게 마무리 할까 하다가... 소스코드 한줄 정도는 만들어 봐야 하지 않을까 싶어서 모든 개발 환경의 기본 테스트이자 가장 많은 의미를 갖는 샘플, "Hello World" 를 출력하는 방법을 살펴보고 글을 마무리 할까 한다. 일단 첫번째 방법으로 무작정 설치 경로에 위치한 node.exe 를 실행해 보자. ">" 프롬프트가 뜨면서 뭔가를 입력하라는 화면이 휑~ 하니 출력된다. 변수 하나에 문자열을 집어넣고 console.log 메소드를 이용하여 콘솔 화면에 출력하는 간단한 소스를 입력해 보자.

 
첫번째 방법은 코드를 간단히 테스트 해볼때 사용하기 좋은 방법이다. 이 화면을 보고 혹시 크롬 브라우저의 개발자 기능중 콘솔 기능이 떠올랐다면 정확히 본 것이다. node.js 가 하는 일이라는 것이 결국 자바스크립트 엔진으로 자바스크립트 소스를 보내고 수행한뒤 결과를 리턴하는 것이라는 이해를 하면 그것으로 충분하다.

하지만 첫번째 방법은 실무에서 쓰기에는 별로 좋은 방법은 아니다. 간단한 디버깅이나 소스코드의 동작을 확인하는 용도 정도일 뿐이다. 우리가 원하는 방식은 별도로 소스코드를 만들어 이를 실행하는 방식일 것이다. 귀차니즘으로 에디터 쓰는 것도 번거로우니 커맨드 라인에서 간단히 소스코드를 만들고 실행을 해보도록 하자. 

 
자바스크립트 기반이기 때문에 확장자는 .js 를 일반적으로 붙여주지만 사람에 따라서는 .node 를 붙여 주기도 한다. 두가지 확장자를 쓰는 경우에 한하여 node.js 는 알아서 해당 파일을 찾아 실행을 해주니 별도의 확장자를 쓰기 보다는 .js, .node 를 이용하는 것이 좋다. 오늘 포스팅에서는 node.js 개발 환경을 설치하고 간단한 소스코드를 실행해 봤다. 다음 포스팅에서는 몇가지 쉬운 코드를 이용하여 node.js 가 기본적으로 제공하는 모듈을 사용해 보도록 하자.


- NoPD - 
728x90
728x90
요즘 가장 핫(Hot)한 개발 트렌드는 무엇일까? 사람에 따라서 가장 관심있는 개발 기술이 다를 것이기 때문에 어떤 것이 가장 관심을 받고 있다고 잘라 말하기는 애매하다. 하지만 일반적인 개발 생태계 전체를 놓고 보면 눈에 띄는 것들이 몇몇 있다. 마이크로소프트가 열심히 밀고 있는 윈도폰, 윈도8을 위한 메트로 스타일(Metro Style) 개발이 그 중 하나일 것이다. 스마트 디바이스를 위한 개발은 여전히 아이폰과 Objective-C 가 가장 뜨거운 관심을 받고 있다. 

그렇다면 웹 개발 영역에서는 어떤 것이 가장 핫한 개발 트렌드 일까? HTML5 나 CSS3 를 이야기 하는 사람들이 많을 것이다. 하지만 개인적으로는 그 보다도 자바스크립트, 더 정확하게는 node.js 가 사람들이 가장 관심을 많이 갖고 있는 웹 개발 영역에서의 아이템일 것 같다.

node.js 가 도대체 뭘까?

node.js 는 뒤에 붙은 접미사가 .js 라는 것으로 미루어 보아 분명 자바스크립트(JavaScript)와 관련된 무언가라고 추측할 수 있을 것이다. 그러면 혹시 jQuery 처럼 클라이언트 사이드의 자바스크립트 라이브러리일까? 그건 그렇지 않다. node.js 는 클라이언트에도 사용될 수 있지만 그것은 제공되는 기능의 일부일 뿐이다. node.js 가 만들어진 주 목적은 바로 서버측에서 구동되는 자바스크립트 개발 환경을 위해서이다.

 
많은 사람들에게 자바스크립트는 브라우저에서 구동되며 웹 사이트에서 다양한 클라이언트단에서 프로그래밍적인 요소가 필요한 상황에서 사용되는 클라이언트 사이드(Client-side) 언어일 것이다. 그런데 쌩뚱맞게도 node.js 는 서버에서 구동되는 개발 환경이라니 이게 무슨 소리인가 싶을지도 모르겠다.

이 글을 읽고 있는 사람이라면 ASP.NET, JSP, PHP 와 같은 서버 사이드(Server-side) 스크립트에 대해서 잘 알고 있을 것이다. 서버 사이드 스크립트는 서버에서 구동되어 동적인 컨텐츠를 만들어 내어 클라이언트(보통 브라우저)에게 전달하는 역할을 하게 된다. 컨텐츠 전달의 중간에는 웹 서버(Web Server), 웹 어플리케이션 서버(Web Application Server)가 있다는 것은 길게 설명할 필요가 없을 것이다.

node.js 를 요약해서 이야기 하자면 웹 서버 혹은 웹 어플리케이션 서버이면서 동시에 서버 사이드 스크립트의 역할도 하는 자바스크립트 기반의 서버 개발 환경이다. 어떻게 자바스크립트가 서버에서 구동되고 쓰이게 되는지에 대해서는 더 자세한 이야기를 기술해 놓은 곳들이 많으니 한번 찾아보면 좋을 것 같다. 중요한 것은 자바스크립트 엔진의 발달로 자바스크립트의 구동속도가 서버에서 쓰일 수 있을 만큼 빨라졌고 오히려 그 간결함과 익숙함, 효율성을 통해 생각치 못했던 더 많은 것을 할 수 있다는 것이다.

[ node.js 관련 참고 URL ]
- node.js 공식 웹사이트 : http://nodejs.org 

- node.js 관련 추천 도서 : "모던 웹을 위한 node.js 프로그래밍" (한빛미디어) [바로가기]  


다음 포스팅에서는 node.js 를 윈도우 환경에서 직접 설치해 보고 간단한 샘플 코드를 통해서 node.js 를 통한 개발이 얼마나 쉬운지 한번 살펴보는 시간을 갖도록 하겠다.

- NoPD -
728x90

+ Recent posts