Nginx系列:Nginx源码安装
共 2792字,需浏览 6分钟
·
2020-08-16 11:35
阅读文本大概需要3分钟。
Nginx是使用C语言开发的,建议部署在Linux操作系统上,当然也可以安装在Windows操作系统安装Windows版本的Nginx,本文演示在CentOS操作系统上安装源码安装Nginx。
0x01:安装依赖库
以下命令均需root权限执行
gcc 安装
源码安装 Nginx需要对在官网下载的Nginx源码进行编译,编译依赖 gcc 环境,如果没有 gcc 环境,则需要先安装
yum install gcc gcc-c++
PCRE pcre-devel 安装
PCRE(Perl Compatible Regular Expressions) 是一个Perl库,包括 perl 兼容的正则表达式库。nginx 的 http 模块使用 pcre 来解析正则表达式,所以需要在 linux 上安装 pcre 库,pcre-devel 是使用 pcre 开发的一个二次开发库。nginx也需要此库。
yum install -y pcre pcre-devel
zlib 安装
zlib 库提供了很多种压缩和解压缩的方式, Nginx使用 zlib 对 http 包的内容进行 gzip ,所以需要在 CentOS上安装 zlib 库。
yum install -y zlib zlib-devel
OpenSSL 安装
OpenSSL 是一个强大的安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功能及 SSL 协议,并提供丰富的应用程序供测试或其它目的使用。Nginx不仅支持 http 协议,而且支持 https(即在ssl协议上传输http),所以需要在 CentOS安装 OpenSSL 库。
yum install -y openssl openssl-devel
以上安装可以整合成一条命令
yum -y install gcc gcc-c++ pcre pcre-devel \
zlib zlib-devel openssl openssl-devel
0x02:创建Nginx用户及Nginx用户组
先创建一个名为nginx且没有登录权限的用户和一个名为nginx的用户组
创建Nginx用户组
创建`nginx`用户组(`-r`选项表示创建一个系统用户组)
groupadd -r nginx
创建用户并加入到nginx系统用户组
创建Nginx用户
useradd -r -g nginx -s /sbin/nologin -d /usr/local/nginx -M nginx
-r: 添加系统用户( 这里指将要被创建的系统用户`nginx`)
-g: 指定要创建的用户所属组( 这里指添加新系统用户`nginx`到`nginx`系统用户组 )
-s: 新帐户的登录`shell`( `/sbin/nologin` 这里设置为将要被创建系统用户`nginx`不能用来登录系统 )
-d: 新帐户的主目录( 这里指定将要被创建的系统用户`nginx`的家目录为 `/usr/local/nginx` )
-M: 不要创建用户的主目录( 也就是说将要被创建的系统用户`nginx`不会在 `/home` 目录下创建 `nginx` 家目录 )
0x03:源码安装Nginx
下载Nginx
wget http://nginx.org/download/nginx-1.16.1.tar.gz
解压
tar -zxvf nginx-1.16.1.tar.gz -C ./nginx
编译安装Nginx
cd ./nginx/nginx-1.16.1/
./configure --prefix=/usr/local/nginx --user=nginx --group=nginx
make
make install
这样就安装成功了。安装成功后,如何要查看Nginx内置模块或者查看自定义模块
查看Nginx内置模块
cat ./auto/options | grep YES
查看自定义模块
目前还没有添加第三方自定义模块
添加第三方模块
/usr/local/nginx/sbin/nginx -V
/root/nginx/nginx-1.16.1/configure 上条命令的configure arguments值 \
--add-module=THIRD_MODULE_PATH
实际上就是下载对应版本的Nginx源码包、解压后,然后带上之前的./configure参数 + 第三方模块重新编译
0x04:验证是否安装成功
一些常用的启动、关闭、加强配置命令
cd /usr/local/nginx/sbin/
./nginx # 启动
./nginx -s stop #关闭
./nginx -s quit
./nginx -s reload #重新加载配置
启动成功后访问:http://127.0.0.1:8080
./nginx -s quit:此方式停止步骤是待nginx进程处理任务完毕进行停止。
./nginx -s stop:此方式相当于先查出nginx进程id再使用kill命令强制杀掉进程。
0x05:生产环境一些非常有用的经验
先停止再启动(推荐)
对 nginx 进行重启相当于先停止再启动,即先执行停止命令再执行启动命令。
./nginx -s quit
./nginx
修改nginx.conf后,重新加载配置文件
当nginx的配置文件nginx.conf修改后,要想让配置生效需要重启nginx,使用nginx -s reload不用先停止nginx,再启动nginx。即可将配置信息在 nginx中生效。
./nginx -s reload
开机自启动Nginx
在rc.local增加启动代码就可以了
vi /etc/rc.local
即增加一行
/usr/local/nginx/sbin/nginx
设置rc.local文件执行权限
chmod 755 rc.local
参考:
https://www.cnblogs.com/liujuncm5/p/6713784.html
https://segmentfault.com/a/1190000016498647
☆
往期精彩
☆
02 Nacos源码编译
关注我
每天进步一点点