Adding nginx modules to Linux

Description of instructions to add Nginx modules on Linux (Debian/Ubuntu/CentOS)

When installing nginx on Linux, it is not possible to configure the installation to add or remove modules and nginx is installed "as is".

If any module needs to be added, nginx needs to be rebuilt manually.

# nginx -V
nginx version: nginx/1.12.1
built by gcc 4.8.5 20150623 (Red Hat 4.8.5-11) (GCC) 
built with OpenSSL 1.0.1e-fips on Feb 11, 2013
TLS SNI support enabled
configure arguments: --prefix=/etc/nginx --conf-path=/etc/nginx/nginx.conf --error-log-path=/var/log/nginx/error.log
--http-client-body-temp-path=/var/lib/nginx/body --http-fastcgi-temp-path=/var/lib/nginx/fastcgi
--http-log-path=/var/log/nginx/access.log --http-proxy-temp-path=/var/lib/nginx/proxy --lock-path=/var/lock/nginx.lock
--pid-path=/var/run/nginx.pid --with-pcre-jit --with-http_gzip_static_module --with-http_ssl_module --with-ipv6
--without-http_browser_module -without-http_geo_module -without-http_limit_req_module -without-http_limit_zone_module
--without-http_memcached_module -without-http_referer_module -without-http_scgi_module -without-http_split_clients_module
--with-http_stub_status_module -without-http_ssi_module -without-http_userid_module -without-http_uwsgi_module
--add-module=/tmp/buildd/nginx-1.12.0/debian/modules/nginx-echo

Let's save the output of the nginx -V command to a text editor. This information will be useful for configuring the system We see that we have nginx version 1.12.1 installed - download the same version:

# wget http://nginx.org/download/nginx-1.12.1.tar.gz

Unpack the archive and go to the folder nginx-1.12.1:

# tar -xvf nginx-1.12.1.tar.gz
# cd nginx-1.12.1

Next, you will need to install a preinstalled set of modules.

# bash <(curl -f -L -sS https://ngxpagespeed.com/install) \
     --nginx-version $nginxversion

Save all modules:

bash <(curl -f -L -sS https://ngxpagespeed.com/install) -m

After installing the packages, proceed to configure nginx with the addition of modules.

To do this copy from a text editor the output of the command nginx -V starting from --prefix= to the first --add-module= (all the --add_module= present in the output are not needed) After that we write in the console ./configure and paste copied from the editor:

./configure --prefix=/etc/nginx --conf-path=/etc/nginx/nginx.conf --error-log-path=/var/log/nginx/error.log
--http-client-body-temp-path=/var/lib/nginx/body --http-fastcgi-temp-path=/var/lib/nginx/fastcgi
--http-log-path=/var/log/nginx/access.log --http-proxy-temp-path=/var/lib/nginx/proxy --lock-path=/var/lock/nginx.lock
--pid-path=/var/run/nginx.pid --with-pcre-jit --with-http_gzip_static_module --with-http_ssl_module --with-ipv6
--without-http_browser_module -without-http_geoip_module -without-http_memcached_module -without-http_referer_module
--without-http_scgi_module -without-http_split_clients_module -without-http_stub_status_module -without-http_ssi_module
--without-http_userid_module -without-http_uwsgi_module 

At the end of the line add --add-dynamic-module=/root/incubator-pagespeed-ngx-latest-stable to make it like this:

./configure --prefix=/etc/nginx --conf-path=/etc/nginx/nginx.conf --error-log-path=/var/log/nginx/error.log
--http-client-body-temp-path=/var/lib/nginx/body --http-fastcgi-temp-path=/var/lib/nginx/fastcgi
--http-log-path=/var/log/nginx/access.log --http-proxy-temp-path=/var/lib/nginx/proxy --lock-path=/var/lock/nginx.lock
--pid-path=/var/run/nginx.pid --with-pcre-jit --with-http_gzip_static_module --with-http_ssl_module --with-ipv6
--without-http_browser_module -without-http_geoip_module -without-http_memcached_module -without-http_referer_module
--without-http_scgi_module -without-http_split_clients_module -without-http_stub_status_module -without-http_ssi_module
--without-http_userid_module -without-http_uwsgi_module 
--add-dynamic-module=/root/incubator-pagespeed-ngx-latest-stable

Press Enter and wait for the process to finish.

Now you can build the nginx binary - run 2 commands:

# make
# make install

After completing the build, check that nginx is built with the module we want:

# /etc/nginx/sbin/nginx -V

Result:

nginx version: nginx/1.12.1
TLS SNI support enabled
configure arguments: ./configure --prefix=/etc/nginx --conf-path=/etc/nginx/nginx.conf --error-log-path=/var/log/nginx/error.log
--http-client-body-temp-path=/var/lib/nginx/body --http-fastcgi-temp-path=/var/lib/nginx/fastcgi
--http-log-path=/var/log/nginx/access.log --http-proxy-temp-path=/var/lib/nginx/proxy --lock-path=/var/lock/nginx.lock
--pid-path=/var/run/nginx.pid --with-pcre-jit --with-http_gzip_static_module --with-http_ssl_module --with-ipv6
--without-http_browser_module -without-http_geoip_module -without-http_memcached_module -without-http_referer_module
--without-http_scgi_module -without-http_split_clients_module -without-http_stub_status_module -without-http_ssi_module
--without-http_userid_module -without-http_uwsgi_module 
--add-dynamic-module=/root/incubator-pagespeed-ngx-latest-stable

As you can see, --add-dynamic-module=/root/incubator-pagespeed-ngx-latest-stable is present in the output of the command. It remains to replace the current nginx binary with the new one we just built.

Let's stop nginx:

# service nginx stop

Rename (just in case) the current nginx to nginx_back:

# mv /usr/sbin/nginx /usr/sbin/nginx_back

Move the newly built binary in its place:

# mv /etc/nginx/sbin/nginx /usr/sbin/nginx

Delete the unnecessary /etc/nginx/sbin folder:

# rm -r -f /etc/nginx/sbin

Check again that we have the right nginx now:

# nginx -V

Result:

nginx version: nginx/1.12.1
TLS SNI support enabled
configure arguments: ./configure --prefix=/etc/nginx --conf-path=/etc/nginx/nginx.conf --error-log-path=/var/log/nginx/error.log
--http-client-body-temp-path=/var/lib/nginx/body --http-fastcgi-temp-path=/var/lib/nginx/fastcgi
--http-log-path=/var/log/nginx/access.log --http-proxy-temp-path=/var/lib/nginx/proxy --lock-path=/var/lock/nginx.lock
--pid-path=/var/run/nginx.pid --with-pcre-jit --with-http_gzip_static_module --with-http_ssl_module --with-ipv6
--without-http_browser_module -without-http_geoip_module -without-http_memcached_module -without-http_referer_module
--without-http_scgi_module -without-http_split_clients_module -without-http_stub_status_module -without-http_ssi_module
--without-http_userid_module -without-http_uwsgi_module 
--add-dynamic-module=/root/incubator-pagespeed-ngx-latest-stable

Run nginx:

# service nginx start

Delete unnecessary nginx-1.12.1 folder:

# cd ../
# rm -r -f nginx-1.12.1
Need help?Our engineers will help you free of charge with any question in minutesContact us