NGINX的基本编译安装部署

  • yum自动安装,不支持自由扩展第三方功能
  • 源码编译安装,可以指定安装路径,并支持自由安装模块

安装前准备

  1. 安装GCC编译环境
[root@localhost ~]# yum install -y gcc gcc-c++ autoconf automake make
  1. 安装模块依赖

Nginx支持的功能模块需要有第三方的库支持,例如gzip的zlib库,rewrite重写需要的pcre库,HTTPS需要的openssl库等等。

[root@localhost ~]# yum install zlib zlib-devel openssl openssl-devel pcre pcre-devel wget httpd-tools vim -y

如果出现报错

错误: Multilib version problems found. This often means that the root
      cause is something else and multilib version checking is just
      pointing out that there is a problem. Eg.:
      
        1. You have an upgrade for zlib which is missing some
           dependency that another package requires. Yum is trying to
           solve this by installing an older version of zlib of the
           different architecture. If you exclude the bad architecture
           yum will tell you what the root cause is (which package
           requires what). You can try redoing the upgrade with
           --exclude zlib.otherarch ... this should give you an error
           message showing the root cause of the problem.
      
        2. You have multiple architectures of zlib installed, but
           yum can only see an upgrade for one of those architectures.
           If you don't want/need both architectures anymore then you
           can remove the one with the missing update and everything
           will work.
      
        3. You have duplicate versions of zlib installed already.
           You can use "yum check" to get yum show these errors.
      
      ...you can also use --setopt=protected_multilib=false to remove
      this checking, however this is almost never the correct thing to
      do as something else is very likely to go wrong (often causing
      much more problems).
      
      保护多库版本:zlib-1.2.7-20.el7_9.x86_64 != zlib-1.2.7-19.el7_9.i686

可以在后面添加命令 –setopt=protected_multilib=false

[root@localhost nginx-1.22.0]# yum install zlib zlib-devel Openssl openssl-devel pcre pcre-devel wget httpd-tools vim -y  --setopt=protected_multilib=false
  1. 安装系统基础开发环境
[root@localhost ~]# yum groupinstall "Development Tools" "Basic Web Server"
  1. 创建管理用户
[root@localhost ~]# useradd -s /sbin/nologin nginx

下载安装包

  1. 创建nginx文件夹,存储下载文件
[root@localhost ~]# mkdir nginx
[root@localhost ~]# ls
anaconda-ks.cfg  nginx  perl5
  1. nginx官网下载安装包,本教程的安装包为nginx1.22
[root@localhost nginx]# wget http://nginx.org/download/nginx-1.22.0.tar.gz
--2022-06-17 21:45:11--  http://nginx.org/download/nginx-1.22.0.tar.gz
正在解析主机 nginx.org (nginx.org)... 52.58.199.22, 3.125.197.172, 2a05:d014:edb:5702::6, ...
正在连接 nginx.org (nginx.org)|52.58.199.22|:80... 已连接。
已发出 HTTP 请求,正在等待回应... 200 OK
长度:1073322 (1.0M) [application/octet-stream]
正在保存至: “nginx-1.22.0.tar.gz”

100%[==================================================>] 1,073,322    823KB/s 用时 1.3s   

2022-06-17 21:45:13 (823 KB/s) - 已保存 “nginx-1.22.0.tar.gz” [1073322/1073322])

[root@localhost nginx]# ls
nginx-1.22.0.tar.gz
  1. 使用tar命令,解压到当前文件夹
[root@localhost nginx]# tar -zxf nginx-1.22.0.tar.gz 
[root@localhost nginx]# ll
总用量 1056
drwxr-xr-x. 8 1001 1001    4096 5月  24 07:59 nginx-1.22.0
-rw-r--r--. 1 root root 1073322 5月  24 22:29 nginx-1.22.0.tar.gz
  1. 让vim系统识别Nginx语法
[root@localhost nginx]# cd nginx-1.22.0/
[root@localhost nginx-1.22.0]# ls
auto  CHANGES  CHANGES.ru  conf  configure  contrib  html  LICENSE  man  README  src
[root@localhost nginx-1.22.0]# mkdir ~/.vim
[root@localhost nginx-1.22.0]# cp -r contrib/vim/* ~/.vim/

编译安装三部曲

  1. 编译Nginx,扩展编译模块
[root@localhost nginx-1.22.0]# ./configure --help  # 列出Nginx的编译选项,如制定安装路径,配置文件、日志文件等路径,指定开启模块功能等

[root@localhost nginx-1.22.0]# ./configure --prefix=/opt/Nginx1.22/ --with-http_ssl_module  --with-http_flv_module --with-http_gzip_static_module --with-http_stub_status_module  --with-threads  --with-file-aio
  1. 执行make,进行编译
[root@localhost nginx-1.22.0]# make
  1. make install 进行安装
[root@localhost nginx-1.22.0]# make install

配置Nginx环境变量

  1. 检查Prefix指定的安装目录
