ホームページ > ウェブフロントエンド > htmlチュートリアル > 高パフォーマンスなWEB開発 (5) リクエスト・レスポンスデータ量の削減

高パフォーマンスなWEB開発 (5) リクエスト・レスポンスデータ量の削減

黄舟
リリース: 2016-12-16 15:34:09
オリジナル
1071 人が閲覧しました

GZIP圧縮
gzip は現在すべてのブラウザでサポートされている圧縮形式です。IE6 をサポートするには SP1 以降が必要です (まだ IE5 を使用していることは言うまでもありません、~_~)。 Gzip は最も便利であり、応答データの量を最小限に抑える方法であると言えます。

追加のコードを記述する必要がないため、http サーバーに構成を追加するだけで済み、さまざまなサーバーの構成がここに表示されます。 (実際には設定方法がわかりません)、


nginx の設定については、私の記事を参照してください: www.blogjava.net/BearRui/archive/2010/01/29/web_performance_server .html

まず、gzip の圧縮率がどれくらい高いかを見てみましょう。ここでは jquery を使用します。 1.4.2 の min と src の 2 つのバージョンがテストされました。nginx サーバーを使用して、gzip 圧縮レベルは 4 でした。

高パフォーマンスなWEB開発 (5) リクエスト・レスポンスデータ量の削減

上の図の赤い部分に注目してください。jquery src ファイルのサイズが小さくなりました。 gzip 有効化後 70%

高パフォーマンスなWEB開発 (5) リクエスト・レスポンスデータ量の削減

この図からわかるように、min.js が圧縮されている場合でも、gzip を有効化するとサイズが 65% 削減されています。


画像で gzip を有効にしないでください

gzip の強力な圧縮機能を理解した後、サーバー上のすべてのファイルに対して gzip を有効にしますか? まず、図で gzip を有効にした後に何が起こるかを見てみましょう。


高パフォーマンスなWEB開発 (5) リクエスト・レスポンスデータ量の削減

ほほ、gif画像をgzipで圧縮すると大きくなりますよね? ? ?これは、画像が元々圧縮形式であるため、gzip では圧縮できなくなり、代わりに追加のヘッダー情報が追加されるため、画像が大きくなります。

テスト中に、理由はわかりませんが、画像の圧縮方法に関係している可能性があるため、jpg 画像が gzip 圧縮後に小さくなることがわかりました。ただし、圧縮率は比較的低いので、jpgであってもgzip圧縮を有効にしないことをお勧めします。

gzip 圧縮を有効にするのに適したファイルは次のとおりです:

1. javascript

2. CSS

3. HTML、xml

4. プレーンテキスト




Cookie を使用しないでください

現在、Cookie を使用していない Web サイトはほとんどありませんが、Cookie にはパス (パス)、ドメイン (ドメイン)、有効期限 (有効期限) などのいくつかの重要な属性があります。ブラウザはこれら 3 つの属性を使用して、リクエストの送信時にこの Cookie を取得する必要があるかどうかを判断します。

​ Cookie を使用する最善の方法は、要求されたリソースで Cookie が必要な場合にのみ Cookie を取得することです。他のリクエストでは Cookie は提供されません。しかし実際には、多くの人が Cookie を使用するときに習慣的に path=/ に設定しています。 ドメイン=.ドメイン.com。その結果、画像 (img.domain.com)、静的リソース サーバー (res.domain.com)、および Cookie をまったく必要としないその他のリソースをリクエストした場合でも、ブラウザーはそれらを送信します。 . この役に立たないクッキー。実際の例、Blog Garden (www.cnblogs.com) を見てみましょう:

まず、Blog Garden の Cookie がどのように設定されているかを見てみましょう。これは、Firefox で Blog Garden の Cookie を表示するスクリーンショットです。

高パフォーマンスなWEB開発 (5) リクエスト・レスポンスデータ量の削減

cnblogs には合計 5 つの Cookie 値があり、すべての設定は path=/ です。 ドメイン=.cnblogs.com。 Cookie の設定がわかったら、ブログパークのホームページへのリクエストを監視してみましょう。監視されている統計情報は次のとおりです:


リクエストの総数: 39 (画像 22 個、JS 7 個、CSS 2 個を含む)。

このうち、js、css、画像は主に 3 つの静的リソース サーバー、common.cnblogs.com、 pic.cnblogs.com 、static.cnblogs.com

要求されたイメージの 1 つの要求ヘッダー (/upload/201005/20100514004349115.gif) を確認してください。 en-US; rv:1.9.2.3) Gecko/20100401 Firefox/3.6.3 GTBDFff GTB7.0

Accept image/png,image/*;q=0.8,*/*;q=0.5

Accept-Language zh-cn,en -us;q=0.7,en;q=0.3


Accept-Encoding gzip,deflate

Accept-Charset ISO-8859-1,utf-8;q=0.7,*;q=0.7

キープアライブ 115

プロキシ接続キープアライブ

リファラー http://www.cnblogs.com/

Cookie __gads=ID=a15d7cb5c3413e56:T=1272278620:S=ALNI_MZNMr6_d_PCjgkJNJeEQXkmZ3bxTQ; __utma=226521935.1697566422.1272278366.1272278366.1272278366.1; __utmb=226521935.2.10.1272278366; __utmc=226521935; __utmz=226521935.1272278367.1.1.utmcsr=(直接)|utmccn=(直接)|utmcmd=(なし)

画像 Banner_job.gif をリクエストすると、ブラウザは cnblogs.com の Cookie をすべて取得したことがわかりました (他の画像のリクエストも同様です)。Blog Park は画像を処理するときに Cookie を使用する必要はないと考えられます。おそらく、これらの Cookie のサイズはわずか約 300 バイトであり、問​​題ではないと思われるかもしれません。

簡単な計算をしてみましょう。ブログ パークには毎日 50W の PV があると仮定します (実際の状況では、各 PV に約 15 件の静的リソースのリクエストがあり、15*500000*300/1024/1024=2145M)。つまり、これらの Cookie はブログ パークの帯域幅を毎日約 2G 消費することになります。もちろん、静的リソースのキャッシュを考慮していないため、この単純な計算方法には誤差が必ずあります。しかし、個人的には、ブログ パークが Cookie のドメインを www.cnblogs.com に設定した方がよいのではないかと考えています。



204ステータスの素晴らしい使い方

http の 200、404、500 ステータスは誰もが知っていますが、204 ステータスは、サーバーがクライアント要求を正常に処理したが、コンテンツが返されなかったことを意味します。 204 は HTTP で最もデータ量が少ない応答ステータスです。204 応答にはボディがなく、Content-Length=0 です。多くの人が ajax を使用して、サーバーにデータを返さずにサーバーにデータを送信する場合、サーバー側で次のコードを使用します: response.getWriter().print("")。これは空白のページを返します。 200をリクエストします。まだ本文があり、Content-Length は 0 に等しくなりません。実際、この時点で 204 ステータス (response.setStatus(204)) を直接返すことができます。 204 は、一部の Web サイト分析コードで最も一般的に使用されます。必要なのは、Google ホームページの 204 応答を見てみましょう。ただし、Google ホームページの最後のリクエストでは、204 ステータスが返されます。このリクエストが何に使われるのか分かりません:


高パフォーマンスなWEB開発 (5) リクエスト・レスポンスデータ量の削減

上記は、高パフォーマンスな WEB 開発 (5) リクエストとレスポンスのデータ量の削減についてです。その他の関連記事は、こちらに注目してください。 PHP 中国語 Web サイト (www.php.cn)!


ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート