zoukankan      html  css  js  c++  java
  • Linux上安装nginx

    环境:centos7   nginx1.16.1(源码安装)

    一、下载nginx源码包

      地址:http://nginx.org/en/download.html

      Mainline version(主线版本)Stable version(稳定版本)Legacy versions(传统老版本)

      下载稳定版:nginx-1.16.1.tar.gz

    二、安装相关依赖

      gcc  gcc-c++  zlib  zlib-devel  openssl  openssl-devel  pcre  pcre-devel

      gcc,gcc-c++  #c,c++编译器,用来编译安装

      zlib,zlib-devel  #压缩和解压的函数库,网页文件压缩要用到它

      openssl,openssl-devel  #网络通信安全协议库,包含众多的密码算法、公钥基础设施标准以及SSL协议

    三、安装Nginx

      (1).解包

      [root@izm5e8nyz28va3a786y465z src]# tar -zxvf nginx-1.16.1.tar.gz 

      (2).编译配置(进入到解压的文件夹)./configure  --选项   

        ./configure  --prefix=/usr/local/nginx/  --sbin-path=/usr/local/nginx/sbin/  --conf-path=/usr/local/nginx/conf/
     --error-log-path=/usr/local/nginx/logs/error.log  --pid-path=/usr/local/nginx/run/nginx.pid  --http-log-path=/usr/local/nginx/logs/access.log
     --http-client-body-temp-path=/usr/local/nginx/tmp/client/  --http-proxy-temp-path=/usr/local/nginx/tmp/proxy/
     --http-fastcgi-temp-path=/usr/local/nginx/tmp/fcgi/  --with-http_ssl_module  --with-http_flv_module  --with-http_gzip_static_module
     --with-http_stub_status_module --with-http_realip_module  --with-pcre --user=nginx --group=nginx

        注意:1 若设置了用户名,用户组,则安装前先创建用户:useradd -M -s /sbin/nologin

             2 若设置了文件路径,则先创建相关目录,并将目录用户所有者,所属组设为配置的值。路径是目录则最后以'/'结尾,以免出错。

             如 =/usr/local/nginx/conf/ 如果结尾没/,conf会被当做文件

        1. 路径配置(不设置则为默认路径)

        --prefix=/usr/local/nginx1.16.1  #nginx的安装路径,所有其它路径都要依赖该选项

        --sbin-path=/usr/sbin/nginx   #指定nginx二进制文件的路径,不指定则:/usr/local/nginx/sbin/nginx

        --conf-path=/etc/nginx/nginx.conf  #nginx配置文件路径,不指定则:/usr/local/nginx/conf/nginx.conf

        --error-log-path=/var/log/nginx/error.log  #nginx错误日志路径,不指定则:/usr/local/nginx/logs/error.log

        --pid-path=/var/run/nginx/nginx.pid  #pid文件路径,不指定则:/usr/local/nginx/logs/nginx.pid

        --http-log-path=/var/log/nginx/access.log  #http访问日志路径

        --http-client-body-temp-path=/var/tem/nginx/client  #存储客户端请求主主体的临时目录

        --http-proxy-temp-path=/var/tem/nginx/proxy #存储代理服务器接收数据的临时文件 

        --http-fastcgi-temp-path=/var/tem/nginx/fcgi  # 设置存储HTTP fastcgi的临时文件的路径 

        2.模块配置

        --http_v2_module      #用于支持http2协议

        --with-http_ssl_module      #用于支持https协议

        --with-http_flv_module    #视频直播模块

        --with-http_gzip_module   #是nginx默认编译的模块,对网页文件压缩

        --with-http_gzip_static_module   #加载gz静态缓存模块,开启后服务器优先返回gz文件    

        --with-http_stub_status_module  #http服务状态模块

        3. 其它功能启用

        --with-pcre  #设置pcre库源码路径,若是yum安装则是默认路径不用写。用以开启对正则表达式支持

        --with-openssl  #启用OpenSSL(安全套接字层密码库)启用后可支持https,ssl证书

        3.用户,用户组配置

         --user=www  #nginx工作进程的用户名,默认:user为  nobody;

         nobody 是系统用户,是一个不能登陆的帐号,一个特殊用途的用户 ID,uid<500一般都是系统ID

         --group=www   #nginx工作进程的用户组,默认:group  nogroup

            nginx 只有一个主进程和多个工作进程,主进程主要读取和评估配置文件正确性,以及管理工作进程

          工作进程是真正的网络请求处理的进程

       (3)编译 

         make    

       (4)安装

         make  install 

    四、nginx服务控制

      1. 启动nginx

      [root@izm5e8nyz28va3a786y465z tmp]# nginx

       nginx: [emerg] mkdir() "/var/tem/nginx/client" failed (2: No such file or directory)

      原因:缺少这个文件夹,nobody默认用户没有权限穿件这个文件夹

       创建:mkdir  -p  /var/tem/nginx/

       修改所有者:chown  nobody  /var/tem/nginx/

       之后,nginx能正常启动

      若要访问到nginx主页,则需要开放80端口,或直接关闭防火墙

      关闭防火墙:(不推荐)

        1. firewall-cmd  --state  #查看防火墙状态,running  /  no running

        2. systemctl stop firewalld.service  #关闭防火墙

        3. systemctl disable firewalld.service  #禁止开机启动

      开放80端口:

        1. firewall-cmd --list-port  #查看开放的端口信息

        2. firewall-cmd --query-port=80/tcp  #查看80端口是否开放

        3. firewall-cmd --zone=public --add-port=80/tcp --permanent  #开放80端口(--permanent永久生效)

        4. firewall-cmd --reload  #重启防火墙

      2. 服务控制

        nginx指令官方文档:https://www.nginx.com/resources/wiki/start/topics/tutorials/commandline/#upgrading-to-a-new-binary-on-the-fly

        nginx服务在运行时,会保持一个主进程和一个或多个 worker process 工作进程。可以通过给Nginx服务的主进程发送信号来控制服务

        2种发送信号的方式:

          一、nginx二进制文件自带的命令(信号控制,向nginx主程序发送信号,执行相应的操作)

          二、kill 命令(系统通过pid控制进程)

       nginx命令:

        注:如果没有设置路径,则要进入/usr/local/nginx/sbin/nginx/ 目录后才能使用下列命令,否则无法识别nignx命令

                  nginx –s  stop/start/reload/quit    #/停止/启动/重启/请求结束后退出

                  nginx -t                #检测配置文件是否正确 

        nginx -V            #查看编译时配置信息和版本号 

                  nginx -v               #查看nginx版本号

                  nginx -h               #查看nginx命令帮助

        nginx -p            #设置nginx安装路径

        nginx -c filename     #用指定的配置文件启动Nginx服务

        nginx -g directives   #nginx启动时执行的指令

              kill命令:kill  single  主进程号 (实际使用中多用此种方式)

        注:pid 可以通过cat  /usr/local/nginx/logs/nginx.pid  命令查看(前提设置过pid位置)。nginx对linux信号的处理如下:
        QUIT     #停止服务(子进程全部结束后关闭主进程)
        TERM或INT  #直接停止服务(不管子进程是否结束)
        HUP      #平缓重启(不重载配置文件)
        USR1       #重读日志文件
        USR2       #平滑升级
       常用组合命令:
        nginx -g -c conffile  pid  #以指定配置文件,平滑重启,若启动失败,则以老的配置文件启动nginx
        nginx  -tc  filename        #检测指定nginx配置文件,并启动
        kill -QUIT $(cat /usr/local/nginx1.16.1/logs/nginx.pid)   #免去手动查询pid
         
        判断nginx是否启动的方式:
          1. ps -ef |grep nginx  //查看进程列表,过滤出nginx
          2. 
         
      3. nginx平滑升级的实现
       相关解释:
          平滑重启:当WorkerMan主进程收到平滑重启信号时,主进程会向其中一个子进程发送安全退出(让对应进程处理完毕当前请求后才退出)信号,当这个进程
        退出后,主进程会重新创建一个新的子进程(这个子进程载入了新的PHP代码),然后主进程再次向另外一个旧的进程发送停止命令,这样一个进程一个进程的
        重启,直到所有旧的进程全部被置换为止。(只有子进程加载的文件支持平滑重启)
          平滑升级:在不停止nginx服务,不丢失任何请求的情况下,更新nginx版本或服务模块。
         当需要更新nginx版本,nginx模块时,可以进行平滑升级,实现步骤如下:
        (1)用新的nginx二进制文件(/usr/local/nginx/sbin)替换旧的
        (2kill -URS2  $(cat /usr/local/nginx1.16.1/logs/nginx.pid)  #向nginx主进程发送USR2信号
          nginx主进程接收到USR2信号,将nginx.pid改名为nginx.pid.oldbin,然后执行nginx启动脚本,启动一个新的nginx主进程和若干新工作进程
        (3)kill -WINCH  $(cat /usr/local/nginx1.16.1/logs/nginx.pid.oldbin)  #优雅地结束旧进程的子进程
          nginx主进程接收到WINCH信号,让旧进程的子进程停止接受请求,并在完成请求后退出,旧进程的请求转到新进程。
        (4)选择使用新的nginx还是旧的nginx服务(如果新的不稳定可以退回旧的)
          一段时间后,旧的子进程会全部退出,只保留旧的主进程和新nginx服务
          a:选择回到旧的nginx
          kill -HUP  oldpid     #旧的主进程开启工作进程,启动旧的nginx服务(不会重读配置文件)
          kill -QUIT  newpid  #优雅停止新的nginx进程
          当新的nginx主进程和工作进程全部停止后,nginx老的工作进程会改回原来的pid文件,一切恢复到未升级状态
          b:选择新的nginx进程
          kill -QUIT  oldpid    #直接结束旧的nginx主进程就OK了
          注意:如果新的nginx进程和旧的nginx安装路径不同,nginx -p  newpath  指定新进程的启动脚本位置后,再发送USR2信号。
          
  • 相关阅读:
    JS pop push unshift shift的作用与区别
    白话js this指向问题
    JS作用域,作用域,作用链详解
    angular $q promise详解
    白话$resource,$resource中的增删改查
    ng-app与ng-app='myApp'的区别
    详解 高效字节流
    详解 字节输出流 与 字节输入流
    阶段性复习与应用——复制多级文件夹
    详解 字节流
  • 原文地址:https://www.cnblogs.com/fanshehu/p/11840572.html
Copyright © 2011-2022 走看看