[root@localhost /]# ll opt
总用量 0
drwxr-xr-x. 2 root root 18 6月  15 18:16 linux_ic
drwxr-xr-x. 6 root root 50 6月  17 22:36 Nginx1.22
drwxr-xr-x. 2 root root  6 10月 31 2018 rh
  1. Nginx的程序目录
[root@localhost /]# cd /opt/Nginx1.22/
[root@localhost Nginx1.22]# pwd
/opt/Nginx1.22
[root@localhost Nginx1.22]# ls
conf  html  logs  sbin
  • conf:配置文件目录
  • html:静态文件
  • logs:日志文件目录
  • sbin:二进制命令文件
  1. 创建系统服务
[root@localhost ~]# echo  export PATH=/opt/Nginx1.22/sbin:$PATH >  /etc/profile.d/nginx.sh
  1. 重新登录终端,查看环境变量
[root@localhost ~]# echo $PATH
/root/perl5/bin:/opt/Nginx1.22/sbin:/root/perl5/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin:/root/bin
  1. 检查nginx版本和安装模块
[root@localhost ~]# nginx -V
nginx version: nginx/1.22.0
built by gcc 4.8.5 20150623 (Red Hat 4.8.5-44) (GCC) 
built with OpenSSL 1.0.2k-fips  26 Jan 2017
TLS SNI support enabled
configure arguments: --prefix=/opt/Nginx1.22/ --with-http_ssl_module --with-http_flv_module --with-http_gzip_static_module --with-http_stub_status_module --with-threads --with-file-aio

启动nginx

  1. 使用nginx命令启动
[root@localhost ~]# nginx
[root@localhost ~]# ps -ef | grep nginx
root     44184     1  0 23:09 ?        00:00:00 nginx: master process nginx
nobody   44185 44184  0 23:09 ?        00:00:00 nginx: worker process
root     44430 40561  0 23:09 pts/0    00:00:00 grep --color=auto nginx
[root@localhost ~]# netstat -tunlp |grep nginx
tcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      44184/nginx: master 
  1. 开放系统80端口
[root@localhost ~]# firewall-cmd --zone=public --add-port=80/tcp --permanent
success
[root@localhost ~]# firewall-cmd --reload
success

  1. 在浏览器中输入IP地址
NGINX的基本编译安装部署

文章来源:https://www.cnaaa.net,转载请注明出处:https://www.cnaaa.net/archives/4765

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022年6月17日 下午2:10
下一篇 2022年6月17日 下午11:43

相关推荐

  • LNMP黄金架构的搭建

    LNMP组合工作流程 LNMP工作流是用户通过浏览器输入域名访问Nginx web服务,Nginx判断请求是静态请求则由Nginx返回给用户。如果是动态请求(如.php结尾),那么Nginx会将该请求通过FastCGI接口发送给PHP引擎(php-fpm进程)进行解析,如果该动态请求需要读取mysql数据库,php会继续向后读取数据库,最终Nginx将获取的…

    2022年7月7日
    11000
  • 如何通过宝塔面板配置ssl证书

    至于宝塔的安装以及如何安装环境搭建网站,大家可以看我们的另一篇文章: Centos7.6下宝塔安装及资产管理系统部署 基于宝塔面板配置网站ssl证书支持https访问其实很简单,不需要你懂什么技术知识。接下来你跟着我的步骤,就能成功配置网站ssl。 宝塔面板后台设置成功如图所示: 第一步:点击设置 第二步:点击右侧的SSL,选择宝塔SSL,点击申请证书 第三…

    2022年6月14日
    12300
  • Php如何配置mysqli扩展

    从官网上下载php后(我下的是php7.2.3版本),本想做个mysql的连接,但是无论怎么配置mysqli扩展,发现mysqli都没法用。 从百度上搜的那些方法都没法用,发现都是一些在php.ini中配置extension=php_mysqli.dll,事实上这句话没用了。 于是我仔细看了一下php.ini的配置文件,发现了一段话 大意就是以前php些版本…

    2022年6月22日
    7500
  • Rabbitmq数据备份与还原

    一、场景 现在有服务器A和服务器B ,由于业务需要,要求把服务器A上mq的数据迁移到服务器B上,rabbitmq的数据包括元数据(RabbitMQ用户、vhost、队列、交换和绑定)和消息数据,而消息数据存储在单独的消息存储库中。 A:192.168.2.58 B:192.168.1.60 二、元数据备份和还原 1、操作 在服务B上搭建rabbitmq服务,…

    2022年11月15日
    1700
  • Nginx报 libraries: libgd.so.3错误

    在宝塔下安装nginx后,启动程序,有如下报错 进去系统,使用nginx -t 检查错误 通过检查发现,是缺少 libgd.so.3,缺少gd库 安装gd库 重新启动nginx,正常启动

    2022年7月6日
    8000

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注

评论列表(1条)

在线咨询: QQ交谈

邮件:712342017@qq.com

工作时间:周一至周五,8:30-17:30,节假日休息

关注微信