SlideShare a Scribd company logo
1 of 59
Download to read offline
HTTP/2 
더 빠른 웹을 위해 
14년 10월 21일 화요일
발표자 소개 
• 이응준 
• NAVER LABS에서 서버사이드 웹 프로그래머로 근무중 
• 책 HTTP: The Definitive Guide 번역중 
14년 10월 21일 화요일
오늘 이야기할 것 
• HTTP/2는 
• 왜 만들었나 
• 왜 빠른가 
14년 10월 21일 화요일
왜 만들었나 
14년 10월 21일 화요일
왜 만들었나 
• HTTP/1이 너무 느려서 
14년 10월 21일 화요일
HTTP/1은 왜 느린가 
• HTTP/1의 동작: 
• 클라이언트가 서버에 요청을 보낸다. 
• 서버가 클라이언트에게 그에 대한 응답을 보낸다. 
• 대역폭과 상관없이 round trip 때문에 느려짐 
14년 10월 21일 화요일
HTTP/1은 왜 느린가 
• 요청이 갔다가 응답이 돌아오는데 걸리는 시간 
• 서울 <=> 춘천: 8ms 
• 서울 <=> 일본: 35ms 
• 서울 <=> 뉴욕: 200ms 
• 지구 <=> 화성: 8분 ~ 48분 
14년 10월 21일 화요일
태초의 HTTP 
HTML x 1 
PNG x 20 
14년 10월 21일 화요일
태초의 HTTP 
• TCP 커넥션 수립 (3-way handshake) 
• HTML 파일 1개 가져옴 
• TCP 커넥션 닫음 
• TCP 커넥션 수립 (3-way handshake) 
• PNG 파일 1개 가져옴 
• TCP 커넥션 닫음 
20번 반복 
14년 10월 21일 화요일
태초의 HTTP 
• TCP 커넥션 수립 (3-way handshake) 
• HTML 파일 1개 가져옴 
• TCP 커넥션 닫음 
• TCP 커넥션 수립 (3-way handshake) 
• PNG 파일 1개 가져옴 
• TCP 커넥션 닫음 
42 RTT 
20번 반복 
14년 10월 21일 화요일
HTTP/1.0+ (KEEP-ALIVE) 
• TCP 커넥션 수립 (3-way handshake) 
• HTML 파일 1개 가져옴 
• PNG 파일 1개 가져옴 (20번 반복) 
14년 10월 21일 화요일
HTTP/1.0+ (KEEP-ALIVE) 
• TCP 커넥션 수립 (3-way handshake) 
• HTML 파일 1개 가져옴 
• PNG 파일 1개 가져옴 (20번 반복) 
22 RTT 
14년 10월 21일 화요일
PARALLEL CONNECTIONS 
• TCP 커넥션 수립 (3-way handshake) 
• HTML 파일 1개 가져옴 
• TCP 커넥션 7개 더 수립 (3-way handshake) 
• PNG 파일 8개 가져옴 
• PNG 파일 8개 더 가져옴 
• PNG 파일 4개 더 가져옴 
14년 10월 21일 화요일
PARALLEL CONNECTIONS 
• TCP 커넥션 수립 (3-way handshake) 
• HTML 파일 1개 가져옴 
• TCP 커넥션 7개 더 수립 (3-way handshake) 
• PNG 파일 8개 가져옴 
• PNG 파일 8개 더 가져옴 
• PNG 파일 4개 더 가져옴 
6 RTT 
14년 10월 21일 화요일
PIPELINING 
• TCP 커넥션 수립 (3-way handshake) 
• HTML 파일 1개 가져옴 
• PNG 파일 20개 가져옴 
14년 10월 21일 화요일
PIPELINING 
• TCP 커넥션 수립 (3-way handshake) 
• HTML 파일 1개 가져옴 
• PNG 파일 20개 가져옴 
3 RTT 
14년 10월 21일 화요일
PIPELINING 
• TCP 커넥션 수립 (3-way handshake) 
• HTML 파일 1개 가져옴 
• PNG 파일 20개 가져옴 
구현이 어려워서 
잘 안씀! 
14년 10월 21일 화요일
HTTP/1은 왜 느린가 2 
• 헤더가 너무 큼 (특히 쿠키) 
14년 10월 21일 화요일
성능 개선을 위한 많은 노력들 
• HTTP-NG 프로젝트 (1997) 
• Roy Fielding이 WAKA 제안 
• S+M(Speedy+Mobility, 마이크로소프트) 
• SPDY (구글, 2009) 
14년 10월 21일 화요일
HTTP/2 
• HTTP 작업그룹이 SPDY를 기반으로 HTTP/2 작업 시작 
(2012년 10월) 
14년 10월 21일 화요일
HTTP/2는 왜 빠른가 
•Header Compression 
•Multiplexed Streams 
•Server Push 
•Stream Priority 
14년 10월 21일 화요일
HEADER COMPRESSION 
•Huffman Coding 
•Header Tables 
14년 10월 21일 화요일
HEADER COMPRESSION 
서버가 헤더 “date:Mon, 21 Oct 2013 
20:13:21 GMT”를 클라이언트에게 전송 
date:Mon, 21 Oct 2013 20:13:21 GMT C S 
14년 10월 21일 화요일
HEADER COMPRESSION 
서버가 헤더 “date:Mon, 21 Oct 2013 
20:13:21 GMT”를 클라이언트에게 전송 
C S 
..date..z...T.D. .....f...-.. 
헤더값에 Huffman Coding 
적용: 34 => 29 
14년 10월 21일 화요일
HEADER COMPRESSION 
서버가 헤더 “date:Mon, 21 Oct 2013 
C 20:13:21 GMT”를 클라이언트에게 전송 
S ..date..z...T.D. .....f...-.. 
Index Header Name Header Value 
1 :authority 
... ... ... 
33 date 
... ... ... 
61 www-authenticate 
Static Table 
Index Header Name Header Value 
Dynamic Table 
14년 10월 21일 화요일
HEADER COMPRESSION 
서버가 헤더 “date:Mon, 21 Oct 2013 
C 20:13:21 GMT”를 클라이언트에게 전송 
S ....z...T.D. .....f...-.. 
Index Header Name Header Value 
1 :authority 
... ... ... 
33 date 
... ... ... 
61 www-authenticate 
Static Table 
Index Header Name Header Value 
Dynamic Table 
헤더 이름을 Static Table 
인덱스로 대체: 29 => 24 
14년 10월 21일 화요일
HEADER COMPRESSION 
서버가 헤더 “date:Mon, 21 Oct 2013 
C 20:13:21 GMT”를 클라이언트에게 전송 
S ....z...T.D. .....f...-.. 
Index Header Name Header Value 
1 :authority 
... ... ... 
33 date 
... ... ... 
61 www-authenticate 
Static Table 
Index Header Name Header Value 
62 date 
Mon, 21 Oct 
2013 20:13:21 
GMT 
Dynamic Table 
14년 10월 21일 화요일
HEADER COMPRESSION 
서버가 헤더 “date:Mon, 21 Oct 2013 
C 20:13:21 GMT”를 클라이언트에게 “또” 전송 
S 
Index Header Name Header Value 
1 :authority 
... ... ... 
33 date 
... ... ... 
61 www-authenticate 
Static Table 
Index Header Name Header Value 
62 date 
Mon, 21 Oct 
2013 20:13:21 
GMT 
Dynamic Table 
14년 10월 21일 화요일
HEADER COMPRESSION 
서버가 헤더 “date:Mon, 21 Oct 2013 
C 20:13:21 GMT”를 클라이언트에게 “또” 전송 
S 
Index Header Name Header Value 
1 :authority 
... ... ... 
33 date 
... ... ... 
61 www-authenticate 
Static Table 
Index Header Name Header Value 
62 date 
Mon, 21 Oct 
2013 20:13:21 
GMT 
Dynamic Table 
. 
헤더 필드를 Dynamic Table 
인덱스로 대체: 24 => 1 
14년 10월 21일 화요일
MULTIPLEXED STREAMS 
한 커넥션으로 동시에 여러 
메시지를 주고 받을 수 있음 
14년 10월 21일 화요일
MULTIPLEXED STREAMS 
HTML x 1 
PNG x 20 
Max Connections: 8 
14년 10월 21일 화요일
MULTIPLEXED STREAMS 
• HTTP/1.1 
• TCP 커넥션 1개를 열고 
• HTML 문서 1개를 요청해서 받음 
• TCP 커넥션 7개를 더 열고 
• PNG 파일 8개를 요청해서 받음 
• PNG 파일 8개를 더 요청해서 받음 
• PNG 파일 4개를 더 요청해서 받음 
14년 10월 21일 화요일
MULTIPLEXED STREAMS 
• HTTP/1.1 
• TCP 커넥션 1개를 열고 
• HTML 문서 1개를 요청해서 받음 
• TCP 커넥션 7개를 더 열고 
• PNG 파일 8개를 요청해서 받음 
• PNG 파일 8개를 더 요청해서 받음 
• PNG 파일 4개를 더 요청해서 받음 
• HTTP/2 
• TCP 커넥션 1개를 열고 
• HTML 문서 1개를 요청해서 받음 
• PNG 파일 20개를 요청해서 받음 
14년 10월 21일 화요일
MULTIPLEXED STREAMS 
C S 
14년 10월 21일 화요일
MULTIPLEXED STREAMS 
GET /a.png 
GET /b.png 
GET /c.png 
... 
C S 
14년 10월 21일 화요일
MULTIPLEXED STREAMS 
1: GET /a.png 
3: GET /b.png 
5: GET /c.png 
... 
C 1 3 5 7 9 11 13 15 17 19 
S 
14년 10월 21일 화요일
MULTIPLEXED STREAMS 
1: GET /a.png 
3: GET /b.png 
5: GET /c.png 
Frame 
... 
C 1 3 5 7 9 11 13 15 17 19 
S 
14년 10월 21일 화요일
MULTIPLEXED STREAMS 
C 1 3 5 7 9 11 13 15 17 19 
S 1 1 3 5 5 3 5 1 1 3 1: a.png 
3: b.png 
5: c.png 
... 
Frame 
1: GET /a.png 
3: GET /b.png 
5: GET /c.png 
... 
14년 10월 21일 화요일
MULTIPLEXED STREAMS 
Stream 1: GET /a.png 
Stream 3: GET /b.png 
Stream 5: GET /c.png 
... 
C 1 3 5 7 9 11 13 15 17 19 
S 
1 1 3 5 5 3 5 1 1 3 Stream 1: a.png 
Stream 3: b.png 
Stream 5: c.png 
... 
Frame 
14년 10월 21일 화요일
SERVER PUSH 
달라고 하지도 않은 리소스를 
서버가 마음대로 보냄 
14년 10월 21일 화요일
SERVER PUSH 
HTML x 1 
PNG x 2 
14년 10월 21일 화요일
SERVER PUSH 
• Server Push 안하면: 
• TCP 커넥션 1개를 열고 
• HTML 문서 1개를 요청해서 받음 
• 그림 파일 2개를 요청해서 받음 
14년 10월 21일 화요일
SERVER PUSH 
• Server Push 안하면: 
• TCP 커넥션 1개를 열고 
• HTML 문서 1개를 요청해서 받음 
• 그림 파일 2개를 요청해서 받음 
• Server Push 하면: 
• TCP 커넥션 1개를 열고 
• HTML 문서 1개를 요청해서 그림 
파일 2개와 함께 받음 
14년 10월 21일 화요일
SERVER PUSH 
C 1 
S 
1 1 1 1 2 1 2 4 1 4 1: PUSH_PROMISE (2: a.png) 
1: PUSH_PROMISE (4: b.png) 
1: a.html 
2: a.png 
4: b.png 
1: GET /a.html 
14년 10월 21일 화요일
SERVER PUSH 
C 1 
S 
1 1 1 1 2 1 2 4 1 4 1: PUSH_PROMISE (2: a.png) 
1: PUSH_PROMISE (4: b.png) 
1: a.html 
2: a.png 
4: b.png 
1: GET /a.html 
a.png를 2번 스트림으로 보내줄 
것이니 요청하지 말아라 
14년 10월 21일 화요일
STREAM PRIORITY 
요청에 의존성 관계를 
지정할 수 있음 
14년 10월 21일 화요일
STREAM PRIORITY 
HTML x 1 
CSS x 1 
PNG x 2 
14년 10월 21일 화요일
STREAM PRIORITY 
• 의존성 지정 안하면: 
• TCP 커넥션 1개를 열고 
• HTML 문서 1개를 요청해서 받음 
• CSS 문서 1개와 그림 파일 2개를 
요청해서 받음 
• CSS 문서가 늦게 와서 렌더링이 
늦어짐 
14년 10월 21일 화요일
STREAM PRIORITY 
• 의존성 지정 안하면: 
• TCP 커넥션 1개를 열고 
• HTML 문서 1개를 요청해서 받음 
• CSS 문서 1개와 그림 파일 2개를 
요청해서 받음 
• CSS 문서가 늦게 와서 렌더링이 
늦어짐 
• 의존성 지정하면: 
• TCP 커넥션 1개를 열고 
• HTML 문서 1개를 요청해서 받음 
• CSS 문서 1개와 그림 파일 2개를 
요청해서 받음. 그림 파일이 CSS 
에 의존성이 있다고 알려줌. 
• CSS 문서가 가장 먼저 순조롭게 
렌더링 
14년 10월 21일 화요일
STREAM PRIORITY 
C 7 5 3 
S 
3 3 3 3 7 5 5 7 7 5 3: a.css 
5: 1.png 
7: 2.png 
3: GET /a.css 
5: GET /1.png (3에 의존) 
7: GET /2.png (3에 의존) 
14년 10월 21일 화요일
STREAM PRIORITY 
C 7 5 3 
S 
3 3 3 3 7 5 5 7 7 5 3: a.css 
5: 1.png 
7: 2.png 
3: GET /a.css 
5: GET /1.png (3에 의존) 
7: GET /2.png (3에 의존) 
서버가 어떻게 줘야하는지에 
대한 규칙은 전혀 없음 
14년 10월 21일 화요일
FAQ 
14년 10월 21일 화요일
HTTP/1에서 변하는 것 
• HTTP 메시지 포맷 
• HTTP 메시지 전송방법 
• Connection 헤더 사라짐 
• chunked 인코딩 사용 금지 
14년 10월 21일 화요일
변하지 않는 것 
• “HTTP's existing semantics remain unchanged.” 
• RFC 7231, 7232, 7233, 7234, 7235 그대로 사용함 
14년 10월 21일 화요일
SPDY와 다른 점 
헤더 압축 
SPDY 
HTTP/2 
zlib 
HPACK 
14년 10월 21일 화요일
SPDY와 다른 점 
헤더 압축 
SPDY 
HTTP/2 
zlib 
HPACK 
CRIME 
취약점 
14년 10월 21일 화요일
브라우저 지원 
• IE 11 on Windows 8 
• Firefox 34 
• Chrome --enable-spdy4 
14년 10월 21일 화요일
현재 HTTP/2 진행상황 
•Working Group Last Call (마무리 단계) 
• 2015년 2월 RFC로 출판될 “예정” 
14년 10월 21일 화요일
HTTP/2에 기여하려면 
• HTTP/2 혹은 HPACK 초안을 읽고, 
• ietf-http-wg@w3.org 로 의견을 보냅니다. 
• 오타 수정 같은 것은 https://github.com/http2/http2-spec 
로 PullRequest를 보내도 좋습니다. 
14년 10월 21일 화요일

