Installation du module PageSpeed pour Nginx sur Debian 9

Comment compiler Nginx avec ngx_pagespeed pour optimiser automatiquement les performances de votre site web.

ngx_pagespeed est un module Nginx qui optimise automatiquement vos pages web — compression des images, minification du CSS et du JavaScript, gestion du cache, et bien plus encore — sans toucher à une seule ligne du code de votre site.

Avant de commencer

Ce guide implique de recompiler Nginx depuis les sources. Assurez-vous d'avoir une sauvegarde de votre configuration Nginx actuelle et notez vos flags de compilation existants — vous en aurez besoin.

Installation des dépendances de compilation

sudo apt-get build-dep nginx
sudo apt-get update
sudo apt-get install build-essential zlib1g-dev libpcre3 libpcre3-dev unzip uuid-dev

Création du répertoire de travail

mkdir ~/custom-nginx
cd ~/custom-nginx

Téléchargement des sources Nginx

Vérifiez la version de Nginx actuellement installée :

nginx -v
nginx version: nginx/1.18.0

Téléchargez l'archive source correspondante depuis le site officiel de Nginx :

sudo wget http://nginx.org/download/nginx-1.18.0.tar.gz
sudo tar zxvf nginx-1.18.0.tar.gz

Mise en place de ngx_pagespeed

Accédez au répertoire des modules Nginx :

cd nginx-1.18.0/src/http/modules/

Téléchargez ngx_pagespeed depuis son dépôt GitHub :

sudo wget https://github.com/pagespeed/ngx_pagespeed/archive/master.zip
sudo unzip master.zip
sudo mv incubator-pagespeed-ngx-master ngx_pagespeed
cd ngx_pagespeed

Téléchargez les PageSpeed Optimization Libraries (psol) — nécessaires à la compilation :

sudo wget https://dl.google.com/dl/page-speed/psol/1.13.35.2-x64.tar.gz
sudo tar -xzvf 1.13.35.2-x64.tar.gz

Compilation de Nginx avec le module pagespeed

Revenez dans le répertoire des sources Nginx :

cd ~/custom-nginx/nginx-1.18.0/

Vérifiez d'abord les flags de compilation de votre Nginx actuel — vous devrez les reproduire :

nginx -V

Lancez ./configure avec ces mêmes flags en ajoutant --add-module à la fin :

sudo ./configure \
  --prefix=/etc/nginx \
  --sbin-path=/usr/sbin/nginx \
  --modules-path=/usr/lib/nginx/modules \
  --conf-path=/etc/nginx/nginx.conf \
  --error-log-path=/var/log/nginx/error.log \
  --http-log-path=/var/log/nginx/access.log \
  --pid-path=/var/run/nginx.pid \
  --lock-path=/var/run/nginx.lock \
  --http-client-body-temp-path=/var/cache/nginx/client_temp \
  --http-proxy-temp-path=/var/cache/nginx/proxy_temp \
  --http-fastcgi-temp-path=/var/cache/nginx/fastcgi_temp \
  --http-uwsgi-temp-path=/var/cache/nginx/uwsgi_temp \
  --http-scgi-temp-path=/var/cache/nginx/scgi_temp \
  --user=nginx \
  --group=nginx \
  --with-compat \
  --with-file-aio \
  --with-threads \
  --with-http_addition_module \
  --with-http_auth_request_module \
  --with-http_dav_module \
  --with-http_flv_module \
  --with-http_gunzip_module \
  --with-http_gzip_static_module \
  --with-http_mp4_module \
  --with-http_random_index_module \
  --with-http_realip_module \
  --with-http_secure_link_module \
  --with-http_slice_module \
  --with-http_ssl_module \
  --with-http_stub_status_module \
  --with-http_sub_module \
  --with-http_v2_module \
  --with-mail \
  --with-mail_ssl_module \
  --with-stream \
  --with-stream_realip_module \
  --with-stream_ssl_module \
  --with-stream_ssl_preread_module \
  --with-cc-opt='-g -O2 -fstack-protector-strong -Wformat -Werror=format-security -Wp,-D_FORTIFY_SOURCE=2 -fPIC' \
  --with-ld-opt='-Wl,-z,relro -Wl,-z,now -Wl,--as-needed -pie' \
  --add-module=./src/http/modules/ngx_pagespeed/

Utilisez toujours les flags issus de votre propre sortie nginx -V — ils peuvent différer de l'exemple ci-dessus selon la façon dont le paquet a été compilé sur votre système.

Compilez et installez :

sudo make
sudo make install

Activation de ngx_pagespeed

Créez un répertoire de cache pour le module :

sudo mkdir -p /var/ngx_pagespeed_cache
sudo chown -R www-data:www-data /var/ngx_pagespeed_cache

Ouvrez la configuration principale de Nginx :

sudo nano /etc/nginx/nginx.conf

Ajoutez les lignes suivantes dans le bloc http :

##
# Pagespeed Settings
##
pagespeed on;
pagespeed FileCachePath /var/ngx_pagespeed_cache;

Dans chaque bloc server, ajoutez ces règles de location :

# Acheminer correctement les requêtes vers les ressources optimisées par pagespeed
location ~ "\.pagespeed\.([a-z]\.)?[a-z]{2}\.[^.]{10}\.[^.]+" {
    add_header "" "";
}
location ~ "^/ngx_pagespeed_static/" { }
location ~ "^/ngx_pagespeed_beacon" { }

Redémarrez Nginx pour appliquer les modifications :

sudo service nginx restart

Vérification de l'installation

Vérifiez que le module apparaît bien dans les flags de compilation :

sudo /usr/sbin/nginx -V

Vous devriez voir --add-module=./src/http/modules/ngx_pagespeed/ dans la sortie.

Confirmez ensuite que le module est bien actif en inspectant les en-têtes de réponse :

curl -I -p YOUR_SERVER_IP

Une installation réussie inclura un en-tête X-Page-Speed dans la réponse :

HTTP/1.1 200 OK
Server: nginx
X-Page-Speed: 1.13.35.2-0
Cache-Control: max-age=0, no-cache

Cet en-tête confirme que ngx_pagespeed est installé et opérationnel.

Aide

Une question ou besoin d'un coup de main ? Écrivez-nous via le système de tickets — nous sommes toujours là pour vous aider !

Besoin d’aide?Nos ingénieurs vous aideront gratuitement pour n’importe quelle question en quelques minutesNous contacter