Node.js
Node.js에서 진정한 Non-blocking 코드 구현, forAsync 모듈!
InspiredJW
2012. 2. 4. 22:13
Node.js 에서의 장점은 non-blocking 입니다.
하지만 이것이 하기에 따라 오히려 독이 될 수도 있는데요.
blocking 코드를 Node.js 에서 작성하게 되면
Node.js 가 돌아가는 이벤트 루프의 특성상
모든 일이 blocking 코드가 다 할때까지 기다리게 됩니다.
예를 들어
웹 어플리케이션 중간에 이런 부분이 있다면
다른 사람들의 작업은 물론 HTTP 요청마저 받아들이지 못하고
서버가 이 작업 하나 밖에 할 수 없기 때문에 서버가 멈춘 것처럼 되어버립니다.
그래서 이 방법을 해결할 수 있는 방법이
사용하는 원리는 setTimeout 과 비슷하지만 setTimeout보다 벤치마킹 해보면
setTimeout result: 6156ms
nextTick result: 196ms
이렇게 나온다는 얘기가 있군요 ㅎㅎ
일반적으로 DB에서 뭉탱이(?) 를 가져와 하나씩 처리를 해줘야할 때가 있는데
이럴때는 forEach 같은 명령어를 써서 여러 데이터를 하나 하나씩 parsing 해줘야 합니다.
간단한 for loop 부터 forEach loop을 non-blocking 으로 구현한 모듈을 제가 하나 만들었습니다.
이 process.nextTick을 이용한건데요.
바로 forAsync 입니다!
설치는 npm install forAsync 해주시고
이렇게 Node.js 소스 상단에 배치하면 사용가능합니다.
사용방법 또한 간단합니다!
up 은
For Loop을 돌리면서 숫자가 커지는 경우 시작하는 숫자 0, 목표 10, 증가 숫자 1, 그리고
하고 싶은 일을 그 다음 함수에서 하시면 됩니다.
물론 i 값을 이용해서 반복되는 배열이나 객체에 접근할 수 있습니다.
down 은
up과 다른 점은 숫자가 큰 숫자에서 작은 숫자로 줄어드는 것 뿐입니다.
forEach 는
객체를 그대로 forEach 함수에 넣고 그 다음 함수에서 key, value 를 인자로 받아서
하고 싶은 일을 하실 수 있습니다.
마지막으로 이 세 함수 모두 다 콜백 함수를 가지고 있어서 이 함수가 작업을 마치고
하고 싶은 일은 콜백 함수 안에다가 정의해주시면 됩니다.
하지만 이것이 하기에 따라 오히려 독이 될 수도 있는데요.
blocking 코드를 Node.js 에서 작성하게 되면
Node.js 가 돌아가는 이벤트 루프의 특성상
모든 일이 blocking 코드가 다 할때까지 기다리게 됩니다.
예를 들어
for(var i=0; i<10000; i++) { // Some heavy works }이와 같이 무거운 작업을 10000번을 한다고 하면
웹 어플리케이션 중간에 이런 부분이 있다면
다른 사람들의 작업은 물론 HTTP 요청마저 받아들이지 못하고
서버가 이 작업 하나 밖에 할 수 없기 때문에 서버가 멈춘 것처럼 되어버립니다.
그래서 이 방법을 해결할 수 있는 방법이
process.nextTick( callback );process.nextTick 입니다.
사용하는 원리는 setTimeout 과 비슷하지만 setTimeout보다 벤치마킹 해보면
setTimeout result: 6156ms
nextTick result: 196ms
이렇게 나온다는 얘기가 있군요 ㅎㅎ
일반적으로 DB에서 뭉탱이(?) 를 가져와 하나씩 처리를 해줘야할 때가 있는데
이럴때는 forEach 같은 명령어를 써서 여러 데이터를 하나 하나씩 parsing 해줘야 합니다.
간단한 for loop 부터 forEach loop을 non-blocking 으로 구현한 모듈을 제가 하나 만들었습니다.
이 process.nextTick을 이용한건데요.
바로 forAsync 입니다!
설치는 npm install forAsync 해주시고
var forAsync = require('forAsync');
이렇게 Node.js 소스 상단에 배치하면 사용가능합니다.
사용방법 또한 간단합니다!
//Upward Loop Function forAsync.up( 0, 10, 1, function(i) { // Do something }, function() { // callback }); // Downward Loop Function forAsync.down( 10, 1, 2, function(i) { // Do something }, function() { // callback }); // forEach Loop Function forAsync.forEach( Array, function(k, v) { // Do something }, function() { // callback });보시는 바와 같이
up 은
For Loop을 돌리면서 숫자가 커지는 경우 시작하는 숫자 0, 목표 10, 증가 숫자 1, 그리고
하고 싶은 일을 그 다음 함수에서 하시면 됩니다.
물론 i 값을 이용해서 반복되는 배열이나 객체에 접근할 수 있습니다.
down 은
up과 다른 점은 숫자가 큰 숫자에서 작은 숫자로 줄어드는 것 뿐입니다.
forEach 는
객체를 그대로 forEach 함수에 넣고 그 다음 함수에서 key, value 를 인자로 받아서
하고 싶은 일을 하실 수 있습니다.
마지막으로 이 세 함수 모두 다 콜백 함수를 가지고 있어서 이 함수가 작업을 마치고
하고 싶은 일은 콜백 함수 안에다가 정의해주시면 됩니다.