More Related Content

What's hot

Reverse proxies & Inconsistency
Reverse proxies & InconsistencyReverse proxies & Inconsistency
Reverse proxies & InconsistencyGreenD0g
 
Basics of HTTP - Nafis Fuad
Basics of HTTP - Nafis FuadBasics of HTTP - Nafis Fuad
Basics of HTTP - Nafis FuadCefalo
 
Introduction to Haproxy
Introduction to HaproxyIntroduction to Haproxy
Introduction to HaproxyShaopeng He
 
Django Web Application Security
Django Web Application SecurityDjango Web Application Security
Django Web Application Securitylevigross
 
golang과 websocket을 활용한 서버프로그래밍 - 장애없는 서버 런칭 도전기
golang과 websocket을 활용한 서버프로그래밍 - 장애없는 서버 런칭 도전기golang과 websocket을 활용한 서버프로그래밍 - 장애없는 서버 런칭 도전기
golang과 websocket을 활용한 서버프로그래밍 - 장애없는 서버 런칭 도전기Sangik Bae
 
A New Era of SSRF - Exploiting URL Parser in Trending Programming Languages! ...
A New Era of SSRF - Exploiting URL Parser in Trending Programming Languages! ...A New Era of SSRF - Exploiting URL Parser in Trending Programming Languages! ...
A New Era of SSRF - Exploiting URL Parser in Trending Programming Languages! ...CODE BLUE
 
