在 CentOS 7 上使用 ngx_pagespeed 安装 Nginx
在此页
- 1 更新系统
- 2 安装所需的依赖项
- 3 使用 Ngx-pagespeed 编译 Nginx
- 4 创建 Nginx 启动脚本
- 5 配置 Nginx
- 6 测试 Ngx-pagespeed
- 结论
Ngx-pagespeed 是一个免费的开源 Nginx 模块,可用于加速您的站点并减少页面加载时间。它的工作原理是自动将 Web 性能最佳实践应用于页面和相关资产,而无需您修改现有内容或工作流程。您可以使用 Ngx-pagespeed 模块轻松优化各种文件,例如 CSS、HTML、png 和 jpg。
Ngx-pagespeed 有很多特性,下面列出了其中一些特性:
- 支持图像动态调整大小、重新压缩和优化。
- 小资源内联。
- HTML 重写。
- 缓存寿命延长。
- 延迟 JavaScript 和图像加载。
在本教程中,我们将讨论如何在 CentOS 7 服务器上使用 ngx_pagespeed 模块编译 Nginx。
要求
- 在您的系统上安装全新的 CentOS 7 服务器。
- 具有 root 权限的 Sudo 用户。
1 更新系统
让我们首先将您的系统更新到最新的稳定版本。您可以通过运行以下命令来执行此操作:
sudo yum update -y
更新系统后,重新启动系统并使用 sudo 用户登录。
2 安装需要的依赖
你需要安装一些包来编译 Nginx。您可以通过运行以下命令来安装所有这些依赖项:
sudo yum install gcc cmake unzip wget gcc-c++ pcre-devel zlib-devel -y
安装所有必需的依赖项后,您可以继续下一步。
3 使用Ngx-pagespeed编译Nginx
要使用 ngx-pagespeed 模块安装 Nginx,您需要从源代码编译 Nginx。首先,您需要下载 Nginx 源代码。您可以通过运行以下命令来下载它:
wget http://nginx.org/download/nginx-1.12.0.tar.gz
要使用 ngx_pagespeed 模块编译 Nginx,您还需要下载 ngx_pagespeed 源码包。您可以使用以下命令下载它:
wget https://github.com/pagespeed/ngx_pagespeed/archive/v1.12.34.2-stable.zip
下载两个包后,使用以下命令解压缩它们:
tar -xvzf nginx-1.12.0.tar.gz
tar -xvzf v1.12.34.2-stable.zip
接下来,您还需要下载 PageSpeed 优化库来编译 Nginx。您可以使用以下命令下载它:
cd ngx_pagespeed-1.12.34.2-stable
wget https://dl.google.com/dl/page-speed/psol/1.12.34.2-x64.tar.gz
tar -xvzf 1.12.34.2-x64.tar.gz
cd ..
现在,让我们开始使用 pagespeed 模块编译 Nginx。
首先,使用以下命令将目录更改为 Nginx 源目录:
cd nginx-1.12.0
接下来,使用以下命令配置 Nginx 源:
sudo ./configure --add-module=$HOME/ngx_pagespeed-1.12.34.2-stable --user=nobody --group=nobody --pid-path=/var/run/nginx.pid ${PS_NGX_EXTRA_FLAGS}
配置完成后,运行以下命令编译Nginx:
sudo make
上面的命令将花费几分钟。之后,您可以通过运行以下命令来安装 nginx:
sudo make install
安装 Nginx 后,您需要为 Nginx 创建一个符号链接:
sudo ln -s /usr/local/nginx/conf/ /etc/nginx
sudo ln -s /usr/local/nginx/sbin/nginx /usr/sbin/nginx
4 创建Nginx启动脚本
您还需要为 Nginx 创建一个启动脚本来停止和启动 Nginx。您可以通过在 /etc/init.d 目录中创建 nginx 文件来做到这一点:
sudo nano /etc/init.d/nginx
添加以下行:
#!/bin/sh
#
# nginx - this script starts and stops the nginx daemon
#
# chkconfig: - 85 15
# description: NGINX is an HTTP(S) server, HTTP(S) reverse \
# proxy and IMAP/POP3 proxy server
# processname: nginx
# config: /etc/nginx/nginx.conf
# config: /etc/sysconfig/nginx
# pidfile: /var/run/nginx.pid
# Source function library.
. /etc/rc.d/init.d/functions
# Source networking configuration.
. /etc/sysconfig/network
# Check that networking is up.
[ "$NETWORKING" = "no" ] && exit 0
nginx="/usr/sbin/nginx"
prog=$(basename $nginx)
NGINX_CONF_FILE="/etc/nginx/nginx.conf"
[ -f /etc/sysconfig/nginx ] && . /etc/sysconfig/nginx
lockfile=/var/lock/subsys/nginx
make_dirs() {
# make required directories
user=`$nginx -V 2>&1 | grep "configure arguments:.*--user=" | sed 's/[^*]*--user=\([^ ]*\).*/\1/g' -`
if [ -n "$user" ]; then
if [ -z "`grep $user /etc/passwd`" ]; then
useradd -M -s /bin/nologin $user
fi
options=`$nginx -V 2>&1 | grep 'configure arguments:'`
for opt in $options; do
if [ `echo $opt | grep '.*-temp-path'` ]; then
value=`echo $opt | cut -d "=" -f 2`
if [ ! -d "$value" ]; then
# echo "creating" $value
mkdir -p $value && chown -R $user $value
fi
fi
done
fi
}
start() {
[ -x $nginx ] || exit 5
[ -f $NGINX_CONF_FILE ] || exit 6
make_dirs
echo -n $"Starting $prog: "
daemon $nginx -c $NGINX_CONF_FILE
retval=$?
echo
[ $retval -eq 0 ] && touch $lockfile
return $retval
}
stop() {
echo -n $"Stopping $prog: "
killproc $prog -QUIT
retval=$?
echo
[ $retval -eq 0 ] && rm -f $lockfile
return $retval
}
restart() {
configtest || return $?
stop
sleep 1
start
}
reload() {
configtest || return $?
echo -n $"Reloading $prog: "
killproc $nginx -HUP
RETVAL=$?
echo
}
force_reload() {
restart
}
configtest() {
$nginx -t -c $NGINX_CONF_FILE
}
rh_status() {
status $prog
}
rh_status_q() {
rh_status >/dev/null 2>&1
}
case "$1" in
start)
rh_status_q && exit 0
$1
;;
stop)
rh_status_q || exit 0
$1
;;
restart|configtest)
$1
;;
reload)
rh_status_q || exit 7
$1
;;
force-reload)
force_reload
;;
status)
rh_status
;;
condrestart|try-restart)
rh_status_q || exit 0
;;
*)
echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload|configtest}"
exit 2
esac
完成后保存并关闭文件,然后授予其执行权限:
sudo chmod +x /etc/init.d/nginx
现在启动 nginx 服务并使用以下命令使其在启动时启动:
sudo systemctl start nginx
sudo systemctl enable nginx
完成后,您可以继续下一步。
5 配置 Nginx
现在,Nginx 安装了 ngx-pagespeed 支持。默认情况下禁用 PageSpeed。在启用它之前,建议测试您的网站速度。接下来,您需要为 ngx-pagespeed 创建一个缓存目录,并将其所有权分配给 Nginx:
sudo mkdir -p /var/ngx_pagespeed_cache
sudo chown -R nobody:nobody /var/ngx_pagespeed_cache
接下来,您需要对 /etc/nginx/nginx.conf 文件进行一些更改。您可以通过运行以下命令来执行此操作:
sudo nano /etc/nginx/nginx.conf
在服务器块之间添加以下代码:
# Pagespeed main settings
pagespeed on;
pagespeed FileCachePath /var/ngx_pagespeed_cache;
# 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" { }
注意:如果您使用的是虚拟主机,则将上述 pagespeed 指令添加到每个服务器块配置文件中,以在每个网站上启用 pagespeed。
完成后保存并关闭文件,然后使用以下命令检查 Nginx 是否存在任何配置错误:
sudo nginx -t
如果一切正常,您应该会看到以下输出:
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
最后,重启 Nginx 以使更改生效:
sudo systemctl restart nginx
配置 Nginx 后,您可以继续测试 Ngx-pagespeed。
6 测试 Ngx-pagespeed
Nginx 现已启动并运行。是时候检查模块是否正常工作了。您可以通过运行以下命令来检查它:
curl -I -p http://localhost
您应该看到以下输出:
HTTP/1.1 200 OK
Server: nginx/1.12.0
Content-Type: text/html
Connection: keep-alive
Vary: Accept-Encoding
Date: Wed, 21 Jun 2017 17:21:08 GMT
X-Page-Speed: 1.12.34.2-0
Cache-Control: max-age=0, no-cache
您应该在上面的输出中看到 X-Page-Speed 及其版本号。这意味着你已经在你的服务器上成功安装了 Ngx_pagespeed。
结论
恭喜!您已经成功安装了支持 Ngx-pagespeed 模块的 Nginx。我希望您现在可以轻松地将它部署到生产环境中。如果您有任何问题,请随时给我评论。