如何在Fedora 25上从源代码编译nginx

・10 分钟阅读

使用不同的系统?

NGINX可用作http/https服务器,反向代理服务器,邮件代理服务器,负载均衡器,TLS或缓存服务器,它使用模块化设计,拥有由社区创建的模块和第三方模块,它是用C编程语言编写的,是一个非常快速和轻量级的软件。

注:Nginx有两个版本流并行运行-稳定和主线,两个版本都可以在生产服务器上使用,建议在生产中使用主线版本。

从源代码安装NGINX相对"容易" - 下载最新版本的NGINX源代码,配置,构建和安装它。

在本教程中,我将使用主线版本,在本文编写时版本是1.13.3。

从源代码构建NGINX的要求

强制要求:

可选要求:

开始之前

  1. 创建sudo访问权限的常规用户

  2. 切换到新用户:

    
    su - <username>
    
    
  3. 更新系统:

    
    sudo dnf check-update || sudo dnf upgrade -y
    
    

从源代码生成Nginx

  1. 安装"开发工具",vim编辑器,wget和gcc-c:

    
    sudo dnf install -y @development-tools && sudo dnf install -y vim wget gcc-c++
    
    
  2. 下载最新的Nginx源代码主线本,并将它解压缩:

    
    wget https://nginx.org/download/nginx-1.13.3.tar.gz && tar zxvf nginx-1.13.3.tar.gz
    
    
  3. 下载Nginx依赖项源代码并提取它们:

    nginx依赖3个库 PCREzlibopenSSL

    
    # PCRE version 8.41
    wget https://ftp.pcre.org/pub/pcre/pcre-8.41.tar.gz && tar xzvf pcre-8.41.tar.gz
    
    # zlib version 1.2.11
    wget https://www.zlib.net/zlib-1.2.11.tar.gz && tar xzvf zlib-1.2.11.tar.gz
    
    # OpenSSL version 1.1.0f
    wget https://www.openssl.org/source/openssl-1.1.0f.tar.gz && tar xzvf openssl-1.1.0f.tar.gz
    
    
  4. 下载并安装可选的Nginx依赖项:

    
    # perl
    sudo dnf install -y perl perl-devel perl-ExtUtils-Embed
    
    # libxslt
    sudo dnf install -y libxslt libxslt-devel
    
    # libxml2
    sudo dnf install -y libxml2 libxml2-devel
    
    # libgd
    sudo dnf install -y gd gd-devel
    
    # GeoIP
    sudo dnf install -y GeoIP GeoIP-devel
    
    # Libatomic_Ops
    sudo dnf install -y libatomic_ops libatomic_ops-devel
    
    
  5. 删除所有.tar.gz文件,我们不再需要它们了:

     
    rm -rf *.tar.gz
    
     
  6. 转到Nginx源目录:

     
    cd ~/nginx-1.13.3
    
     
  7. 为了获得良好的度量,列出Nginx源代码文件和目录:

    
    ls
    # auto CHANGES CHANGES.ru conf configure contrib html LICENSE man README src
    
    
  8. 将Nginx手册页复制到/usr/share/man/man8/

    
    sudo cp ~/nginx-1.13.3/man/nginx.8 /usr/share/man/man8/
    sudo gzip /usr/share/man/man8/nginx.8
    # Check that Man page for NGINX is working
    man nginx
    
    
  9. 有关帮助,可以通过运行以下命令列出可用的配置开关:

    
    ./configure --help
    # To see want core modules can be build as dynamic run:
    ./configure --help | grep -F =dynamic
    
    
  10. 配置,编译和安装Nginx :

    
    ./configure --prefix=/etc/nginx 
     --sbin-path=/usr/sbin/nginx 
     --modules-path=/usr/lib64/nginx/modules 
     --conf-path=/etc/nginx/nginx.conf 
     --error-log-path=/var/log/nginx/error.log 
     --pid-path=/var/run/nginx.pid 
     --lock-path=/var/run/nginx.lock 
     --user=nginx 
     --group=nginx 
     --build=Fedora 
     --builddir=nginx-1.13.3 
     --with-select_module 
     --with-poll_module 
     --with-threads 
     --with-file-aio 
     --with-http_ssl_module 
     --with-http_v2_module 
     --with-http_realip_module 
     --with-http_addition_module 
     --with-http_xslt_module=dynamic 
     --with-http_image_filter_module=dynamic 
     --with-http_geoip_module=dynamic 
     --with-http_sub_module 
     --with-http_dav_module 
     --with-http_flv_module 
     --with-http_mp4_module 
     --with-http_gunzip_module 
     --with-http_gzip_static_module 
     --with-http_auth_request_module 
     --with-http_random_index_module 
     --with-http_secure_link_module 
     --with-http_degradation_module 
     --with-http_slice_module 
     --with-http_stub_status_module 
     --with-http_perl_module=dynamic 
     --with-perl=/usr/bin/perl 
     --http-log-path=/var/log/nginx/access.log 
     --http-client-body-temp-path=/var/cache/nginx/client_temp 
     --http-proxy-temp-path=/var/cache/nginx/proxy_temp 
     --http-fastcgi-temp-path=/var/cache/nginx/fastcgi_temp 
     --http-uwsgi-temp-path=/var/cache/nginx/uwsgi_temp 
     --http-scgi-temp-path=/var/cache/nginx/scgi_temp 
     --with-mail=dynamic 
     --with-mail_ssl_module 
     --with-stream=dynamic 
     --with-stream_ssl_module 
     --with-stream_realip_module 
     --with-stream_geoip_module=dynamic 
     --with-stream_ssl_preread_module 
     --with-compat 
     --with-pcre=../pcre-8.41 
     --with-pcre-jit 
     --with-zlib=../zlib-1.2.11 
     --with-openssl=../openssl-1.1.0f 
     --with-openssl-opt=no-nextprotoneg 
     --with-debug
    
    make
    sudo make install
    
    
  11. 打印Nginx版本,编译器版本,并配置脚本参数:

    
    nginx -V
    
    # nginx version: nginx/1.13.3 (Fedora)
    # built by gcc 6.3.1 20161221 (Red Hat 6.3.1-1) (GCC)
    # built with OpenSSL 1.1.0f 25 May 2017
    # TLS SNI support enabled
    # configure arguments: --prefix=/etc/nginx . . .
    # . . .
    
    
  12. 创建Nginx系统用户和组:

    
    sudo useradd --system --home /var/cache/nginx --shell /sbin/nologin --comment"nginx user" --user-group nginx
    
    
  13. 检查语法和潜在错误:

    
    sudo nginx -t
    # Will throw this error: nginx: [emerg] mkdir()"/var/cache/nginx/client_temp" failed (2: No such file or directory)
    # Just create directory
    sudo mkdir -p /var/cache/nginx/ && sudo nginx -t
    
    
  14. 为nginx创建一个systemd单元文件:

    
    sudo vim /etc/systemd/system/nginx.service
    
    
  15. 复制/粘贴以下内容:

    注:PID文件和Nginx二进制文件的位置可能有所不同,具体取决于Nginx的编译方式。

    
    [Unit]
    Description=Nginx - A high performance web server and a reverse proxy server
    Documentation=http://nginx.org/en/docs/
    After=network.target
    
    [Service]
    Type=forking
    PIDFile=/var/run/nginx.pid
    ExecStartPre=/usr/sbin/nginx -t -q -g 'daemon on; master_process on;'
    ExecStart=/usr/sbin/nginx -g 'daemon on; master_process on;'
    ExecReload=/usr/sbin/nginx -g 'daemon on; master_process on;' -s reload
    ExecStop=-/sbin/start-stop-daemon --quiet --stop --retry QUIT/5 --pidfile /var/run/nginx.pid
    TimeoutStopSec=5
    KillMode=mixed
    
    [Install]
    WantedBy=multi-user.target
    
    
  16. 启动Nginx :

    
    sudo systemctl start nginx.service
    
    
  17. 在引导时自动启动NGINX:

    
    sudo systemctl enable nginx.service
    
    
  18. 检查Nginx在重新启动后是否将启动:

    
    sudo systemctl is-enabled nginx.service
    # enabled
    
    
  19. 检查Nginx是否正在运行:

    
    sudo systemctl status nginx.service
    ps aux | grep nginx
    curl -I 127.0.0.1
    
    
  20. 重新启动VPS以验证Nginx是否自动启动:

    
    sudo shutdown -r now
    
    
  21. /etc/nginx/目录中删除旧文件:

    
    sudo rm /etc/nginx/koi-utf /etc/nginx/koi-win /etc/nginx/win-utf
    
    
  22. 将Nginx配置的语法突出显示为~/.vim/vim ,编辑Nginx配置文件时,你将得到语法高亮显示:

    
    mkdir ~/.vim/
    cp -r ~/nginx-1.13.3/contrib/vim/* ~/.vim/
    
    
  23. /etc/nginx/目录中创建一个conf.d/目录,

    
    sudo mkdir /etc/nginx/conf.d/
    
    
  24. 从你的主目录中删除提取的目录和文件:

    
    rm -rf nginx-1.13.3/ openssl-1.1.0f/ pcre-8.41/ zlib-1.2.11/
    
    

结束语

就是这样了,你现在安装了最新版本的NGINX。

Anne655 profile image