Cross Site Request Forgery Vulnerabilities
Cross Site Request Forgery VulnerabilitiesCross Site Request Forgery Vulnerabilities
Cross Site Request Forgery VulnerabilitiesMarco Morana
 
Introduction to Prometheus and Cortex (WOUG)
Introduction to Prometheus and Cortex (WOUG)Introduction to Prometheus and Cortex (WOUG)
Introduction to Prometheus and Cortex (WOUG)Weaveworks
 
Dangling DNS records takeover at scale
Dangling DNS records takeover at scaleDangling DNS records takeover at scale
Dangling DNS records takeover at scaleChandrapal Badshah
 
Apache Web Server Architecture Chaitanya Kulkarni
Apache Web Server Architecture Chaitanya KulkarniApache Web Server Architecture Chaitanya Kulkarni
Apache Web Server Architecture Chaitanya Kulkarniwebhostingguy
 
Moving From Actions & Behaviors to Microservices
Moving From Actions & Behaviors to MicroservicesMoving From Actions & Behaviors to Microservices
Moving From Actions & Behaviors to MicroservicesJeff Potts
 
One-Liners to Rule Them All
One-Liners to Rule Them AllOne-Liners to Rule Them All
One-Liners to Rule Them Allegypt
 

What's hot (20)

Reverse proxies & Inconsistency
Reverse proxies & InconsistencyReverse proxies & Inconsistency
Reverse proxies & Inconsistency
 
