Upload
Download free for 30 days
Login
Submit search
設計から実装まで、今すぐ始める高速化
Download as PDF, PPTX
262 likes
13,846 views
masaaki komori
2012.06.30 CSS Nite LP, Disk 23 こもり資料
Technology
Read more
1 of 95
Download now
Download as PDF, PPTX
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
More Related Content
PDF
CSSフレームワークを使った 簡単なレスポンシブデザインの作成
Kazuki Akiyama
PDF
ADC OnAir 第5回 『レスポンシブ Web デザインを学ぼう!実装編』
Naoki Matsuda
PDF
WordPress を使いこなそう
Wataru OKAMOTO
PDF
WordPressでCSSプリプロセッサ入門
Sou Lab
PDF
悩まないコーディングをしよう! OOCSS,SMACSSを用いた、読みやすくてメンテナブルなCSS設計(Sass対応)
Horiguchi Seito
PPTX
第10回勉強会 CSS設計について
takumaro web
PDF
今日から使える! HTML/CSS/JSの シンプルテクニック15選
Horiguchi Seito
PDF
ブラウザにやさしいHTML/CSS
Takeharu Igari
CSSフレームワークを使った 簡単なレスポンシブデザインの作成
Kazuki Akiyama
ADC OnAir 第5回 『レスポンシブ Web デザインを学ぼう!実装編』
Naoki Matsuda
WordPress を使いこなそう
Wataru OKAMOTO
WordPressでCSSプリプロセッサ入門
Sou Lab
悩まないコーディングをしよう! OOCSS,SMACSSを用いた、読みやすくてメンテナブルなCSS設計(Sass対応)
Horiguchi Seito
第10回勉強会 CSS設計について
takumaro web
今日から使える! HTML/CSS/JSの シンプルテクニック15選
Horiguchi Seito
ブラウザにやさしいHTML/CSS
Takeharu Igari
What's hot
(20)
PPTX
現場で使える効果的なHTML&CSS構造設計(Effective HTML&CSS)
Shin Takeuchi
PPTX
2016年版 フロントエンド開発フォーマット
Kenya Kodaira
PDF
CSS の歩き方
Seiichiro Mishiba
PDF
HTML/CSSを効率的にする メタ言語とツールのアレコレ
知己 久保
PDF
使いやすいWordPressのためのCSSのつくりかた
Hiroshi Urabe
PPTX
SMACSS入門
iPride Co., Ltd.
PDF
Css Architecture for the future 未来を見据えるCSS設計
Horiguchi Seito
PDF
CSS設計のお勉強
MarlboroLand
PDF
WordPressで作るポートフォリオサイト
Takuma Nishiyama
PDF
イマドキの「タグ=HTML」とスタイルシート=CSS」を知ろう
Mori Kazue
PPTX
css基本。
web12
PDF
今必要なCSSアーキテクチャ
Mayu Kimura
PDF
モダンCSS設計と BEMという開発手法
Kenji Karahashi
PPTX
メンテナブルなJsってなんだろう
Daiki Matsumoto
PDF
WordCampOsaka2012セッション資料
horike37
PDF
E2E CSS Testing at HTML5 Conference 2016
Takeharu Igari
PDF
信頼性が高くハイパフォーマンスなテーマ開発テクニックでライバルに差をつけろ!
Takayuki Miyauchi
PDF
第3回WordPress Cafe プラグイン紹介
foom_in
PDF
ヒューマンリーダブルな CSS 記述法(異次元編):2016年5月13日 CodeGrid 四周年記念パーティー
Yoshiki Hayama
PDF
大規模サイトにおける本当は怖いCSSの話
井上 誠
現場で使える効果的なHTML&CSS構造設計(Effective HTML&CSS)
Shin Takeuchi
2016年版 フロントエンド開発フォーマット
Kenya Kodaira
CSS の歩き方
Seiichiro Mishiba
HTML/CSSを効率的にする メタ言語とツールのアレコレ
知己 久保
使いやすいWordPressのためのCSSのつくりかた
Hiroshi Urabe
SMACSS入門
iPride Co., Ltd.
Css Architecture for the future 未来を見据えるCSS設計
Horiguchi Seito
CSS設計のお勉強
MarlboroLand
WordPressで作るポートフォリオサイト
Takuma Nishiyama
イマドキの「タグ=HTML」とスタイルシート=CSS」を知ろう
Mori Kazue
css基本。
web12
今必要なCSSアーキテクチャ
Mayu Kimura
モダンCSS設計と BEMという開発手法
Kenji Karahashi
メンテナブルなJsってなんだろう
Daiki Matsumoto
WordCampOsaka2012セッション資料
horike37
E2E CSS Testing at HTML5 Conference 2016
Takeharu Igari
信頼性が高くハイパフォーマンスなテーマ開発テクニックでライバルに差をつけろ!
Takayuki Miyauchi
第3回WordPress Cafe プラグイン紹介
foom_in
ヒューマンリーダブルな CSS 記述法(異次元編):2016年5月13日 CodeGrid 四周年記念パーティー
Yoshiki Hayama
大規模サイトにおける本当は怖いCSSの話
井上 誠
Viewers also liked
(8)
PDF
文系デザイナーでも大丈夫!レスポンシブWEBサイトをWordPressで作ってみよう
Junko Nukaga
PDF
High Performance Web Design
Koji Ishimoto
PDF
スマートフォンサイトの作成術 - 大川洋一
okyawa
PDF
ノンプログラマーのためのjQuery入門
Hayato Mizuno
PDF
レスポンシブ・ウェブデザイン基礎
masaaki komori
PDF
Webデザインのセオリーを学ぼう
Toshiaki Sasaki
KEY
ノンデザイナーのための配色理論
tsukasa obara
PPT
色彩センスのいらない配色講座
Mariko Yamaguchi
文系デザイナーでも大丈夫!レスポンシブWEBサイトをWordPressで作ってみよう
Junko Nukaga
High Performance Web Design
Koji Ishimoto
スマートフォンサイトの作成術 - 大川洋一
okyawa
ノンプログラマーのためのjQuery入門
Hayato Mizuno
レスポンシブ・ウェブデザイン基礎
masaaki komori
Webデザインのセオリーを学ぼう
Toshiaki Sasaki
ノンデザイナーのための配色理論
tsukasa obara
色彩センスのいらない配色講座
Mariko Yamaguchi
Similar to 設計から実装まで、今すぐ始める高速化
(20)
PDF
Internet Explorer 10とマイクロソフトにとってのHTML5
Microsoft
KEY
コーディングが上達するコツ
evol-ni
PDF
終わりなきWebの旅
Yasuhisa Hasegawa
PDF
jQuery Performance Tips – jQueryにおける高速化 -
Hayato Mizuno
PDF
HTML5
smallworkshop
KEY
HTML5実力テスト 答え合わせ勉強会 HTML/CSS編
Kazuya Hiruma
PDF
Aqua ion press_tech_20121116_publish
Keita Watanabe
PDF
更に進化するCSSの表現力と新しいWebツール (アドビセッション @HTML5 Conference 2012)
Keisuke Todoroki
PDF
今さら聞けないWordPressのあんなことこんなこと [WCAN 2012 Autumn]
takashi ono
PDF
マークアップ講座 02 CSS
eiji sekiya
PDF
Webとスマホとデザインと - 地方から広がるつながるデザイナーのお仕事 -
Miho Yamamori
PDF
「html5 boilerplate」から考える、これからのマークアップ
Yasuhito Yabe
PDF
Css preprocessorの始めかた
Hiroki Shibata
PDF
HTML5な今日この頃に贈る、Webデザイナーこれからの生きる道
Hideki Akiba
PDF
HTML5とCSS3でWebが変わる!でも導入は簡単!
Toshihito Gamo
PPTX
マルチデバイス時代の高速化
Shin Takeuchi
PDF
CSSの光と闇
Shuma Mizuno
PDF
Web Site Optimization for Beginners
masaaki komori
PDF
WebとIE10とWindows 8
Microsoft
PDF
更に進化するCSSの表現力と 新しいWebツール [Reloaded]
Keisuke Todoroki
Internet Explorer 10とマイクロソフトにとってのHTML5
Microsoft
コーディングが上達するコツ
evol-ni
終わりなきWebの旅
Yasuhisa Hasegawa
jQuery Performance Tips – jQueryにおける高速化 -
Hayato Mizuno
HTML5
smallworkshop
HTML5実力テスト 答え合わせ勉強会 HTML/CSS編
Kazuya Hiruma
Aqua ion press_tech_20121116_publish
Keita Watanabe
更に進化するCSSの表現力と新しいWebツール (アドビセッション @HTML5 Conference 2012)
Keisuke Todoroki
今さら聞けないWordPressのあんなことこんなこと [WCAN 2012 Autumn]
takashi ono
マークアップ講座 02 CSS
eiji sekiya
Webとスマホとデザインと - 地方から広がるつながるデザイナーのお仕事 -
Miho Yamamori
「html5 boilerplate」から考える、これからのマークアップ
Yasuhito Yabe
Css preprocessorの始めかた
Hiroki Shibata
HTML5な今日この頃に贈る、Webデザイナーこれからの生きる道
Hideki Akiba
HTML5とCSS3でWebが変わる!でも導入は簡単!
Toshihito Gamo
マルチデバイス時代の高速化
Shin Takeuchi
CSSの光と闇
Shuma Mizuno
Web Site Optimization for Beginners
masaaki komori
WebとIE10とWindows 8
Microsoft
更に進化するCSSの表現力と 新しいWebツール [Reloaded]
Keisuke Todoroki
More from masaaki komori
(20)
PDF
コアなエンジニアじゃなくてもできるよ #JP_Stripes Vol.3
masaaki komori
PDF
InstaVR使ってみた
masaaki komori
PDF
Framerで始めるプロトタイプコーディング
masaaki komori
PDF
Prototyping with Sketch
masaaki komori
PDF
プロトタイピングツール戦国時代
masaaki komori
PDF
Bootstrapではじめる、 Webサイト設計のモダンアプローチ
masaaki komori
PDF
レスポンシブEメールを作ろう
masaaki komori
PDF
Bootstrapはこう使う
masaaki komori
PDF
デバイス多様化の時代のWeb制作
masaaki komori
PDF
2015年のWebサイトの作り方 at 67ws
masaaki komori
PDF
Webデザインと開発の未来
masaaki komori
PDF
Framerで動くモックアップを簡単作成
masaaki komori
PDF
Sketch 3 Basics at kkmsz
masaaki komori
PDF
Re:Cre Vol.14 | Web design process for the future
masaaki komori
PDF
Web Design Process for The Future
masaaki komori
PDF
Web Design Process for The Future
masaaki komori
PDF
groundwork-pasona-tech
masaaki komori
PDF
インブラウザ勉強会 Vol.1
masaaki komori
PDF
Sublime Text 2 Basics
masaaki komori
PDF
Web制作者は変化についていけるか? 変化についていくべきか?
masaaki komori
コアなエンジニアじゃなくてもできるよ #JP_Stripes Vol.3
masaaki komori
InstaVR使ってみた
masaaki komori
Framerで始めるプロトタイプコーディング
masaaki komori
Prototyping with Sketch
masaaki komori
プロトタイピングツール戦国時代
masaaki komori
Bootstrapではじめる、 Webサイト設計のモダンアプローチ
masaaki komori
レスポンシブEメールを作ろう
masaaki komori
Bootstrapはこう使う
masaaki komori
デバイス多様化の時代のWeb制作
masaaki komori
2015年のWebサイトの作り方 at 67ws
masaaki komori
Webデザインと開発の未来
masaaki komori
Framerで動くモックアップを簡単作成
masaaki komori
Sketch 3 Basics at kkmsz
masaaki komori
Re:Cre Vol.14 | Web design process for the future
masaaki komori
Web Design Process for The Future
masaaki komori
Web Design Process for The Future
masaaki komori
groundwork-pasona-tech
masaaki komori
インブラウザ勉強会 Vol.1
masaaki komori
Sublime Text 2 Basics
masaaki komori
Web制作者は変化についていけるか? 変化についていくべきか?
masaaki komori
設計から実装まで、今すぐ始める高速化
1.
設計段階から実装まで、今すぐ始める高速化
設計段階から実装まで、今すぐ始める高速化 CSS Nite LP Disk 23 , こもりまさあき 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
2.
設計段階から実装まで、今すぐ始める高速化 自己紹介を… こもりまさあき
http://protean.im 1990年代前半に都内のDTP系デザイン会社にてアルバイトをはじめる。大 学卒業後そのまま正社員となり、入出力業務、デザイン業務、ネットワーク 関連業務に並行して従事。2001年、会社を退職しフリーランスの道へ。 案件ごとに業務内容や立ち位置が異なるため、職域的な肩書きはなし 近著に『レスポンシブ・ウェブデザイン標準ガイド(MdN刊)』 『WordPress 高速化&スマート運用必携ガイド(共著・MdN刊)』、など Twitter: @cipher / @proteanbm Facebook: gaspanik Instagram: @cipher 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
3.
設計段階から実装まで、今すぐ始める高速化
Webサイトが遅い原因の80%は、 フロントエンドの処理だと言われる 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
4.
設計段階から実装まで、今すぐ始める高速化
「フロントエンドの処理」って、 実装する人だけが考えること? 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
5.
設計段階から実装まで、今すぐ始める高速化
いやいや、ちょっと待って。 実装前から考える方が良くない? 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
6.
設計段階から実装まで、今すぐ始める高速化
バックエ ンドの 話もまと めて 今日は、そんな設計段階から 実装に関わる部分までの話を 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
7.
設計段階から実装まで、今すぐ始める高速化
これからお話しすること • コンテンツのロードを速くしよう • キャッシュを使いこなそう • 外部要因による遅延を改善しよう • リクエストを分散させてより高速に 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
8.
設計段階から実装まで、今すぐ始める高速化
キレイなサイト、面白いサイト、 完成すればそれで良いのかな? 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
9.
設計段階から実装まで、今すぐ始める高速化
ブロードバンドの普及、 スマートデバイスの登場 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
10.
設計段階から実装まで、今すぐ始める高速化
相反する回線環境 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
11.
設計段階から実装まで、今すぐ始める高速化
ネットワークの仕組みを理解し、 より速く配信することを考えよう 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
12.
設計段階から実装まで、今すぐ始める高速化
表示が速すぎても、誰も文句は言いません 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
13.
設計段階から実装まで、今すぐ始める高速化
目には見えない部分を改善する、 それもデザインのひとつですから 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
14.
設計段階から実装まで、今すぐ始める高速化
みんなで考えましょうよ 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
15.
設計段階から実装まで、今すぐ始める高速化
誰のためのWebサイトなのか 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
16.
設計段階から実装まで、今すぐ始める高速化 コンテンツのロードを速くするためにできること 2012. 06. 30
CSS Nite LP, Disk 23 | こもりまさあき
17.
設計段階から実装まで、今すぐ始める高速化 コンテンツがロードされる様子、アゲイン Pingdom Tools: http://tools.pingdom.com/fpt/ 2012.
06. 30 CSS Nite LP, Disk 23 | こもりまさあき
18.
設計段階から実装まで、今すぐ始める高速化 箱作りのベースは速く、とにかく速く • HTML
• CSS • JavaScript 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
19.
設計段階から実装まで、今すぐ始める高速化 周りを見渡せば、意外と多いこんな状況 • コンテンツ量が多く、
HTMLのサイズそのものが大きい • 制作効率、メンテナンス効率、 そこを重視するあまり、 分割されすぎたCSSファイル • あれもこれもと追加されたJavaScript 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
20.
設計段階から実装まで、今すぐ始める高速化 @import、えっと…
@import url(contents_base2.css); @import url(base.css); @import url(layout.css); @import url(common.css); @import url(menu.css); @import url(contents_base.css); <link rel="stylesheet" … href="import.css"> import.css @import url(search.css); @import url(top.css); @import url(news.css); @import url(chmn.css); @import url(map.css); @import url(faq.css); @import url(logo.css); @import url(background.css); 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
21.
設計段階から実装まで、今すぐ始める高速化 これだと、こういう結果になる
example.html import.css base.css layout.css common.css menu.css contents_base.css search.css top.css news.css chmn.css map.css faq.css logo.css … 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
22.
設計段階から実装まで、今すぐ始める高速化
当たり前の話 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
23.
設計段階から実装まで、今すぐ始める高速化 リクエストとレスポンス、同時接続数 • クライアントとサーバのやりとり
• ブラウザの同時接続数 • 初期段階のロードから コンテンツの整形までを速くするには、 この部分に着目することが大事 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
24.
設計段階から実装まで、今すぐ始める高速化
いかにして速くブラウザに届けるか 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
25.
設計段階から実装まで、今すぐ始める高速化 ファイルをまとめる、余分な要素は除去 • 分割されすぎたCSS、JavaScriptは、
可能な限りまとめる • ファイルに含まれる余分な要素、 たとえば、改行やコメントなどを除去する 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
26.
設計段階から実装まで、今すぐ始める高速化 さっきの@importもまとめてしまえば
example.html compact.css jQuery.js plugin.js imageA.png imageB.png imageC.png imageD.png imageE.png imageF.png imageG.png imageH.png imageI.png imageJ.png … 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
27.
設計段階から実装まで、今すぐ始める高速化
余分なリクエストは減り、 その分だけ速く他の要素へ 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
28.
設計段階から実装まで、今すぐ始める高速化
でも効率が…、手間だし… 嫌がる人が多いのも事実 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
29.
設計段階から実装まで、今すぐ始める高速化 ツールやサービスを使えば、比較的簡単
OS X 環 境な • excssive CodeKit ら 便利 ! http://www.excssive.com/ • YUI Compressor http://developer.yahoo.com/yui/compressor/ • Closure Compiler Service http://closure-compiler.appspot.com/home CodeKit: http://incident57.com/codekit/ 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
30.
設計段階から実装まで、今すぐ始める高速化 excssive なら画面内にファイルをドラッグ 2012. 06.
30 CSS Nite LP, Disk 23 | こもりまさあき
31.
設計段階から実装まで、今すぐ始める高速化
運用体制をどうするか?の話でしかない 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
32.
設計段階から実装まで、今すぐ始める高速化
「それでも面倒」と言うなら、 テキストデータを圧縮しちゃえ 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
33.
設計段階から実装まで、今すぐ始める高速化 テキストをGzip圧縮して高速化 •
バックエンドのサーバ側で Gzipを使った符号化をおこなう • 1/5∼1/3ぐらいにファイルサイズは小さく • 特に不安定な回線に対して有効 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
34.
設計段階から実装まで、今すぐ始める高速化 Apacheの場合はこのように •
2.x系なら、mod_deflateを有効にする <IfModule mod_deflate.c> SetOutputFilter DEFLATE BrowserMatch ^Mozilla/4 gzip-only-text/html BrowserMatch ^Mozilla/4.0[678] no-gzip BrowserMatch bMSI[E] !no-gzip !gzip-only-text/html SetEnvIfNoCase Request_URI .(?:gif|jpe?g|png)$ no-gzip dont-vary Header append Vary User-Agent env=!dont-vary </IfModule> mod_deflateの記述例: https://httpd.apache.org/docs/2.2/mod/mod_deflate.html 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
35.
設計段階から実装まで、今すぐ始める高速化 転送データサイズはここまで変わる 2012. 06. 30
CSS Nite LP, Disk 23 | こもりまさあき
36.
設計段階から実装まで、今すぐ始める高速化 HTMLをピ ク ッ
ッ ア プ 27.5k Gzipしない元のファイル 8.6 k Gzip後の転送サイズ 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
37.
設計段階から実装まで、今すぐ始める高速化
小さくなれば、より速く届く 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
38.
設計段階から実装まで、今すぐ始める高速化
もっと簡単にいろいろできないの? 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
39.
設計段階から実装まで、今すぐ始める高速化 Google謹製、mod_pagespeedの導入 • Apacheのモジュール「mod_pagespeed」
https://developers.google.com/speed/pagespeed/mod • さまざまな高速化の施策をサーバ側で • サーバ側の負荷、動作確認など、 事前に徹底的な検証が必要 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
40.
設計段階から実装まで、今すぐ始める高速化
繰り返します 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
41.
設計段階から実装まで、今すぐ始める高速化
箱作りのベースは、とにかく速く 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
42.
設計段階から実装まで、今すぐ始める高速化
方法はいろいろ。 どこまでやるか、 どうやってやるか 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
43.
設計段階から実装まで、今すぐ始める高速化 必要なファイルだけを配信。キャッシュを使おう 2012. 06. 30
CSS Nite LP, Disk 23 | こもりまさあき
44.
設計段階から実装まで、今すぐ始める高速化 もう一度おさらい、リクエストとレスポンス •
構成要素の数だけ繰り返される リクエストとレスポンス • サイトにアクセスするたびに ファイルをダウンロードさせるのは非効率 • 変更のないファイルは、 ダウンロードさせたくない 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
45.
設計段階から実装まで、今すぐ始める高速化 キャッシュといってもいろいろある •
ブラウザが持っているキャッシュ • アプリケーションキャッシュ • サーバサイドによるキャッシュ • その他、DNSのキャッシュなど、いろいろ 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
46.
設計段階から実装まで、今すぐ始める高速化 キャッシュ対象になるもの •
変更頻度が極端に少ない サイト内で使い回す画像ファイル • 定期的な改修でしか触らない CSS、JavaScript • jQueryなどのライブラリ 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
47.
設計段階から実装まで、今すぐ始める高速化 ファイルに有効期限を設定するには •
Apacheなら、mod_expires を有効にする <ifModule mod_expires.c> ExpiresActive On ExpiresDefault "access plus 1 seconds" ExpiresByType image/x-icon "access plus 1 years" ExpiresByType image/jpeg "access plus 10 years" ExpiresByType image/png "access plus 10 years" ExpiresByType text/css "access plus 1 years" … </ifModule> 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
48.
設計段階から実装まで、今すぐ始める高速化 ファイルに有効期限を設定すると 2012. 06. 30
CSS Nite LP, Disk 23 | こもりまさあき
49.
設計段階から実装まで、今すぐ始める高速化 結果として、HTTPリクエストは減る 2012. 06. 30
CSS Nite LP, Disk 23 | こもりまさあき
50.
設計段階から実装まで、今すぐ始める高速化 もう一度、全文掲載
<ifModule mod_expires.c> ExpiresActive On ExpiresDefault "access plus 1 seconds" ExpiresByType image/x-icon "access plus 1 years" ExpiresByType image/vnd.microsoft.icon "access plus 1 years" ExpiresByType image/jpeg "access plus 10 years" ExpiresByType image/png "access plus 10 years" ExpiresByType image/gif "access plus 10 years" ExpiresByType text/css "access plus 1 years" ExpiresByType text/javascript "access plus 1 years" ExpiresByType application/x-javascript "access plus 1 years" ExpiresByType text/html "access plus 600 seconds" ExpiresByType application/xhtml+xml "access plus 600 seconds" </ifModule> 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
51.
設計段階から実装まで、今すぐ始める高速化
コピペするだけ、時間にして2分 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
52.
設計段階から実装まで、今すぐ始める高速化 もうひとつのキャッシュ、.appcache •
通常のキャッシュとは別枠。 指定したファイルをキープしてくれる • サイズの大きい画像、 jQueryなどのライブラリなど • 強制的にネットワークを参照させることも可 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
53.
設計段階から実装まで、今すぐ始める高速化 .appcacheを有効にして、ファイルを列挙 •
キャッシュ・マニフェストを用意 CACHE MANIFEST # version 2 CACHE: index_Resources/PIE.htc index_Resources/TopImage_Bg.jpg … NETWORK: index.html index_Resources/HYPE.js 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
54.
設計段階から実装まで、今すぐ始める高速化 .appcacheが有効になっている状態 chrome://appcache-internals/ 2012. 06. 30
CSS Nite LP, Disk 23 | こもりまさあき
55.
設計段階から実装まで、今すぐ始める高速化
変更の少ないファイルは、 できるだけ配信しない工夫 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
56.
設計段階から実装まで、今すぐ始める高速化 さらに? キャッシングサーバの導入 •
大量のアクセスを処理するなら、 キャッシングサーバを追加して 静的なファイルだけはそこ経由で配信する • Apache + Varnish https://www.varnish-cache.org/ • Nginx によるリバースプロキシ http://wiki.nginx.org/NginxJa 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
57.
設計段階から実装まで、今すぐ始める高速化
大量に配信するものは、 より高速なサーバで処理 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
58.
設計段階から実装まで、今すぐ始める高速化
自身の環境に合わせて、 キ ッ ュ ャ シ をうまく使って 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
59.
設計段階から実装まで、今すぐ始める高速化
ご利用は計画的に 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
60.
設計段階から実装まで、今すぐ始める高速化 外部要因による遅延を極力抑えよう 2012. 06. 30
CSS Nite LP, Disk 23 | こもりまさあき
61.
設計段階から実装まで、今すぐ始める高速化 自サイトのコンテンツ以外の要素が問題 •
効果測定のためなど、 外部サービスのタグ(JavaScriptのコード) • サイト内にあれこれ貼られる広告 • あれもこれもと追加した ソーシャルメディア系のリソース群 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
62.
設計段階から実装まで、今すぐ始める高速化
大人の事情で減らせない… 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
63.
設計段階から実装まで、今すぐ始める高速化 外部の要素を取り込むことで起こる問題 •
外部のサービスが止まった場合、 最悪コンテンツのロードが途中で止まる • JavaScriptの document.write() • 外部ドメインに接続する時、 起こっているのは、DNSルックアップ document.writeでSCRIPTを書き出すなやで!: http://t32k.me/mol/log/dont-docwrite-scripts/ 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
64.
設計段階から実装まで、今すぐ始める高速化 DNSルックアップは、極力減らすが吉 •
接続先がわからなければ、 初回はこのDNSルックアップが起きる • できる限り減らしておいた方がいいもの • 理想をいえば、4つぐらい 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
65.
設計段階から実装まで、今すぐ始める高速化 DNSプリフェッチの導入という手も •
接続する予定のドメインは、 あらかじめDNSに問い合わせさせておこう • 有効になる、ならないブラウザがある • link要素を使って、参照するドメインを記述 https://github.com/h5bp/html5-boilerplate/wiki/DNS-Prefetching 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
66.
設計段階から実装まで、今すぐ始める高速化
無駄を省いて、できる限り 外部ドメイン参照を減らす 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
67.
設計段階から実装まで、今すぐ始める高速化
外部要因といえば、もうひとつ 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
68.
設計段階から実装まで、今すぐ始める高速化 貼り付けた後、放置してない? •
Google Analyticsのコード • Twitterのボタン、Facebookの all.js • その他、 ソーシャル系サービスのJSの読み込み 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
69.
設計段階から実装まで、今すぐ始める高速化 放置はよくない、定期的にチェック •
最近のコードは、 非同期でロードするように改良 • 微妙な変更なども入れると、 貼り込み用のコードは頻繁に変わっている • 定期的に見直しを 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
70.
設計段階から実装まで、今すぐ始める高速化
コンテンツロードの阻害要因は、 できるだけ解消しないと止まる 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
71.
設計段階から実装まで、今すぐ始める高速化 減らせないリクエスト。配信サーバを分けてしまう 2012. 06. 30
CSS Nite LP, Disk 23 | こもりまさあき
72.
設計段階から実装まで、今すぐ始める高速化 HTTPリクエストを減らせと言われても… •
コンテンツはこれ以上少なくできない • 制作効率とかコストを考えた場合、 ファイルの結合などもできれば避けたい • 画像も使わざるを得ない 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
73.
設計段階から実装まで、今すぐ始める高速化 コンテンツは減らせない、ならどうする? •
同じホスト、 同じネットワーク、 それでまかなうから限界が出てくる • それを何とかするには… 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
74.
設計段階から実装まで、今すぐ始める高速化
狭い道に車が押し寄せたら 当然のように渋滞が起きる 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
75.
設計段階から実装まで、今すぐ始める高速化
ならば、バイパスを作るか、 もっと速い高速道路を作るか 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
76.
設計段階から実装まで、今すぐ始める高速化 サーバを分割し、配信を効率化する •
サイトで頻繁に使う画像だけ別サーバに • サブドメインでも分けないよりはマシ • コンテンツ内の画像は、 Flickrなどの外部サービスを使ってみる 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
77.
設計段階から実装まで、今すぐ始める高速化 たとえば、みんな大好きjQuery •
Googleなどから読み込むように変更 • これで自サイトの接続数は、1本減ることに • 当たり前だけど、やっぱり速い 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
78.
設計段階から実装まで、今すぐ始める高速化 Google Libraries API Google
Developers: https://developers.google.com/speed/libraries/ 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
79.
設計段階から実装まで、今すぐ始める高速化 外部からjQueryを読み込んでみる •
フォールバックも忘れずに <script src="//ajax.googleapis.com/ajax/libs/jquery/バージョン/ jquery.min.js"></script> <script type="text/javascript"> window.jQuery || document.write(unescape('%3Cscript src="js/jquery/jquery-バージョン.min.js"%3E%3C/script%3E')); </script> 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
80.
設計段階から実装まで、今すぐ始める高速化
速いネ ト ー から配信できればなぁ… ッ ワ ク 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
81.
設計段階から実装まで、今すぐ始める高速化 そこで登場するのが、CDN •
コンテンツ・デリバリー・ネットワークの略 • データのコピーを世界中の拠点におき、 ネットワークの距離的に近い場所から配信する • いまは、無償のサービスや 有償でも手に届くレベルの存在に 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
82.
設計段階から実装まで、今すぐ始める高速化 代表的なCDNサービス •
Akamai http://www.akamai.co.jp/enja/ • CloudFlare http://jp.cloudflare.com/ • Amazon Web Service(S3* / CloudFront) http://aws.amazon.com/jp/cloudfront/ * S3はストレージサービスでCDNというわけではない 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
83.
設計段階から実装まで、今すぐ始める高速化 無償から始められるCloud Flare 2012. 06.
30 CSS Nite LP, Disk 23 | こもりまさあき
84.
設計段階から実装まで、今すぐ始める高速化 Amazonのインフラを使うCloudFront 2012. 06. 30
CSS Nite LP, Disk 23 | こもりまさあき
85.
設計段階から実装まで、今すぐ始める高速化 サービスによって異なる仕組み •
Cloud Flareは、ネームサーバを切り替える • オリジナルデータを、 自分で指定されたサーバにアップする • リクエストがあったデータを、 オリジナルから拾ってキャッシュする 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
86.
設計段階から実装まで、今すぐ始める高速化 従量制の場合は、コストチェックを 2012. 06. 30
CSS Nite LP, Disk 23 | こもりまさあき
87.
設計段階から実装まで、今すぐ始める高速化
構成要素が多い場合など、 使いどころ、利用頻度で分割 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
88.
設計段階から実装まで、今すぐ始める高速化
それを、より高速な環境から配信する 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
89.
設計段階から実装まで、今すぐ始める高速化
多くのサイトでネックなのは、 そこに配置された画像フ イ ァ ル 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
90.
設計段階から実装まで、今すぐ始める高速化
インフラそのものが弱い、 使用画像が多い き と など、 その効果は絶大なはず 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
91.
設計段階から実装まで、今すぐ始める高速化
本体のサーバに極力仕事をさせない 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
92.
設計段階から実装まで、今すぐ始める高速化
このあたりの実際は、ライブデモで 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
93.
設計段階から実装まで、今すぐ始める高速化
今日のまとめ • 箱作りのファイルは、とにかく速く • キャッシュをうまく使えばリクエスト減 • 外部要因による遅延を解消する • ファイルが多すぎるなら、サーバ分割 • 設計段階からちゃんと考えること 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
94.
設計段階から実装まで、今すぐ始める高速化
これからのコンテンツ配信は、 実装する人間だけじゃなく、 いろんな立場が意識をしないと 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
95.
設計段階から実装まで、今すぐ始める高速化
本日はありがとうございました 2012. 06. 30 CSS Nite LP, Disk 23 | こもりまさあき
Download