Fornex
Европейский
хостинг

    ngx_pagespeed (или просто pagespeed) – это модуль Nginx, предназначенный для автоматической оптимизации работы сайта путём сокращения времени загрузки сайта в браузере.

    Загрузка исходного кода и зависимостей

    Для начала нужно обновить систему до последней стабильной версии:

    sudo yum update -y  
    

    Далее, загрузите все необходимые для компиляции и тестирования программы:

    sudo yum install wget curl unzip gcc-c++ pcre-devel zlib-devel  
    

    Затем создайте в домашнем каталоге папку для загрузки пакета Nginx.

    mkdir ~/custom-nginx  
    

    Откройте эту папку:

    cd ~/custom-nginx  
    

    Далее загрузите исходный пакет Nginx с официального сайта.

    sudo wget http://nginx.org/download/nginx-1.16.1.tar.gz  
    
    [root@kvmde54-19861 custom-nginx]# sudo wget http://nginx.org/download/nginx-1.16.1.tar.gz  
    --2020-06-24 15:15:43--  http://nginx.org/download/nginx-1.16.1.tar.gz
    Resolving nginx.org (nginx.org)... 2001:1af8:4060:a004:21::e3, 62.210.92.35, 95.211.80.227  
    Connecting to nginx.org (nginx.org)|2001:1af8:4060:a004:21::e3|:80... connected.  
    HTTP request sent, awaiting response... 200 OK  
    Length: 1032630 (1008K) [application/octet-stream]  
    Saving to: 'nginx-1.16.1.tar.gz'  
    
    100%[========================================================>] 1,032,630   --.-K/s   in 0.1s  
    
    2020-06-24 15:15:43 (10.1 MB/s) - 'nginx-1.16.1.tar.gz' saved [1032630/1032630]  
    

    Распакуйте полученный архив:

    sudo tar zxvf nginx-1.16.1.tar.gz  
    

    Запросите контент папки ~/custom-nginx:

    ls ~/custom-nginx  
    

    Команда покажет вывод:

    [root@kvmde54-19861 custom-nginx]# ls ~/custom-nginx
    nginx-1.16.1  nginx-1.16.1.tar.gz  
    

    Чтобы добавить модуль ngx_pagespeed, нужно сначала открыть папку modules в каталоге nginx-1.16.1:

    cd nginx-1.16.1/src/http/modules/  
    

    В этот каталог нужно загрузить архив ngx_pagespeed из репозитория Github.

    sudo wget https://github.com/pagespeed/ngx_pagespeed/archive/master.zip  
    

    После завершения загрузки разархивируйте архив:

    sudo unzip master.zip  
    

    Для удобства переименуйте его в ngx_pagespeed:

    sudo mv incubator-pagespeed-ngx-master ngx_pagespeed  
    

    Откройте каталог:

    cd ngx_pagespeed  
    

    Загрузите в него пакет PageSpeed Optimization Libraries (psol), необходимый для компиляции:

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

    В завершение извлеките архив psol в каталог ngx_pagespeed:

    sudo tar -xzvf 1.13.35.2-x64.tar.gz  
    

    Настройка и компиляция исходного кода

    Теперь нужно отредактировать код Nginx и добавить в него модуль pagespeed. Откройте родительский каталог кода Nginx:

    cd ~/custom-nginx/nginx-1.16.1/  
    

    Смотрим конфигурацию уже установленного nginx в системе:

    # nginx -V
    
    nginx -V  
    nginx version: nginx/1.16.1  
    built by gcc 4.8.5 20150623 (Red Hat 4.8.5-36) (GCC)  
    built with OpenSSL 1.0.2k-fips  26 Jan 2017  
    TLS SNI support enabled  
    configure arguments: --prefix=/etc/nginx --sbin-path=/usr/sbin/nginx --modules-path=/usr/lib64/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='-O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector-strong --param=ssp-buffer-size=4 -grecord-gcc-switches -m64 -mtune=generic -fPIC' --with-ld-opt='-Wl,-z,relro -Wl,-z,now -pie'
    
    

    Соберем nginx из исходников:

    # sudo ./configure __параметры_у_старого_nginx_ --add-module=:
    
    sudo ./configure --prefix=/etc/nginx --sbin-path=/usr/sbin/nginx --modules-path=/usr/lib64/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='-O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector-strong --param=ssp-buffer-size=4 -grecord-gcc-switches -m64 -mtune=generic -fPIC' --with-ld-opt='-Wl,-z,relro -Wl,-z,now -pie' --add-module=./src/http/modules/ngx_pagespeed/  
    

    После попытки сборки Nginx может возникнуть ошибка:

    ./configure: error: SSL modules require the OpenSSL library.
    You can either do not enable the modules, or install the OpenSSL library  
    into the system, or build the OpenSSL library statically from the source  
    with nginx by using --with-openssl=<path> option.  
    

    В этом случае необходимо установить недостающие пакеты и повторить попытку:

    yum install libssl-dev  
    и  
    yum install -y openssl-devel  
    
    [root@kvmde54-19861 nginx-1.16.1]# sudo ./configure --prefix=/etc/nginx --sbin-path=/usr/sbin/nginx --modules-path=/usr/lib64/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='-O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector-strong --param=ssp-buffer-size=4 -grecord-gcc-switches -m64 -mtune=generic -fPIC' --with-ld-opt='-Wl,-z,relro -Wl,-z,now -pie' --add-module=./src/http/modules/ngx_pagespeed/
    checking for OS  
     + Linux 3.10.0-1127.8.2.el7.x86_64 x86_64
    checking for C compiler ... found  
     + using GNU C compiler
     + gcc version: 4.8.5 20150623 (Red Hat 4.8.5-39) (GCC) 
    checking for gcc -pipe switch ... found  
    checking for --with-ld-opt="-Wl,-z,relro -Wl,-z,now -pie" ... found  
    checking for -Wl,-E switch ... found  
    checking for gcc builtin atomic operations ... found  
    checking for C99 variadic macros ... found  
    checking for gcc variadic macros ... found  
    checking for gcc builtin 64 bit byteswap ... found  
    checking for unistd.h ... found  
    checking for inttypes.h ... found  
    checking for limits.h ... found  
    checking for sys/filio.h ... not found  
    checking for sys/param.h ... found  
    checking for sys/mount.h ... found  
    checking for sys/statvfs.h ... found  
    checking for crypt.h ... found  
    checking for Linux specific features  
    checking for epoll ... found  
    checking for EPOLLRDHUP ... found  
    checking for EPOLLEXCLUSIVE ... not found  
    checking for O_PATH ... found  
    checking for sendfile() ... found  
    checking for sendfile64() ... found  
    checking for sys/prctl.h ... found  
    checking for prctl(PR_SET_DUMPABLE) ... found  
    checking for prctl(PR_SET_KEEPCAPS) ... found  
    checking for capabilities ... found  
    checking for crypt_r() ... found  
    checking for sys/vfs.h ... found  
    checking for poll() ... found  
    checking for /dev/poll ... not found  
    checking for kqueue ... not found  
    checking for crypt() ... not found  
    checking for crypt() in libcrypt ... found  
    checking for F_READAHEAD ... not found  
    checking for posix_fadvise() ... found  
    checking for O_DIRECT ... found  
    checking for F_NOCACHE ... not found  
    checking for directio() ... not found  
    checking for statfs() ... found  
    checking for statvfs() ... found  
    checking for dlopen() ... not found  
    checking for dlopen() in libdl ... found  
    checking for sched_yield() ... found  
    checking for sched_setaffinity() ... found  
    checking for SO_SETFIB ... not found  
    checking for SO_REUSEPORT ... found  
    checking for SO_ACCEPTFILTER ... not found  
    checking for SO_BINDANY ... not found  
    checking for IP_TRANSPARENT ... found  
    checking for IP_BINDANY ... not found  
    checking for IP_BIND_ADDRESS_NO_PORT ... found  
    checking for IP_RECVDSTADDR ... not found  
    checking for IP_SENDSRCADDR ... not found  
    checking for IP_PKTINFO ... found  
    checking for IPV6_RECVPKTINFO ... found  
    checking for TCP_DEFER_ACCEPT ... found  
    checking for TCP_KEEPIDLE ... found  
    checking for TCP_FASTOPEN ... found  
    checking for TCP_INFO ... found  
    checking for accept4() ... found  
    checking for kqueue AIO support ... not found  
    checking for Linux AIO support ... found  
    checking for int size ... 4 bytes  
    checking for long size ... 8 bytes  
    checking for long long size ... 8 bytes  
    checking for void * size ... 8 bytes  
    checking for uint32_t ... found  
    checking for uint64_t ... found  
    checking for sig_atomic_t ... found  
    checking for sig_atomic_t size ... 4 bytes  
    checking for socklen_t ... found  
    checking for in_addr_t ... found  
    checking for in_port_t ... found  
    checking for rlim_t ... found  
    checking for uintptr_t ... uintptr_t found  
    checking for system byte ordering ... little endian  
    checking for size_t size ... 8 bytes  
    checking for off_t size ... 8 bytes  
    checking for time_t size ... 8 bytes  
    checking for AF_INET6 ... found  
    checking for setproctitle() ... not found  
    checking for pread() ... found  
    checking for pwrite() ... found  
    checking for pwritev() ... found  
    checking for sys_nerr ... found  
    checking for localtime_r() ... found  
    checking for clock_gettime(CLOCK_MONOTONIC) ... found  
    checking for posix_memalign() ... found  
    checking for memalign() ... found  
    checking for mmap(MAP_ANON|MAP_SHARED) ... found  
    checking for mmap("/dev/zero", MAP_SHARED) ... found  
    checking for System V shared memory ... found  
    checking for POSIX semaphores ... not found  
    checking for POSIX semaphores in libpthread ... found  
    checking for struct msghdr.msg_control ... found  
    checking for ioctl(FIONBIO) ... found  
    checking for struct tm.tm_gmtoff ... found  
    checking for struct dirent.d_namlen ... not found  
    checking for struct dirent.d_type ... found  
    checking for sysconf(_SC_NPROCESSORS_ONLN) ... found  
    checking for sysconf(_SC_LEVEL1_DCACHE_LINESIZE) ... found  
    checking for openat(), fstatat() ... found  
    checking for getaddrinfo() ... found  
    configuring additional modules  
    adding module in ./src/http/modules/ngx_pagespeed/  
    mod_pagespeed_dir=./src/http/modules/ngx_pagespeed//psol/include  
    build_from_source=false  
    checking for psol ... found  
    List of modules (in reverse order of applicability): ngx_http_write_filter_module ngx_http_header_filter_module ngx_http_chunked_filter_module ngx_http_v2_filter_module ngx_http_range_header_filter_module ngx_pagespeed_etag_filter ngx_http_gzip_filter_module ngx_pagespeed ngx_http_postpone_filter_module ngx_http_ssi_filter_module ngx_http_charset_filter_module ngx_http_sub_filter_module ngx_http_addition_filter_module ngx_http_gunzip_filter_module ngx_http_userid_filter_module ngx_http_headers_filter_module  
    checking for psol-compiler-compat ... found  
     + ngx_pagespeed was configured
    checking for PCRE library ... found  
    checking for PCRE JIT support ... found  
    checking for OpenSSL library ... found  
    checking for zlib library ... found  
    creating objs/Makefile  
    
    Configuration summary  
      + using threads
      + using system PCRE library
      + using system OpenSSL library
      + using system zlib library
    
      nginx path prefix: "/etc/nginx"
      nginx binary file: "/usr/sbin/nginx"
      nginx modules path: "/usr/lib64/nginx/modules"
      nginx configuration prefix: "/etc/nginx"
      nginx configuration file: "/etc/nginx/nginx.conf"
      nginx pid file: "/var/run/nginx.pid"
      nginx error log file: "/var/log/nginx/error.log"
      nginx http access log file: "/var/log/nginx/access.log"
      nginx http client request body temporary files: "/var/cache/nginx/client_temp"
      nginx http proxy temporary files: "/var/cache/nginx/proxy_temp"
      nginx http fastcgi temporary files: "/var/cache/nginx/fastcgi_temp"
      nginx http uwsgi temporary files: "/var/cache/nginx/uwsgi_temp"
      nginx http scgi temporary files: "/var/cache/nginx/scgi_temp"
    

    Завершив настройку, запустите компиляцию:

    sudo make  
    

    После этого можно установить программу:

    sudo make install  
    

    После этого мы увидим что модуль добавлен:

    [root@kvmde54-19861 nginx-1.16.1]# nginx -V
    nginx version: nginx/1.16.1  
    built by gcc 4.8.5 20150623 (Red Hat 4.8.5-39) (GCC)  
    built with OpenSSL 1.0.2k-fips  26 Jan 2017  
    TLS SNI support enabled  
    configure arguments: --prefix=/etc/nginx --sbin-path=/usr/sbin/nginx --modules-path=/usr/lib64/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='-O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector-strong --param=ssp-buffer-size=4 -grecord-gcc-switches -m64 -mtune=generic -fPIC' --with-ld-opt='-Wl,-z,relro -Wl,-z,now -pie' --add-module=./src/http/modules/ngx_pagespeed/
    
    

    Пользовательская установка Nginx хранится в каталоге /usr/local/nginx. Теперь нужно создать две символьные ссылки.

    Одна из них – на конфигурационный файл:

    sudo ln -s /usr/local/nginx/conf/ /etc/nginx  
    

    Теперь конфигурационные файлы будут доступны в каталоге /etc/nginx/.

    Вторая ссылка – на главный бинарный файл в каталоге /usr/sbin/. Для этого выполните команду:

    sudo ln -s /usr/local/nginx/sbin/nginx /usr/sbin/nginx  
    

    Создание сценария запуска

    Предыдущий процесс установки выполняет создание необходимой учётной записи пользователя и группы, при помощи которых будет работать Nginx.

    Для начала создайте новый файл в каталоге /etc/init.d/:

    sudo nano /etc/init.d/nginx  
    

    Затем перейдите по этой ссылке, скопируйте скрипт и вставьте его в файл.

    Сделайте скрипт исполняемым, запустив команду:

    sudo chmod +x /etc/init.d/nginx  
    

    После этого можно запустить Nginx:

    sudo service nginx start  
    

    Чтобы Nginx автоматически запускался и останавливался вместе с сервером, добавьте в уровни запуска следующую команду:

    sudo chkconfig nginx on  
    

    Включение модуля pagespeed

    После установки сервера Nginx нужно включить ngx_pagespeed.

    Но сначала нужно создать папку, в которой модуль сможет хранить кэш файлов сайта:

    sudo mkdir -p /var/ngx_pagespeed_cache  
    

    Передайте права на эту папку пользователю Nginx, чтобы веб-сервер имел необходимый уровень доступа.

    sudo chown -R nobody:nobody /var/ngx_pagespeed_cache  
    

    Откройте главный конфигурационный файл Nginx, nginx.conf, для редактирования:

    sudo nano /etc/nginx/nginx.conf  
    

    Добавьте в блок http следующие строки:

    # Pagespeed main settings
    pagespeed on;  
    pagespeed FileCachePath /var/ngx_pagespeed_cache;  
    

    Конфигурацию pagespeed нужно добавить в блок server и сохранить изменения:

    # Ensure requests for pagespeed optimized resources go to the pagespeed
    # handler and no extraneous headers get set.
    location ~ "\.pagespeed\.([a-z]\.)?[a-z]{2}\.[^.]{10}\.[^.]+" { add_header "" ""; }  
    location ~ "^/ngx_pagespeed_static/" { }  
    location ~ "^/ngx_pagespeed_beacon" { }  
    

    file

    Перезапустите Nginx:

    sudo service nginx restart  
    

    Теперь проверим, является ли модуль работающим или нет. Вы можете проверить его, выполнив следующую команду:

    curl -I -p http://localhost  
    

    Вы должны увидеть следующий вывод:

    [root@kvmde54-19861 /]# curl -I -p http://localhost
    HTTP/1.1 200 OK  
    Server: nginx  
    Content-Type: text/html  
    Connection: keep-alive  
    Keep-Alive: timeout=30  
    Date: Thu, 25 Jun 2020 15:07:35 GMT  
    X-Page-Speed: 1.13.35.2-0  
    Cache-Control: max-age=0, no-cache  
    

    Вы должны увидеть X-Page-Speed ​​и номер версии в выводе выше. Это означает, что вы успешно установили Ngx_pagespeed на сервере.


    Если у Вас возникли трудности в настройке или появились дополнительные вопросы, вы всегда можете обращаться в нашу службу поддержки через систему тикетов.