Basics of HTTP - Nafis Fuad
Basics of HTTP - Nafis FuadBasics of HTTP - Nafis Fuad
Basics of HTTP - Nafis Fuad
 
Introduction to Haproxy
Introduction to HaproxyIntroduction to Haproxy
Introduction to Haproxy
 
Django Web Application Security
Django Web Application SecurityDjango Web Application Security
Django Web Application Security
 
SSRF exploit the trust relationship
SSRF exploit the trust relationshipSSRF exploit the trust relationship
SSRF exploit the trust relationship
 
Deep dive into ssrf
Deep dive into ssrfDeep dive into ssrf
Deep dive into ssrf
 
golang과 websocket을 활용한 서버프로그래밍 - 장애없는 서버 런칭 도전기
golang과 websocket을 활용한 서버프로그래밍 - 장애없는 서버 런칭 도전기golang과 websocket을 활용한 서버프로그래밍 - 장애없는 서버 런칭 도전기
golang과 websocket을 활용한 서버프로그래밍 - 장애없는 서버 런칭 도전기
 
A New Era of SSRF - Exploiting URL Parser in Trending Programming Languages! ...
A New Era of SSRF - Exploiting URL Parser in Trending Programming Languages! ...A New Era of SSRF - Exploiting URL Parser in Trending Programming Languages! ...
A New Era of SSRF - Exploiting URL Parser in Trending Programming Languages! ...
 
