共计 4640 个字符,预计需要花费 12 分钟才能阅读完成。
1. Nginx 简介
Nginx (发音为[engine x]) 专为性能优化而开发,其最知名的优点是它的稳定性和低系统资源消耗,以及对并发连接的高处理能力(单台物理服务器可支持 30000~50000 个并发连接),是一个高性能的 HTTP 和反向代理服务器,也是一个 IMAP/POP3/SMTP 代理服。
Linux 系统:CentOS 7.3
2. 安装准备
2.1 gcc 安装
安装 nginx 需要先将官网下载的源码进行编译,编译依赖 gcc 环境,如果没有 gcc 环境,则需要安装:
[root@nginx ~]# yum -y install gcc-c++
2.2 pcre 安装
PCRE(Perl Compatible Regular Expressions) 是一个 Perl 库,包括 perl 兼容的正则表达式库。nginx 的 http 模块使用 pcre 来解析正则表达式,所以需要在 linux 上安装 pcre 库,pcre-devel 是使用 pcre 开发的一个二次开发库。nginx 也需要此库。
[root@nginx ~]# yum -y install pcre pcre-devel
2.3 zlib 安装
zlib 库提供了很多种压缩和解压缩的方式,nginx 使用 zlib 对 http 包的内容进行 gzip,所以需要在 Centos 上安装 zlib 库。
[root@nginx ~]# yum -y install zlib zlib-devel
2.4 OpenSSL 安装
OpenSSL 是一个强大的安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功能及 SSL 协议,并提供丰富的应用程序供测试或其它目的使用。
nginx 不仅支持 http 协议,还支持 https(即在 ssl 协议上传输 http),所以需要在 Centos 安装 OpenSSL 库。
[root@nginx ~]# yum -y install openssl openssl-devel
3. Nginx 安装
3.1 Nginx 版本
下载网址:https://nginx.org/en/download.html
选择最新的稳定版 nginx-1.12.2
版本说明:
Mainline version:Mainline 是 Nginx 目前主力在做的版本,可以说是开发版
Stable version:最新稳定版,生产环境上建议使用的版本
Legacy versions:遗留的老版本的稳定版
3.2 Nginx 下载
使用 wget 命令下载
[root@nginx ~]# wget -c https://nginx.org/download/nginx-1.12.2.tar.gz
如没有 wget 命令则安装:
[root@nginx ~]# yum -y install wget
3.3 解压
[root@nginx ~]# tar -zxvf nginx-1.12.2.tar.gz
3.4 安装配置
3.4.1 新建 nginx 用户和组
[root@nginx include]# groupadd nginx
[root@nginx include]# useradd -g nginx -d /home/nginx nginx
[root@nginx include]# passwd nginx
3.4.2 第三方模块安装
本文以安装第三方模块 sticky 为例,版本为 1.,2.5,下载地址:
可以到 Linux 公社资源站下载:
—————————————— 分割线 ——————————————
免费下载地址在 http://linux.linuxidc.com/
用户名与密码都是www.linuxidc.com
具体下载目录在 /2018 年资料 / 9 月 /27 日 /CentOS 7.3 编译安装 Nginx 1.12.2/
下载方法见 http://www.linuxidc.com/Linux/2013-07/87684.htm
—————————————— 分割线 ——————————————
上传解压:
[root@nginx ~]# tar -zxvf nginx-goodies-nginx-sticky-module-ng-08a395c66e42..gz
[root@nginx ~]# mv nginx-goodies-nginx-sticky-module-ng-08a395c66e42 nginx-sticky-1.2.5
3.4.3 安装
[root@nginx ~]# cd nginx-1.12.2
[root@nginx nginx-1.12.2]# ./configure –add-module=/root/nginx-sticky-1.2.5
指定用户、路径和模块配置(可选):
./configure \
–user=nginx –group=nginx \ #安装的用户组
–prefix=/usr/local/nginx \ #指定安装路径
–with-http_stub_status_module \ #监控 nginx 状态,需在 nginx.conf 配置
–with-http_ssl_module \ #支持 HTTPS
–with-http_sub_module \ #支持 URL 重定向
–with-http_gzip_static_module #静态压缩
–add-module=/root/nginx-sticky-1.2.5 #安装 sticky 模块
3.5 编译
[root@nginx nginx-1.12.2]# make && make install
报错:
/root/nginx-sticky-1.2.5//ngx_http_sticky_misc.c: 在函数‘ngx_http_sticky_misc_sha1’中:
/root/nginx-sticky-1.2.5//ngx_http_sticky_misc.c:176:15: 错误:‘SHA_DIGEST_LENGTH’未声明(在此函数内第一次使用)
u_char hash[SHA_DIGEST_LENGTH];
^
/root/nginx-sticky-1.2.5//ngx_http_sticky_misc.c:176:15: 附注:每个未声明的标识符在其出现的函数内只报告一次
/root/nginx-sticky-1.2.5//ngx_http_sticky_misc.c:176:10: 错误:未使用的变量‘hash’[-Werror=unused-variable]
u_char hash[SHA_DIGEST_LENGTH];
^
/root/nginx-sticky-1.2.5//ngx_http_sticky_misc.c: 在函数‘ngx_http_sticky_misc_hmac_sha1’中:
/root/nginx-sticky-1.2.5//ngx_http_sticky_misc.c:242:15: 错误:‘SHA_DIGEST_LENGTH’未声明(在此函数内第一次使用)
u_char hash[SHA_DIGEST_LENGTH];
解决方法:
修改 ngx_http_sticky_misc.c 文件,新增 #include <openssl/sha.h> 和 #include <openssl/md5.h> 模块
[root@nginx nginx-1.12.2]# sed -i ’12a #include <openssl/sha.h>’ /root/nginx-sticky-1.2.5/ngx_http_sticky_misc.c
[root@nginx nginx-1.12.2]# sed -i ’12a #include <openssl/md5.h>’ /root/nginx-sticky-1.2.5/ngx_http_sticky_misc.c
重新编译:
[root@nginx nginx-1.12.2]# make && make install
3.6 nginx 命令全局执行设置
[root@nginx bin]# cd /usr/local/nginx/sbin/
[root@nginx sbin]# ln -s /usr/local/nginx/sbin/nginx /usr/local/bin/nginx
4. Nginx 相关命令
4.1 版本查看
[root@nginx ~]# nginx -v
nginx version: nginx/1.12.2
4.2 查看加载的模块
[root@nginx ~]# nginx -V
nginx version: nginx/1.12.2
built by gcc 4.8.5 20150623 (Red Hat 4.8.5-28) (GCC)
configure arguments: –add-module=/root/nginx-sticky-1.2.5/
4.3 启停命令
4.3.1 启动
[root@nginx nginx-1.12.2]# nginx
4.3.2 停止
[root@nginx nginx-1.12.2]# nginx -s stop
[root@nginx nginx-1.12.2]# nginx -s quit
4.3.3 动态加载
[root@nginx nginx-1.12.2]# ngins -s reload
4.3.4 测试配置文件 nginx.conf 正确性
[root@nginx ~]# 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 -s quit: 此方式停止步骤是待 nginx 进程处理任务完毕进行停止。
nginx -s stop: 此方式相当于先查出 nginx 进程 id 再使用 kill 命令强制杀掉进程。
nginx -s reload: 动态加载,当配置文件 nginx.conf 有变化时执行该命令动态加载。
4.4 开机自启动
编辑 /etc/rc.d/rc.local 文件,新增一行 /usr/local/nginx/sbin/nginx
[root@nginx rc.d]# cd /etc/rc.d
[root@nginx rc.d]# sed -i ’13a /usr/local/nginx/sbin/nginx’ /etc/rc.d/rc.local
[root@nginx rc.d]# chmod u+x rc.local
5. 更改默认端口
编辑配置文件 /usr/local/nginx/conf/nginx.conf,将默认端口 80 修改为 81:
[root@nginx ~]# view /usr/local/nginx/conf/nginx.conf
加载配置:
[root@nginx ~]# nginx -s reload
6. 访问 Nginx
6.1 关闭防火墙
[root@nginx ~]# firewall-cmd –state
running
[root@nginx ~]# systemctl stop firewalld.service
[root@nginx ~]# firewall-cmd –state
not running
6.2 访问 Nginx
http://localhost:81
: