Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Introduction to NodeJS
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
uictechparty
July 01, 2012
Programming
1
210
Introduction to NodeJS
By Zelong Liang, 1st TechParty@UIC
uictechparty
July 01, 2012
Tweet
Share
More Decks by uictechparty
See All by uictechparty
产品经理是做什么的呢?
uictechparty
1
220
找人
uictechparty
3
470
香港研究生申请经验分享
uictechparty
0
410
css.pdf
uictechparty
1
220
Introduction to Design Patterns
uictechparty
2
150
编写高质量Java代码的7个建议
uictechparty
2
190
视觉障碍出行辅助仪 -The Third Eye
uictechparty
1
120
jQuery 快速入门
uictechparty
1
150
Introduction to Hadoop
uictechparty
3
230
Other Decks in Programming
See All in Programming
Basic Architectures
denyspoltorak
0
660
例外処理とどう使い分ける?Result型を使ったエラー設計 #burikaigi
kajitack
16
6k
Oxlint JS plugins
kazupon
1
810
16年目のピクシブ百科事典を支える最新の技術基盤 / The Modern Tech Stack Powering Pixiv Encyclopedia in its 16th Year
ahuglajbclajep
5
990
Fluid Templating in TYPO3 14
s2b
0
130
AIで開発はどれくらい加速したのか?AIエージェントによるコード生成を、現場の評価と研究開発の評価の両面からdeep diveしてみる
daisuketakeda
1
970
プロダクトオーナーから見たSOC2 _SOC2ゆるミートアップ#2
kekekenta
0
200
AI によるインシデント初動調査の自動化を行う AI インシデントコマンダーを作った話
azukiazusa1
1
700
The Past, Present, and Future of Enterprise Java
ivargrimstad
0
510
AIエージェント、”どう作るか”で差は出るか? / AI Agents: Does the "How" Make a Difference?
rkaga
4
2k
Architectural Extensions
denyspoltorak
0
280
20260127_試行錯誤の結晶を1冊に。著者が解説 先輩データサイエンティストからの指南書 / author's_commentary_ds_instructions_guide
nash_efp
0
930
Featured
See All Featured
How to make the Groovebox
asonas
2
1.9k
The #1 spot is gone: here's how to win anyway
tamaranovitovic
2
930
Build The Right Thing And Hit Your Dates
maggiecrowley
38
3k
How GitHub (no longer) Works
holman
316
140k
Leadership Guide Workshop - DevTernity 2021
reverentgeek
1
200
Groundhog Day: Seeking Process in Gaming for Health
codingconduct
0
91
エンジニアに許された特別な時間の終わり
watany
106
230k
Making the Leap to Tech Lead
cromwellryan
135
9.7k
BBQ
matthewcrist
89
10k
Thoughts on Productivity
jonyablonski
74
5k
Fantastic passwords and where to find them - at NoRuKo
philnash
52
3.6k
How to train your dragon (web standard)
notwaldorf
97
6.5k
Transcript
Node.js
Who am I? • @龙mol_才不是小眼睛
Introduction • Node.js是什么? • Node.js的优势与特点是什么? – 什么是V8引擎 – 什么是非阻塞模式 •
Node.js能解决什么问题? • Node.js实践?
Node.js是什么 • Node.JS 是资深 C 程序员 Ryan Dahl的作 品,依据 Google
著名的开源 JavaScript 引擎 V8 来进行二次开发的 Web I/O 服务 器 • 轻量级WebServer • 脱离了浏览器在后端运行的Javascript代码 • 运行坏境、库
优势与特点 • 单进程(single-thread) • 异步非阻塞(non-blocking) • 事件驱动(event-based) • V8引擎 •
性能很好 • 第三方模块丰富 • 速度、灵活
V8引擎 • V8是一个由丹麦Google开 发的开源JavaScript引 擎,用于Google Chrome 中。 • V8在执行之前将 JavaScript编译成了机器
码,而非字节码或是直译 它,以此提升效能。并且 使用了如内联缓存(inline caching)等方法来提高性 能。 • 有了这些功能, JavaScript程序与V8引擎 的速度媲美二进制编译。
非阻塞模式 • 在非阻塞模式下利用socket事件的消息机 制,Server端与Client端之间的通信处于异 步状态。 • 通常需要从CSocket类派生一个新类,派生 新类的目的是重载socket事件的消息函数, 然后在socket事件的消息函数中添入合适的 代码以完成Client端与Server端之间的通信。
• 与阻塞模式相比,非阻塞模式无需创建一 个新线程。
性能 • Python:Tornado • Go • Java:Netty • Nodejs
None
None
None
None
None
None
第三方模块 • 官方共收集列出1152个第三方模块! – 涵盖了Web、Database、XML、Web Sockets & Ajax、API clients、TCP/IP、CSS Enginess
等等,几乎涉及网络开发中需要的功能模块。 管理工具:npm 管理着4427+模块,想用哪个用哪个,妈妈在也 不用担心我没有模块用!
Node.js能解决什么问题 • Node 公开宣称的目标是 “旨在提供一种简 单的构建可伸缩网络程序的方法”。
E.g. • 在 Java™ 和 PHP 这类语言中,每个连接 都会生成一个新线程,每个新线程可能需 要 2
MB 的配套内存。在一个拥有 8 GB RAM 的系统上,理论上最大的并发连接数 量是 4,000 个用户。随着您的客户群的增 长,如果希望您的 Web 应用程序支持更多 用户,那么,您必须添加更多服务器。当 然,这会增加服务器成本、流量成本和人 工成本等成本。 • 瓶颈是:服务器能够处理的并发连接的最 大数量。
A • 解决这个问题的方法是:更改连接到服务 器的方式。每个连接发射一个在 Node 引擎 的进程中运行的事件,而不是为每个连接 生成一个新的 OS 线程(并为其分配一些
配套内存)。Node 声称它绝不会死锁,因 为它根本不允许使用锁,它不会直接阻塞 I/O 调用。Node 还宣称,运行它的服务器 能支持数万个并发连接。
Node.js实践 • 不受限制地访问文件和网络资源 • 前后端代码复用 • 解决跨域访问的问题
常规Web应用
实时性强的网络应用
实时性强的网络应用
Q&A
Thanks!