• ブログTOP
  • AI・ディープラーニング
  • AR
  • VR
  • WEBサイト
  • WEBマーケティング
  • SEO
  • SNS
  • その他
  • お問い合わせ

ALAKI株式会社

COZIKEEいつまでも使えるTech情報発信ブログ

  • ブログTOP
  • AI・ディープラーニング
  • AR
  • VR
  • WEBサイト
  • WEBマーケティング
  • SEO
  • SNS
  • その他
  • お問い合わせ

「gzip圧縮」でWebサイトを高速化しよう!【mod_rewrite編】

2017年12月15日

  • このエントリーをはてなブックマークに追加

こんにちは、Webプログラマの篠田です。

大阪では寒い日が続いています。

個人的に、夏の暑さも堪えますが、冬の寒さも苦手な典型的もやしっ子は、こたつに入りながら春の来るのを待ちたい気持ちです。

前回「『gzip圧縮』でWebサイトを高速化しよう!【mod_deflate編】
」では、「mod_deflate」を利用した「gzip圧縮」方法をご紹介しました。

今回は、サーバー負荷を軽減して「gzip圧縮」を行う方法「mod_rewrite」をご紹介します。

「mod_rewrite」を使って「gzip圧縮」を実現する理由

「mod_deflate」を利用した「gzip圧縮」方法は、記述内容も少なくサイトへの実装が非常に簡単です。

ですが、レンタルサーバー(特に、低価格な共用サーバー)によっては、サーバー負荷を懸念され「mod_deflate」の利用ができないものもあります。

その代案の1つとして「mod_rewrite」による「gzip圧縮」方法を選択するという場合もあります。

その他にも、サーバー負荷の軽減を目的として、あえて「mod_rewrite」を利用する場合もあります。

「mod_rewrite」を使っての「gzip圧縮」の注意点

「mod_rewrite」を利用した「gzip圧縮」方法は、事前に「gzip圧縮」を行ったファイルが必要となります。

そのため、「gzip圧縮」ファイルが無い状態で.htaccessを書き換えても、「gzip圧縮」転送は利用できません。

また、別途定期的な「gzip圧縮」処理の必要になりますので、注意しましょう。

事前に「gzip圧縮」されたファイルを用意するので、「mod_deflate」よりもサーバーに負荷が少ないという所以です。

サーバーで「gzip圧縮」を行う

「gzip圧縮」を行う場合、最も簡単なのはサーバーのコンソール画面で行う方法です。

下記のコマンドを、「gzip圧縮」を行いたいファイルがあるディレクトリで行います。

# gzip -c style.css > style.css.gz

「gzip」コマンドを実行して対象のファイルを、「gzip圧縮」することができます。

注意が必要なのは、「gzip」コマンドをオプション無しで実行すると、元のファイルが消えてしまう点です。
※ブラウザのリクエストに必要なのは「gzip圧縮」されたファイルのみなので、実体がなくてもページは表示されます。
ただし、すべてのブラウザが「gzip圧縮」に対応している訳ではないので、保険で実体はおいておくのが良いです。

「-c」オプションを付けることで、圧縮元のファイルを残して、圧縮ファイルを作成することができます。

これで、「gzip圧縮」ファイルの準備はできました。

.htaccessで「gzip圧縮」を有効化

最後に、.htaccessに「gzip圧縮」ファイルをブラウザに対して送信する設定になります。

<IfModule mod_rewrite.c>
#mod_rewriteを有効化
RewriteEngine on

#ブラウザからの「gzip圧縮」リクエストがあるかを確認
RewriteCond %{HTTP:Accept-Encoding} gzip

#要求されているファイルの拡張子を取得(今回はjsとcssのみ)
RewriteCond %{REQUEST_URI} (\.js|\.css)$

#要求されたファイル名に「.gz」の拡張子をつけたファイルがあるかを確認
RewriteCond %{REQUEST_FILENAME}\.gz -s

#最後にリクエストされたファイルから「gzip圧縮」済みファイルに置換します。
RewriteRule .* %{REQUEST_URI}.gz [L]
</IfModule>

#gzip版cssファイルタイプの変更
<FilesMatch "\.css\.gz$">
 ForceType text/css
 AddEncoding x-gzip .gz
</FilesMatch>

#gzip版jsファイルタイプの変更
<FilesMatch "\.js\.gz$">
 ForceType application/x-javascript
 AddEncoding x-gzip .gz
</FilesMatch>

これで、.htaccessの設定は完了です。

最後の「FilesMatch」設定は、通常「gzip圧縮」されたファイルは「application/gzip」または「application/x-gzip」として認識されます。

それでは、本来のCSSやJavaScriptとしてブラウザが読み込めないので、それぞれの「gzip圧縮」ファイルをCSSのファイルタイプ、JavaScriptのファイルタイプに変換するという処理が必要となります。

まとめ