Cross Site Request Forgery Vulnerabilities
Cross Site Request Forgery VulnerabilitiesCross Site Request Forgery Vulnerabilities
Cross Site Request Forgery Vulnerabilities
 
Introduction to Prometheus and Cortex (WOUG)
Introduction to Prometheus and Cortex (WOUG)Introduction to Prometheus and Cortex (WOUG)
Introduction to Prometheus and Cortex (WOUG)
 
Network scanning
Network scanningNetwork scanning
Network scanning
 
Ssh tunnel
Ssh tunnelSsh tunnel
Ssh tunnel
 
The Rise of Ransomware
The Rise of RansomwareThe Rise of Ransomware
The Rise of Ransomware
 
Dangling DNS records takeover at scale
Dangling DNS records takeover at scaleDangling DNS records takeover at scale
Dangling DNS records takeover at scale
 
Nfs
NfsNfs
Nfs
 
Apache Web Server Architecture Chaitanya Kulkarni
Apache Web Server Architecture Chaitanya KulkarniApache Web Server Architecture Chaitanya Kulkarni
Apache Web Server Architecture Chaitanya Kulkarni
 
Moving From Actions & Behaviors to Microservices
Moving From Actions & Behaviors to MicroservicesMoving From Actions & Behaviors to Microservices
Moving From Actions & Behaviors to Microservices
 
Ftp
FtpFtp
Ftp
 
Offzone | Another waf bypass
Offzone | Another waf bypassOffzone | Another waf bypass
Offzone | Another waf bypass
 
One-Liners to Rule Them All
One-Liners to Rule Them AllOne-Liners to Rule Them All
One-Liners to Rule Them All
 

Similar to 더 빠른 웹을 위해: HTTP/2

Network Project
Network ProjectNetwork Project
Network ProjectMinho Yoo
 
15minutes to create_vm
15minutes to create_vm15minutes to create_vm
15minutes to create_vmChoe Cheng-Dae
 
Dropbox와 같은 시스템은 파일을 어떻게 저장할까?
Dropbox와 같은 시스템은 파일을 어떻게 저장할까?Dropbox와 같은 시스템은 파일을 어떻게 저장할까?
Dropbox와 같은 시스템은 파일을 어떻게 저장할까?nexusz99
 
[NDC 2018] Spark, Flintrock, Airflow 로 구현하는 탄력적이고 유연한 데이터 분산처리 자동화 인프라 구축
[NDC 2018] Spark, Flintrock, Airflow 로 구현하는 탄력적이고 유연한 데이터 분산처리 자동화 인프라 구축[NDC 2018] Spark, Flintrock, Airflow 로 구현하는 탄력적이고 유연한 데이터 분산처리 자동화 인프라 구축
[NDC 2018] Spark, Flintrock, Airflow 로 구현하는 탄력적이고 유연한 데이터 분산처리 자동화 인프라 구축Juhong Park
 
19.컴퓨터 네트워크 program homework
19.컴퓨터 네트워크 program homework19.컴퓨터 네트워크 program homework
19.컴퓨터 네트워크 program homework호상 장
 

Similar to 더 빠른 웹을 위해: HTTP/2 (8)

Network Project
Network ProjectNetwork Project
Network Project
 
15minutes to create_vm
15minutes to create_vm15minutes to create_vm
15minutes to create_vm
 
Dropbox와 같은 시스템은 파일을 어떻게 저장할까?
Dropbox와 같은 시스템은 파일을 어떻게 저장할까?Dropbox와 같은 시스템은 파일을 어떻게 저장할까?
Dropbox와 같은 시스템은 파일을 어떻게 저장할까?
 
[NDC 2018] Spark, Flintrock, Airflow 로 구현하는 탄력적이고 유연한 데이터 분산처리 자동화 인프라 구축
[NDC 2018] Spark, Flintrock, Airflow 로 구현하는 탄력적이고 유연한 데이터 분산처리 자동화 인프라 구축[NDC 2018] Spark, Flintrock, Airflow 로 구현하는 탄력적이고 유연한 데이터 분산처리 자동화 인프라 구축
[NDC 2018] Spark, Flintrock, Airflow 로 구현하는 탄력적이고 유연한 데이터 분산처리 자동화 인프라 구축
 
네트워크 기본
네트워크 기본네트워크 기본
네트워크 기본
 
Hadoop overview
Hadoop overviewHadoop overview
Hadoop overview
 
19.컴퓨터 네트워크 program homework
19.컴퓨터 네트워크 program homework19.컴퓨터 네트워크 program homework
19.컴퓨터 네트워크 program homework
 
CDN overview
CDN overviewCDN overview
CDN overview
 

