1. 安装依赖包和必要的库
1.1 安装依赖包
# yum -y install gcc gcc-c++ automake autoconf make libtool
这些依赖包是编译所必需的,如果yum上没有的话可以去下载源码来安装
1.2 安装必要的库
这些库都是nginx中一些功能模块所依赖的,如without-http_gzip_module需要zlib库来构建和运行此模块,http_rewrite_module需要pcre库来构建和运行此模块,http_ssl_module需要OpenSSL库来构建和运行此模块
1.安装pcre库(版本8.42)
# wget http://ftp.pcre.org/pub/pcre/pcre-8.42.tar.gz
# tar -zxvf pcre-8.42.tar.gz
# cd pcre-8.42
# ./configure
# make && make install
# pcre-config --version
注:也可用 yum install pcre-devel 替代
2.安装zlib库(版本1.2.11)
# wget http://www.zlib.net/zlib-1.2.11.tar.gz
# tar -zxvf zlib-1.2.11.tar.gz
# cd zlib-1.2.11
# ./configure
# make && make install
- 注:也可用
yum install zlib-devel
替代
3.安装OpenSSL(版本1.1.0h)
# wget https://www.openssl.org/source/openssl-1.1.0h.tar.gz
# tar -zxvf openssl-1.1.0h.tar.gz
# cd openssl-1.1.0h
# ./config
# make && make install
- 注:也可用
yum install openssl-devel
替代
问题
在Centos7上编译安装openssl后,运行openssl version
出现如下错误:
openssl: error while loading shared libraries: libssl.so.1.1: cannot open shared object file: No such file or directory
这是由于openssl库的位置不正确造成的。
解决方法:
在root用户下执行:
ln -s /usr/local/lib64/libssl.so.1.1 /usr/lib64/libssl.so.1.1
ln -s /usr/local/lib64/libcrypto.so.1.1 /usr/lib64/libcrypto.so.1.1
**以上三个可以用YUM安装**
# yum -y pcre-devel zlib-devel openssl-devl
2. 选择稳定nginx版本
centos的yum不提供nginx安装,通过配置官方yum源的方式获取到的也只是源码包。所以我们找到了Nginx官网看下官方提供的安装方式:Nginx源码包下载的官网地址(http://nginx.org/en/download.html)
从官网上提供三个类型的版本,分别是Mainline version、Stable version、Legacy versions
- Mainline version:Mainline 是 Nginx 目前主力在做的版本,可以说是开发版
- Stable version:最新稳定版,生产环境上建议使用的版本
- Legacy versions:遗留的老版本的稳定版
在这里我们选择Stable 版本的 nginx-1.12.2.tar.gz
安装过程所执行的命令需要root权限,所以我们选择使用root用户安装。
2.1 添加用户和用户组
# groupadd -r www
# useradd -r -g www www
groups 查看当前登录用户的组内成员
groups www 查看www用户所在的组,以及组内成员
whoami 查看当前登录用户名
2.2 nginx编译选项详解
# wget http://nginx.org/download/nginx-1.12.2.tar.gz
# tar -zxvf nginx-1.12.2.tar.gz
# cd nginx-1.12.2.tar
# ./configure --help
可以在编译时./configure –help列出大部分常用模块和编译选项,列出的编译选项中以–without开头的都默认安装,以PATH结尾的需要手动指定依赖库源码目录。
完整编译指令
./configure \ --prefix=/usr/local/nginx \ --user=www \ --group=www \ --with-http_realip_module \ --with-http_ssl_module \
--with-http_sub_module \ --with-http_stub_status_module \ --with-http_gzip_static_module \ --with-zlib=/data/soft/zlib/zlib-1.2.11 \ --with-pcre=/data/soft/pcre/pcre-8.42 \ --with-openssl=/data/soft/openssl/openssl-1.1.0h \
注意:如果不指定 --with-zlib 或 --with-pcre 或 --with-openssl,则使用系统,前提是使用yum安装 zlib-devel,pcre-devel,openssl-devl
nginx安装
# make && make install
2.3 nginx相关命令
2.3.1 检查配置文件是否正确
注意,启动前和修改了配置文件nginx.conf后最好先检查一下修改过的配置文件是否正确,以免重启后Nginx出现错误影响服务器稳定运行。判断Nginx配置是否正确命令如下:
# /usr/local/nginx/sbin/nginx -t
2.3.2 启动
# /usr/local/nginx/sbin/nginx # 默认配置文件 conf/nginx.conf, -c指定其他配置文件
启动成功会在logs目录中出现nginx.pid文件,即nginx进程号
若未成功可以查看logs目录下的error.log文件查看报错日志
2.3.3 平滑重启nginx
如果更改了配置就要重启Nginx,要先关闭Nginx再打开?不是的,可以向Nginx 发送信号,平滑重启。
/usr/local/nginx/sbin/nginx -s reload
或
kill -HUP 进程号或进程号文件路径
2.3.4 停止Nginx
停止操作是通过向nginx进程发送信号来进行的
步骤1:查询nginx主进程号
ps -ef | grep nginx
步骤2:发送信号
1.正常关闭
kill -QUIT 主进程号
- 2.快速停止Nginx:
kill -TERM 主进程号
- 3.强制停止Nginx:
pkill -9 nginx
Nginx 其他命令
以下包含了 Nginx 常用的几个命令:
/usr/local/nginx/sbin/nginx -t # 检查配置文件
/usr/local/nginx/sbin/nginx # 启动
/usr/local/nginx/sbin/nginx -s reload # 重新载入配置文件
/usr/local/nginx/sbin/nginx -s reopen # 重启 Nginx
/usr/local/nginx/sbin/nginx -s stop # 停止 Nginx
阿