「gzip圧縮」の情報は多くありますが、「mod_deflate版」か「mod_rewrite版」で、.htaccessの書き方も変わりますが、大きく異なる点は「gzip圧縮」ファイルを用意する必要があるかどうかです。

この点を間違えると、せっかくの設定が意味をなさなくなりますので、ご注意ください。

  • ツイート
  • このエントリーをはてなブックマークに追加

You may also like...

  • twig30分クッキング-基本編(1)-

    22 7月, 2016

  • 何となく使っているプログラム①-デバイス判定 編-

    21 11月, 2018

  • Laravel5.6でテンプレートエンジン「Twig」を使えるようにしよう!

    27 8月, 2018

  • Next story SNS運用でお悩みの方へ!<勤務時間短縮>と<業績アップ>を同時に実現する、クラウド型SNSマーケティングツール【KUKUL】をリリースしました。
  • Previous story イラストレーターがDTPの入稿前に確認しておくべきチェック項目一覧

運営会社

ALAKI株式会社 ALAKI株式会社採用サイト

弊社サービス

MUGHEN ALAKI クラウド型受発注システム さよなら過去のAR。WebARがイベント集客に革命を起こします。 広報活動の課題を数字で可視化し、出願者数アップをお手伝いします クリエイティブ業務のコミュニケーションを高速化 Webの知識が無くてもWebサイトの品質をチェックできます。

カテゴリー

  • AI・ディープラーニング
  • AR
  • BtoB
  • CMS
  • Git
  • Google AdWords
  • gulp
  • Javascript
  • Laravel
  • Photoshop
  • Pug
  • pyhotn
  • Sass
  • SEO
  • SNS
  • Twitter広告
  • VR
  • Web3.0
  • WEBサイト
  • WEBマーケティング
  • YouTube
  • コーディング
  • システム開発
  • スマートフォンサイト
  • セキュリティ
  • セミナー
  • その他
  • ツール
  • デザイン
  • ベトナムレポート
  • 仕事術
  • 未分類
  • 業務効率化
  • 色

アーカイブ

  • 2023年2月
  • 2023年1月
  • 2022年12月
  • 2022年11月
  • 2022年10月
  • 2022年9月
  • 2022年2月
  • 2021年12月
  • 2021年9月
  • 2021年7月
  • 2021年6月
  • 2020年10月
  • 2020年9月
  • 2020年8月
  • 2020年6月
  • 2019年6月
  • 2019年5月
  • 2019年4月
  • 2019年3月
  • 2019年2月
  • 2019年1月
  • 2018年12月
  • 2018年11月
  • 2018年9月
  • 2018年8月
  • 2018年7月
  • 2018年6月
  • 2018年5月
  • 2018年4月
  • 2018年3月
  • 2018年2月
  • 2018年1月
  • 2017年12月
  • 2017年11月
  • 2017年10月
  • 2017年9月
  • 2017年8月
  • 2017年7月
  • 2017年6月
  • 2017年4月
  • 2017年3月
  • 2017年2月
  • 2017年1月
  • 2016年12月
  • 2016年11月
  • 2016年10月
  • 2016年9月
  • 2016年8月
  • 2016年7月
  • 2016年6月
  • 2016年5月
  • 2016年4月
  • 2016年3月
  • 2016年2月
  • 2016年1月
  • 2015年12月
  • 2015年11月
  • 2015年10月
  • 2015年9月
  • 2015年7月
  • 2015年3月
  • 2015年2月
  • 2015年1月
  • 2014年12月
  • 2014年11月
  • 2014年10月
  • 2014年9月
  • 2014年8月
  • 2014年7月
  • 2014年6月
  • 2013年10月
  • 2013年9月

Facebook

お問い合わせ

お問い合わせ

人気の記事

  • 「SwinIR」で高画質化した画像を pythonを使用して一括で元のサイズに戻す方法
  • Web制作時に高解像度の元画像がない場合にPythonで高画質化する方法
  • 『考える』が楽しくなる!考えを「広げる」・「深める」12の方法
  • macにpythonの開発環境を作ってみよう!
  • 商品・サービスを圧倒的に成長させる、シリコンバレーで注目の「プロダクト・レッド・グロース」を解説

カテゴリー

  • AI・ディープラーニング
  • AR
  • BtoB
  • CMS
  • Git
  • Google AdWords
  • gulp
  • Javascript
  • Laravel
  • Photoshop
  • Pug
  • pyhotn
  • Sass
  • SEO
  • SNS
  • Twitter広告
  • VR
  • Web3.0
  • WEBサイト
  • WEBマーケティング
  • YouTube
  • コーディング
  • システム開発
  • スマートフォンサイト
  • セキュリティ
  • セミナー
  • その他
  • ツール
  • デザイン
  • ベトナムレポート
  • 仕事術
  • 未分類
  • 業務効率化
  • 色

検索

ALAKI株式会社 © 2026. All Rights Reserved.