더 빠른 웹을 위해: HTTP/2

  • 1. HTTP/2 더 빠른 웹을 위해 14년 10월 21일 화요일
  • 2. 발표자 소개 • 이응준 • NAVER LABS에서 서버사이드 웹 프로그래머로 근무중 • 책 HTTP: The Definitive Guide 번역중 14년 10월 21일 화요일
  • 3. 오늘 이야기할 것 • HTTP/2는 • 왜 만들었나 • 왜 빠른가 14년 10월 21일 화요일
  • 4. 왜 만들었나 14년 10월 21일 화요일
  • 5. 왜 만들었나 • HTTP/1이 너무 느려서 14년 10월 21일 화요일
  • 6. HTTP/1은 왜 느린가 • HTTP/1의 동작: • 클라이언트가 서버에 요청을 보낸다. • 서버가 클라이언트에게 그에 대한 응답을 보낸다. • 대역폭과 상관없이 round trip 때문에 느려짐 14년 10월 21일 화요일
  • 7. HTTP/1은 왜 느린가 • 요청이 갔다가 응답이 돌아오는데 걸리는 시간 • 서울 <=> 춘천: 8ms • 서울 <=> 일본: 35ms • 서울 <=> 뉴욕: 200ms • 지구 <=> 화성: 8분 ~ 48분 14년 10월 21일 화요일
  • 8. 태초의 HTTP HTML x 1 PNG x 20 14년 10월 21일 화요일
  • 9. 태초의 HTTP • TCP 커넥션 수립 (3-way handshake) • HTML 파일 1개 가져옴 • TCP 커넥션 닫음 • TCP 커넥션 수립 (3-way handshake) • PNG 파일 1개 가져옴 • TCP 커넥션 닫음 20번 반복 14년 10월 21일 화요일
  • 10. 태초의 HTTP • TCP 커넥션 수립 (3-way handshake) • HTML 파일 1개 가져옴 • TCP 커넥션 닫음 • TCP 커넥션 수립 (3-way handshake) • PNG 파일 1개 가져옴 • TCP 커넥션 닫음 42 RTT 20번 반복 14년 10월 21일 화요일
  • 11. HTTP/1.0+ (KEEP-ALIVE) • TCP 커넥션 수립 (3-way handshake) • HTML 파일 1개 가져옴 • PNG 파일 1개 가져옴 (20번 반복) 14년 10월 21일 화요일
  • 12. HTTP/1.0+ (KEEP-ALIVE) • TCP 커넥션 수립 (3-way handshake) • HTML 파일 1개 가져옴 • PNG 파일 1개 가져옴 (20번 반복) 22 RTT 14년 10월 21일 화요일
  • 13. PARALLEL CONNECTIONS • TCP 커넥션 수립 (3-way handshake) • HTML 파일 1개 가져옴 • TCP 커넥션 7개 더 수립 (3-way handshake) • PNG 파일 8개 가져옴 • PNG 파일 8개 더 가져옴 • PNG 파일 4개 더 가져옴 14년 10월 21일 화요일
  • 14. PARALLEL CONNECTIONS • TCP 커넥션 수립 (3-way handshake) • HTML 파일 1개 가져옴 • TCP 커넥션 7개 더 수립 (3-way handshake) • PNG 파일 8개 가져옴 • PNG 파일 8개 더 가져옴 • PNG 파일 4개 더 가져옴 6 RTT 14년 10월 21일 화요일
  • 15. PIPELINING • TCP 커넥션 수립 (3-way handshake) • HTML 파일 1개 가져옴 • PNG 파일 20개 가져옴 14년 10월 21일 화요일
  • 16. PIPELINING • TCP 커넥션 수립 (3-way handshake) • HTML 파일 1개 가져옴 • PNG 파일 20개 가져옴 3 RTT 14년 10월 21일 화요일
  • 17. PIPELINING • TCP 커넥션 수립 (3-way handshake) • HTML 파일 1개 가져옴 • PNG 파일 20개 가져옴 구현이 어려워서 잘 안씀! 14년 10월 21일 화요일
  • 18. HTTP/1은 왜 느린가 2 • 헤더가 너무 큼 (특히 쿠키) 14년 10월 21일 화요일
  • 19. 성능 개선을 위한 많은 노력들 • HTTP-NG 프로젝트 (1997) • Roy Fielding이 WAKA 제안 • S+M(Speedy+Mobility, 마이크로소프트) • SPDY (구글, 2009) 14년 10월 21일 화요일
  • 20. HTTP/2 • HTTP 작업그룹이 SPDY를 기반으로 HTTP/2 작업 시작 (2012년 10월) 14년 10월 21일 화요일
  • 21. HTTP/2는 왜 빠른가 •Header Compression •Multiplexed Streams •Server Push •Stream Priority 14년 10월 21일 화요일
  • 22. HEADER COMPRESSION •Huffman Coding •Header Tables 14년 10월 21일 화요일
  • 23. HEADER COMPRESSION 서버가 헤더 “date:Mon, 21 Oct 2013 20:13:21 GMT”를 클라이언트에게 전송 date:Mon, 21 Oct 2013 20:13:21 GMT C S 14년 10월 21일 화요일
  • 24. HEADER COMPRESSION 서버가 헤더 “date:Mon, 21 Oct 2013 20:13:21 GMT”를 클라이언트에게 전송 C S ..date..z...T.D. .....f...-.. 헤더값에 Huffman Coding 적용: 34 => 29 14년 10월 21일 화요일
  • 25. HEADER COMPRESSION 서버가 헤더 “date:Mon, 21 Oct 2013 C 20:13:21 GMT”를 클라이언트에게 전송 S ..date..z...T.D. .....f...-.. Index Header Name Header Value 1 :authority ... ... ... 33 date ... ... ... 61 www-authenticate Static Table Index Header Name Header Value Dynamic Table 14년 10월 21일 화요일
  • 26. HEADER COMPRESSION 서버가 헤더 “date:Mon, 21 Oct 2013 C 20:13:21 GMT”를 클라이언트에게 전송 S ....z...T.D. .....f...-.. Index Header Name Header Value 1 :authority ... ... ... 33 date ... ... ... 61 www-authenticate Static Table Index Header Name Header Value Dynamic Table 헤더 이름을 Static Table 인덱스로 대체: 29 => 24 14년 10월 21일 화요일
  • 27. HEADER COMPRESSION 서버가 헤더 “date:Mon, 21 Oct 2013 C 20:13:21 GMT”를 클라이언트에게 전송 S ....z...T.D. .....f...-.. Index Header Name Header Value 1 :authority ... ... ... 33 date ... ... ... 61 www-authenticate Static Table Index Header Name Header Value 62 date Mon, 21 Oct 2013 20:13:21 GMT Dynamic Table 14년 10월 21일 화요일
  • 28. HEADER COMPRESSION 서버가 헤더 “date:Mon, 21 Oct 2013 C 20:13:21 GMT”를 클라이언트에게 “또” 전송 S Index Header Name Header Value 1 :authority ... ... ... 33 date ... ... ... 61 www-authenticate Static Table Index Header Name Header Value 62 date Mon, 21 Oct 2013 20:13:21 GMT Dynamic Table 14년 10월 21일 화요일
  • 29. HEADER COMPRESSION 서버가 헤더 “date:Mon, 21 Oct 2013 C 20:13:21 GMT”를 클라이언트에게 “또” 전송 S Index Header Name Header Value 1 :authority ... ... ... 33 date ... ... ... 61 www-authenticate Static Table Index Header Name Header Value 62 date Mon, 21 Oct 2013 20:13:21 GMT Dynamic Table . 헤더 필드를 Dynamic Table 인덱스로 대체: 24 => 1 14년 10월 21일 화요일
  • 30. MULTIPLEXED STREAMS 한 커넥션으로 동시에 여러 메시지를 주고 받을 수 있음 14년 10월 21일 화요일
  • 31. MULTIPLEXED STREAMS HTML x 1 PNG x 20 Max Connections: 8 14년 10월 21일 화요일
  • 32. MULTIPLEXED STREAMS • HTTP/1.1 • TCP 커넥션 1개를 열고 • HTML 문서 1개를 요청해서 받음 • TCP 커넥션 7개를 더 열고 • PNG 파일 8개를 요청해서 받음 • PNG 파일 8개를 더 요청해서 받음 • PNG 파일 4개를 더 요청해서 받음 14년 10월 21일 화요일
  • 33. MULTIPLEXED STREAMS • HTTP/1.1 • TCP 커넥션 1개를 열고 • HTML 문서 1개를 요청해서 받음 • TCP 커넥션 7개를 더 열고 • PNG 파일 8개를 요청해서 받음 • PNG 파일 8개를 더 요청해서 받음 • PNG 파일 4개를 더 요청해서 받음 • HTTP/2 • TCP 커넥션 1개를 열고 • HTML 문서 1개를 요청해서 받음 • PNG 파일 20개를 요청해서 받음 14년 10월 21일 화요일
  • 34. MULTIPLEXED STREAMS C S 14년 10월 21일 화요일
  • 35. MULTIPLEXED STREAMS GET /a.png GET /b.png GET /c.png ... C S 14년 10월 21일 화요일
  • 36. MULTIPLEXED STREAMS 1: GET /a.png 3: GET /b.png 5: GET /c.png ... C 1 3 5 7 9 11 13 15 17 19 S 14년 10월 21일 화요일
  • 37. MULTIPLEXED STREAMS 1: GET /a.png 3: GET /b.png 5: GET /c.png Frame ... C 1 3 5 7 9 11 13 15 17 19 S 14년 10월 21일 화요일
  • 38. MULTIPLEXED STREAMS C 1 3 5 7 9 11 13 15 17 19 S 1 1 3 5 5 3 5 1 1 3 1: a.png 3: b.png 5: c.png ... Frame 1: GET /a.png 3: GET /b.png 5: GET /c.png ... 14년 10월 21일 화요일
  • 39. MULTIPLEXED STREAMS Stream 1: GET /a.png Stream 3: GET /b.png Stream 5: GET /c.png ... C 1 3 5 7 9 11 13 15 17 19 S 1 1 3 5 5 3 5 1 1 3 Stream 1: a.png Stream 3: b.png Stream 5: c.png ... Frame 14년 10월 21일 화요일
  • 40. SERVER PUSH 달라고 하지도 않은 리소스를 서버가 마음대로 보냄 14년 10월 21일 화요일
  • 41. SERVER PUSH HTML x 1 PNG x 2 14년 10월 21일 화요일
  • 42. SERVER PUSH • Server Push 안하면: • TCP 커넥션 1개를 열고 • HTML 문서 1개를 요청해서 받음 • 그림 파일 2개를 요청해서 받음 14년 10월 21일 화요일
  • 43. SERVER PUSH • Server Push 안하면: • TCP 커넥션 1개를 열고 • HTML 문서 1개를 요청해서 받음 • 그림 파일 2개를 요청해서 받음 • Server Push 하면: • TCP 커넥션 1개를 열고 • HTML 문서 1개를 요청해서 그림 파일 2개와 함께 받음 14년 10월 21일 화요일
  • 44. SERVER PUSH C 1 S 1 1 1 1 2 1 2 4 1 4 1: PUSH_PROMISE (2: a.png) 1: PUSH_PROMISE (4: b.png) 1: a.html 2: a.png 4: b.png 1: GET /a.html 14년 10월 21일 화요일
  • 45. SERVER PUSH C 1 S 1 1 1 1 2 1 2 4 1 4 1: PUSH_PROMISE (2: a.png) 1: PUSH_PROMISE (4: b.png) 1: a.html 2: a.png 4: b.png 1: GET /a.html a.png를 2번 스트림으로 보내줄 것이니 요청하지 말아라 14년 10월 21일 화요일
  • 46. STREAM PRIORITY 요청에 의존성 관계를 지정할 수 있음 14년 10월 21일 화요일
  • 47. STREAM PRIORITY HTML x 1 CSS x 1 PNG x 2 14년 10월 21일 화요일
  • 48. STREAM PRIORITY • 의존성 지정 안하면: • TCP 커넥션 1개를 열고 • HTML 문서 1개를 요청해서 받음 • CSS 문서 1개와 그림 파일 2개를 요청해서 받음 • CSS 문서가 늦게 와서 렌더링이 늦어짐 14년 10월 21일 화요일
  • 49. STREAM PRIORITY • 의존성 지정 안하면: • TCP 커넥션 1개를 열고 • HTML 문서 1개를 요청해서 받음 • CSS 문서 1개와 그림 파일 2개를 요청해서 받음 • CSS 문서가 늦게 와서 렌더링이 늦어짐 • 의존성 지정하면: • TCP 커넥션 1개를 열고 • HTML 문서 1개를 요청해서 받음 • CSS 문서 1개와 그림 파일 2개를 요청해서 받음. 그림 파일이 CSS 에 의존성이 있다고 알려줌. • CSS 문서가 가장 먼저 순조롭게 렌더링 14년 10월 21일 화요일
  • 50. STREAM PRIORITY C 7 5 3 S 3 3 3 3 7 5 5 7 7 5 3: a.css 5: 1.png 7: 2.png 3: GET /a.css 5: GET /1.png (3에 의존) 7: GET /2.png (3에 의존) 14년 10월 21일 화요일
  • 51. STREAM PRIORITY C 7 5 3 S 3 3 3 3 7 5 5 7 7 5 3: a.css 5: 1.png 7: 2.png 3: GET /a.css 5: GET /1.png (3에 의존) 7: GET /2.png (3에 의존) 서버가 어떻게 줘야하는지에 대한 규칙은 전혀 없음 14년 10월 21일 화요일
  • 52. FAQ 14년 10월 21일 화요일
  • 53. HTTP/1에서 변하는 것 • HTTP 메시지 포맷 • HTTP 메시지 전송방법 • Connection 헤더 사라짐 • chunked 인코딩 사용 금지 14년 10월 21일 화요일
  • 54. 변하지 않는 것 • “HTTP's existing semantics remain unchanged.” • RFC 7231, 7232, 7233, 7234, 7235 그대로 사용함 14년 10월 21일 화요일
  • 55. SPDY와 다른 점 헤더 압축 SPDY HTTP/2 zlib HPACK 14년 10월 21일 화요일
  • 56. SPDY와 다른 점 헤더 압축 SPDY HTTP/2 zlib HPACK CRIME 취약점 14년 10월 21일 화요일
  • 57. 브라우저 지원 • IE 11 on Windows 8 • Firefox 34 • Chrome --enable-spdy4 14년 10월 21일 화요일
  • 58. 현재 HTTP/2 진행상황 •Working Group Last Call (마무리 단계) • 2015년 2월 RFC로 출판될 “예정” 14년 10월 21일 화요일
  • 59. HTTP/2에 기여하려면 • HTTP/2 혹은 HPACK 초안을 읽고, • ietf-http-wg@w3.org 로 의견을 보냅니다. • 오타 수정 같은 것은 https://github.com/http2/http2-spec 로 PullRequest를 보내도 좋습니다. 14년 10월 21일 화요일