Successfully reported this slideshow.
We use your LinkedIn profile and activity data to personalize ads and to show you more relevant ads. You can change your ad preferences anytime.

Node.js 현재와 미래

20,320 views

Published on

한국 웹20주년 국제 콘퍼런스( http://www20.kr/ )에서 발표한 발표자료

Published in: Technology
  • Be the first to comment

Node.js 현재와 미래

  1. 1. Node.js 현재와 미래 2014.10.17 Outsider@www20kr https://www.flickr.com/photos/15216811@N06/6023029145
  2. 2. node.js ! Ryan Dahl ! JSConf.eu 2009 Node.js의 미래를 예측하거나 하진 않습니다. Node.js를 개발하고 앞으로 공부하기 위해 http://www.youtube.com/watch?v=EeYvFl7li9E 도움이 될만한 현재 상태와 앞으로 관심가져야 할 방향에 대한 얘기입니다
  3. 3. node.js ! Ryan Dahl ! JSConf.eu 2009 http://www.youtube.com/watch?v=EeYvFl7li9E
  4. 4. node.js ! Ryan Dahl ! JSConf.eu 2009 node.js가 나온지 5년 지났습니다 http://www.youtube.com/watch?v=EeYvFl7li9E
  5. 5. stable unstable v0.10.x v0.11.x
  6. 6. stable unstable v0.10.x v0.11.x 다음 버전은 0.12.x이고 그 다음에 1.0 이 나올 예정입니다
  7. 7. stable unstable 5년 동안 1.0이 안나왔으니 버전은 상당히 보수적으로 v0.10.x v0.11.x 영하고 있습니다.
  8. 8. 작년 여름에 Issac이 1.0에 대한 계획을 발표했습니다
  9. 9. 조만간 0.12를 발표하고 이어서 1.0을 발표할 것이라는 계획이었습니다
  10. 10. 1년이 지난 이 시점까지도 0.12가 나오지 않았습니다.
  11. 11. node.js 개발이 늦어지는 이유가 무엇일까요.
  12. 12. Ryan Dahl Isaac Z. Schlueter TJ Fontaine
  13. 13. node.js에는 2번의 리더 교체가 있었습니다. Issac이 올 초에 물러나고 TJ Fontaine가 새 리더가 되었습니다. Ryan Dahl Isaac Z. Schlueter TJ Fontaine
  14. 14. node.js의 개발이 늦어지는 이유는 리더와 코어 개발팀이 교체되었고 그 뒤에 코어 개발자의 커밋이 줄어들었습니다 Ryan Dahl Isaac Z. Schlueter TJ Fontaine
  15. 15. TJ Fontain은 올해 Node.js on the road 라는 이름으로 발표를 하며 각 도시에서 커뮤니티를 만나고 있습니다
  16. 16. 코어팀이 바뀌면서 커뮤니티의 의견을 듣고 이를 Node.js개발에 반영하려는 의도로 보입니다
  17. 17. Production Ready?
  18. 18. Ready? Production 가장 많이 받는 질문은 프로덕션에 쓸만한가 이지만 정확한 답은 없습니다
  19. 19. Ready? Production 프로젝트 규모나 성격에 따라 다르고 1.0이 아닌 상황에서 윗사람을 설득하기 어려운 부분은 있습니다
  20. 20. http://nodejs.org/industry/
  21. 21. http://nodejs.org/industry/ 해외에서는 많은 회사에서 node.js를 Production에서 사용하고 있습니다
  22. 22. node.js의 미래는?
  23. 23. Go Language?
  24. 24. Go Language? TJ처럼 Go 언어로 가자는 이야기는 아닙니다
  25. 25. Network Program
  26. 26. Network Program node.js는 네트워크 프로그램을 위해 만들었습니다
  27. 27. Network Program Tools
  28. 28. Network Program Tools node.js를 이용해서 사람들은 도구를 만들기 시작했고 JavaScript이므로 특히 프론트앤드 관련도구가 많이 생겼습니다
  29. 29. Network Program Tools
  30. 30. Network Program Tools Desktop Application
  31. 31. Network Program Tools Desktop Application 많은 시도가 있었지만 지금은 데스크탑 어플리케이션도 만들고 있습니다
  32. 32. Network Program Tools node-webkit Desktop Application
  33. 33. Network Program Tools Desktop Application Robot node-webkit
  34. 34. Network Program Tools Desktop Application Robot node-webkit 최근에는 로봇제어가 큰 이슈로 관련 컨퍼런스도 많이 열리고 있습니다
  35. 35. Node.js v0.12.x
  36. 36. Node.js v0가장. 가1까운2 미래는.x 0.12의 변경사항입니다.
  37. 37. - 클러스터링에 라운드로빈 로드밸런싱 도입 - 한 프로세스 안에서 여러 인스턴스 실행 - Node Inspector로 클러스터 앱의 디버깅 - 성능 최적화(TLS, Crypto, …)
  38. 38. - 클러스터링에 라운드로빈 로드밸런싱 도입 - 한 프로세스 안에서 여러 인스턴스 실행 - Node Inspector로 클러스터 앱의 디버깅 성능 개성 및 기능 강화가 주 내용으로 커다란 기능의 추가는 없습니다 - 성능 최적화(TLS, Crypto, …) v1.0에서도 API는 확정후에 개선을 위주로 개발할 것이라고 발표했습니다.
  39. 39. ES6 Harmony
  40. 40. ES6 Node.js 개발에 차후 크게 신경써야 할 Harmony 부분 중 하나가 ES6 라고 생각합니다 브라우저는 크로스 브라우징 문제로 최신 기능을 쓰기 어렵지만 Node.js에서는 바로 사용할 수 있다
  41. 41. $ node --harmony
  42. 42. $ node --harmony ES6기능을 사용하려면 옵션을 주어야 한다
  43. 43. Block Scope if (true){ let name = ‘www20’; console.log(name); // www20 } ! console.log(name); // ReferenceError: name is not defined
  44. 44. Collection var map1 = new Map(); ! map1.set('name', 'www20kr'); map1.set('date', new Date(‘2014-10-17')); ! map1.get('name'); // ‘www20kr’ map1.get('date'); // Fri Oct 17 2014 09:00:00 GMT+0900 (KST)
  45. 45. Collection var map1 = new Map(); ! var obj = {name: ‘www20kr’); map1.set(obj, 'Congrat'); ! map1.get(obj); // ‘Congrat’
  46. 46. Collection var set1 = new Set(); ! set1.add(1); set1.add(2); set1.add(2); ! set.size; // 2 set1.has(2); // true
  47. 47. Arrow Functions(Lambdas) var t = (x) => x * x; ! t(4) // 16 t(8) // 64
  48. 48. Arrow Functions(Lambdas) db.find(id, function(err, data) { return data; }); ! ! // es6 db.find(id, (err, data) => data);
  49. 49. Callback Hell
  50. 50. var doSomething = function(callback) { somethingAsync(function(err, data) { somethingAsync(function(err, data) { somethingAsync(function(err, data) { somethingAsync(function(err, data) { callback(err, data); }); }); }); }); };
  51. 51. Promise q, bluebird
  52. 52. Promise Promise도 ES6에 포함되어 있습니다 현재 callback hell을 해결하는 접근으로 q, bluebird 많이 사용하고 있습니다
  53. 53. var fs = require(‘fs’); var Q = require(‘q’); ! var readFile = function(file) { var deferred = Q.defer(); fs.readFile(file, function(err, data) { if (err) { return deferred.reject(err); deferred.resolve(data); }); return deferred.promise; }; ! readFile(‘/path/to/file’) .then(function(data) { … }) .catch(function(err) { … });
  54. 54. var fs = require(‘fs’); var Q = require(‘q’); ! var readFile = Q.denodeify(fs.readFile); ! readFile(‘/path/to/file’) .then(function(data) { … }) .catch(function(err) { … });
  55. 55. Generator
  56. 56. Generator 현재는 시작단계이지만 최종적으로는 제너레이터로 갈꺼라고 생각하고 있습니다 물론 정착되기까지는 꽤 시간이 걸릴겁니다
  57. 57. function*
  58. 58. function* inc() { for (var i = 0; i < 5; i++) { yield i; } }
  59. 59. > var index = inc();
  60. 60. > var index = increase(); > index.next(); { value: 0, done: false }
  61. 61. > var index = increase(); > index.next(); { value: 0, done: false } > index.next(); { value: 1, done: false }
  62. 62. > var index = increase(); > index.next(); { value: 0, done: false } > index.next(); { value: 1, done: false } > index.next(); { value: 2, done: false }
  63. 63. > var index = increase(); > index.next(); { value: 0, done: false } > index.next(); { value: 1, done: false } > index.next(); { value: 2, done: false } > index.next(); { value: 3, done: false }
  64. 64. > var index = increase(); > index.next(); { value: 0, done: false } > index.next(); { value: 1, done: false } > index.next(); { value: 2, done: false } > index.next(); { value: 3, done: false } > index.next(); { value: 4, done: false } > index.next(); { value: undefined, done: true }
  65. 65. Thank you. outsideris@gmail.com Twitter: @outsideris

×