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
Hono - Ultrafast web framework for Cloudflare W...
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
Yusuke Wada
November 26, 2022
Programming
8.6k
3
Share
Hono - Ultrafast web framework for Cloudflare Workers, Deno, Bun, and Node.js
Yusuke Wada 2022.11.26 JSConf JP
Yusuke Wada
November 26, 2022
More Decks by Yusuke Wada
See All by Yusuke Wada
飯MCP
yusukebe
0
480
へんな働き方
yusukebe
6
2.9k
Cap'n Webについて
yusukebe
0
270
OSS開発者の憂鬱
yusukebe
16
18k
r2-image-worker
yusukebe
1
250
Introduce Hono CLI
yusukebe
6
3.9k
私はどうやって技術力を上げたのか
yusukebe
47
21k
Reactをクライアントで使わない
yusukebe
8
7k
AI時代のUIはどこへ行く?
yusukebe
23
12k
Other Decks in Programming
See All in Programming
Migration to Signals, Signal Forms, Resource API, and NgRx Signal Store @Angular Days 03/2026 Munich
manfredsteyer
PRO
0
230
AI-DLC 入門 〜AIコーディングの本質は「コード」ではなく「構造」〜 / Introduction to AI-DLC: The Essence of AI Coding Is Not “Code” but “Structure”
seike460
PRO
0
220
車輪の再発明をしよう!PHP で実装して学ぶ、Web サーバーの仕組みと HTTP の正体
h1r0
3
500
ポーリング処理廃止によるイベント駆動アーキテクチャへの移行
seitarof
3
1.3k
脱 雰囲気実装!AgentCoreを良い感じにWEBアプリケーションに組み込むために
takuyay0ne
3
430
Radical Imagining - LIFT 2025-2027 Policy Agenda
lift1998
0
230
PHP でエミュレータを自作して Ubuntu を動かそう
m3m0r7
PRO
2
170
メッセージングを利用して時間的結合を分離しよう #phperkaigi
kajitack
3
550
GoのDB アクセスにおける 「型安全」と「柔軟性」の両立 - Bob という選択肢
tak848
0
310
Goの型安全性で実現する複数プロダクトの権限管理
ishikawa_pro
2
1.4k
RSAが破られる前に知っておきたい 耐量子計算機暗号(PQC)入門 / Intro to PQC: Preparing for the Post-RSA Era
mackey0225
3
120
Symfonyの特性(設計思想)を手軽に活かす特性(trait)
ickx
0
120
Featured
See All Featured
SEO in 2025: How to Prepare for the Future of Search
ipullrank
3
3.4k
Cheating the UX When There Is Nothing More to Optimize - PixelPioneers
stephaniewalter
287
14k
We Analyzed 250 Million AI Search Results: Here's What I Found
joshbly
1
1.1k
Building a Modern Day E-commerce SEO Strategy
aleyda
45
9k
Measuring & Analyzing Core Web Vitals
bluesmoon
9
800
Primal Persuasion: How to Engage the Brain for Learning That Lasts
tmiket
0
310
WCS-LA-2024
lcolladotor
0
510
Joys of Absence: A Defence of Solitary Play
codingconduct
1
330
The Director’s Chair: Orchestrating AI for Truly Effective Learning
tmiket
1
140
Intergalactic Javascript Robots from Outer Space
tanoku
273
27k
Build The Right Thing And Hit Your Dates
maggiecrowley
39
3.1k
Design of three-dimensional binary manipulators for pick-and-place task avoiding obstacles (IECON2024)
konakalab
0
390
Transcript
Yusuke Wada 2022.11.26 JSConf JP Hono Ultrafast web framework for
Cloud fl are Workers, Deno, Bun, and Node.js
Me • Yusuke Wada • Supervisor at TravelBook Inc. •
Web developer, Web framework developer • https://yusukebe.com/ • https://github.com/yusukebe 2
Today's topics • Core concepts of Hono 1. Multi-runtimes 2.
Ultrafast 3. Middleware 4. Experience 3
Hono in 1min. 4
Initial Commit • 2021-12-15 5
Star History 6
Who is using Hono • cdnjs API Server • Drivly
- Commerce infrastructure for the automotive industry • Ultra - Zero-Legacy Deno/React Suspense SSR Framework • Deno cli/bench/http 7
Workers Launchpad 8 ref: https://blog.cloud fl are.com/launchpad-fall-22/
Deno benchmarks 9 https://deno.land/benchmarks
Concept 1 Multi-runtimes 10
Hono works on... • Cloud fl are Workers / workerd
• Vercel Edge Runtime • Fastly Compute@Edge • Deno • Bun • Node.js • and more... 11
The same code runs on all platforms 12
Cloudflare Workers and Bun
Fastly Compute@Edge and Vercel Edge Runtime
Deno
Node.js
Thanks to Web standards • Zero-dependencies / No poly fi
ll • Web-interoperable Runtimes will be powered by WinterCG 17
Cloudflare Workers 18 ref: https://developers.cloud fl are.com/workers/runtime-apis/
Deno 19 ref: https://deno.land/
[email protected]
/runtime/web_platform_apis
Bun 20 ref: https://github.com/oven-sh/bun#Reference
Node.js 21 ref: https://github.com/honojs/node-server • Using `@remix-run/web-fetch`
context.ts 22 Discussion in WinterCG => https://github.com/wintercg/runtime-keys/pull/2
Great 👍 23
Concept 2 Ultrafast 24
Cloudflare Workers 25 ref: https://github.com/honojs/hono/tree/main/benchmarks/handle-event
Deno 26 ref: https://github.com/denosaurs/bench
Bun 27 ref: https://github.com/SaltyAom/bun-http-framework-benchmark
Node.js • Fastify • Reqs/sec 63417.00 5358.22 67487.06 • Express
• Reqs/sec 20709.94 1683.03 23045.34 • Hono with @honojs/node-server • Reqs/sec 32054.95 2642.04 35583.36 28
Node.js - router 29 Decode URI, Handle Query strings Does
not support regexp Does not support regexp
Why so fast? 30
3+1 Routers 1. StaticRouter • Fastest, supports only static routes.
2. RegExpRouter • Faster, supports almost routes. 3. TrieRouter • Slowest, supports all routes. But it's faster than other routers in the world. 31
"Linear" router 32
ref: https://github.com/yusukebe/pico
TrieRouter • Using Trie Tree structure • Support all patterns
34
None
RegExpRouter • Match the route with using one big Regex
made before dispatch. • By @usualoma • https://speakerdeck.com/usualoma/ultrafast-js-router 36
37
StaticRouter • Optimized for static routings • Does not support
dynamic routings such as "path parameters" 38
None
SmartRouter • The default router • Automatically picks the best
router from the three routers. 40 • StaticRouter • RegExpRouter • TrieRouter
Great 👍 41
Concept 3 Middleware 42
Small core • hono.ts • context.ts • compose.ts • request.ts
43 Basic app with Wrangler: Total Upload: 34.15 KiB / gzip: 8.26 KiB
Three types of Middleware • Built-in Middleware - including the
package • Custom Middleware - created by the users • Third-party Middleware - depends on external libraries 44
Built-in Middleware • Basic Auth • Bearer Auth • Cache
• Compress • CORS • Etag • html • JSX • JWT Auth • Logger • Pretty JSON • Serve Static • Validator 45
JSX Middleware 46
Validator Middleware 47
Custom Middleware 48
Third-party Middleware 49 • GraphQL Server • Firebase Auth •
Sentry • tRPC (?) ref: https://github.com/honojs/hono/issues/582
Great 👍 50
Concept 4 Experience 51
TypeScript • Wrangler, Deno, and Bun fi rst-class support TypeScript.
52
Path parameters 53
Validator Middleware 54
Easy to write tests • With `jest-environment-mini fl are` •
We can do test `Request` to `Response` 55
Great 👍 56
Example: Blog 57
import 58
Model 59
Logic 60
JSX 61
GET / 62
POST /post 63
Use cases in the real world 64
With Cloudflare R2 65 • github.com/yusukebe/r2-image-worker • Store and Deliver
images with R2 backend Cloud fl are Workers. ref: https://github.com/yusukebe/r2-image-worker
With Cloudflare D1 66 ref: https://blog.cloud fl are.com/making-static-sites-dynamic-with-cloud fl are-d1/
Cache control 67 ref: https://yusukebe.com/posts/2022/wsh/
Express alternative on Bun 68
Feature plans 69
Ecosystem • For Third-party Middleware • monorepo • API specs
as Types • tRPC like, but integrated 70
API specs as Types 71 ref: https://github.com/honojs/hono/issues/582
And... 72
Going to Standard web framework for Web standards 73
One more thing 74
Pico 75 Pico is ultra-tiny (about 1kB) web framework using
URLPattern. Pico works on Cloud fl are Workers and Deno. Pico is compatible with Hono.
Love 76
Thanks • Thanks to all contributors, all supporters, and all
users!! 77
Try Hono! 78 https://honojs.dev