Hoe Nginx vanuit de bron te compileren op CentOS 7

NGINX kan worden gebruikt als een HTTP / HTTPS-server, reverse-proxyserver, mail-proxyserver, load balancer, TLS-terminator of cachingserver. Het is vrij modulair van opzet. Het heeft native modules en modules van derden die door de community zijn gemaakt. Het is geschreven in de programmeertaal C en het is een zeer snel en lichtgewicht stuk software.

OPMERKING : NGINX heeft twee versie streams die parallel lopen - stabiel en hoofdlijn . Beide versies kunnen worden gebruikt op een productieserver. Het wordt aanbevolen om de hoofdversie in productie te gebruiken.

NGINX installeren vanaf broncode is relatief "eenvoudig" - download de laatste versie van de NGINX broncode, configureer, bouw en installeer deze.

In deze zelfstudie zal ik de hoofdversie gebruiken , die op het moment van schrijven 1.13.2 is. Update de versienummers dienovereenkomstig wanneer er nieuwere versies beschikbaar komen.

Vereisten voor het bouwen van NGINX vanaf de bron

Verplichte eisen:

  • OpenSSL- bibliotheekversie tussen 1.0.2 en 1.1.0
  • zlib bibliotheekversie tussen 1.1.3 - 1.2.11
  • PCRE- bibliotheekversie tussen 4,4 - 8,40
  • GCC- compiler

Facultatieve vereisten:

Voordat je begint

  1. Creëer een gewone gebruiker met sudotoegang .
  2. Schakel over naar de nieuwe gebruiker:

    su - <username>
    
  3. Systeem bijwerken:

    sudo yum check-update || sudo yum update -y
    

Bouw NGINX vanaf de bron

  1. Installeer "Development Tools" en Vim-editor:

    sudo yum groupinstall -y 'Development Tools' && sudo yum install -y vim
    
  2. Installeer extra pakketten voor Enterprise Linux (EPEL):

    sudo yum install -y epel-release
    
  3. Download en installeer optionele NGINX-afhankelijkheden:

    sudo yum install -y perl perl-devel perl-ExtUtils-Embed libxslt libxslt-devel libxml2 libxml2-devel gd gd-devel GeoIP GeoIP-devel
    
  4. Download de nieuwste hoofdversie van de NGINX-broncode en pak deze uit:

    wget https://nginx.org/download/nginx-1.13.2.tar.gz && tar zxvf nginx-1.13.2.tar.gz
    
  5. Download de broncode van de NGINX-afhankelijkheden en pak ze uit:

    NGINX is afhankelijk van 3 bibliotheken: PCRE , zlib en OpenSSL :

    # PCRE version 8.40
    wget https://ftp.pcre.org/pub/pcre/pcre-8.40.tar.gz && tar xzvf pcre-8.40.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
    
  6. Verwijder alle .tar.gzbestanden. We hebben ze niet meer nodig:

    rm -rf *.tar.gz
    
  7. Ga naar de NGINX-bronmap:

    cd ~/nginx-1.13.2
    
  8. Voor een goede meting, vermeld nginx broncodebestanden en mappen:

    ls
    # auto  CHANGES  CHANGES.ru  conf  configure  contrib  html  LICENSE  man  README  src
    
  9. Kopieer de NGINX-handleiding naar /usr/share/man/man8:

    sudo cp ~/nginx-1.13.2/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
    
  10. Voor hulp kunt u de beschikbare configuratieschakelaars vermelden door te draaien:

    ./configure --help
    # To see want core modules can be build as dynamic run:
    ./configure --help | grep -F =dynamic
    
  11. NGINX configureren, compileren en installeren:

    ./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=CentOS \
                --builddir=nginx-1.13.2 \
                --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 \
                --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.40 \
                --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
    
  12. Symlink /usr/lib64/nginx/modulesnaar /etc/nginx/modulesdirectory, zodat u dynamische modules in nginx-configuratie als volgt kunt laden load_module modules/ngx_foo_module.so;:

    sudo ln -s /usr/lib64/nginx/modules /etc/nginx/modules
    
  13. Druk de NGINX-versie, compilerversie af en configureer scriptparameters:

    sudo nginx -V
    
    # nginx version: nginx/1.13.2 (CentOS)
    # built by gcc 4.8.5 20150623 (Red Hat 4.8.5-11) (GCC)
    # built with OpenSSL 1.1.0f  25 May 2017
    # TLS SNI support enabled
    # configure arguments: --prefix=/etc/nginx --sbin-path=/usr/sbin/nginx . . .
    # . . .
    # . . .
    
  14. Maak de NGINX-systeemgebruiker en groep aan:

    sudo useradd --system --home /var/cache/nginx --shell /sbin/nologin --comment "nginx user" --user-group nginx
    
  15. Controleer syntaxis en mogelijke fouten:

    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
    
  16. Maak een systemd-eenheidsbestand voor nginx:

    sudo vim /usr/lib/systemd/system/nginx.service
    
  17. Kopieer / plak de volgende inhoud:

    OPMERKING : de locatie van het PID-bestand en het NGINX-binaire bestand kan verschillen, afhankelijk van hoe NGINX is gecompileerd.

    [Unit]
    Description=nginx - high performance web server
    Documentation=https://nginx.org/en/docs/
    After=network-online.target remote-fs.target nss-lookup.target
    Wants=network-online.target
    
    [Service]
    Type=forking
    PIDFile=/var/run/nginx.pid
    ExecStartPre=/usr/sbin/nginx -t -c /etc/nginx/nginx.conf
    ExecStart=/usr/sbin/nginx -c /etc/nginx/nginx.conf
    ExecReload=/bin/kill -s HUP $MAINPID
    ExecStop=/bin/kill -s TERM $MAINPID
    
    [Install]
    WantedBy=multi-user.target
    
  18. Start en schakel de NGINX-service in:

    sudo systemctl start nginx.service && sudo systemctl enable nginx.service
    
  19. Controleer of NGINX zal opstarten na een herstart:

    sudo systemctl is-enabled nginx.service
    # enabled
    
  20. Controleer of NGINX actief is:

    sudo systemctl status nginx.service
    ps aux | grep nginx
    curl -I 127.0.0.1
    
  21. Start je VPS opnieuw op om te controleren of NGINX automatisch opstart:

    sudo shutdown -r now
    
  22. Verwijder archaïsche bestanden uit de /etc/nginxmap:

    sudo rm /etc/nginx/koi-utf /etc/nginx/koi-win /etc/nginx/win-utf
    
  23. Plaats syntaxisaccentuering van NGINX-configuratie voor vimin ~/.vim/. U krijgt mooie syntaxisaccentuering bij het bewerken van het NGINX-configuratiebestand:

    mkdir ~/.vim/
    cp -r ~/nginx-1.13.2/contrib/vim/* ~/.vim/
    
  24. Verwijder alle .defaultback-upbestanden van /etc/nginx/:

    sudo rm /etc/nginx/*.default
    

Gevolgtrekking

Dat is het. Je hebt nu de nieuwste versie van NGINX geïnstalleerd. Het is statisch samengesteld tegen enkele belangrijke bibliotheken zoals OpenSSL. Vaak is de OpenSSL-versie van het systeem verouderd. Door deze installatiemethode te gebruiken met een nieuwere versie van OpenSSL, kunt u profiteren van nieuwe coderingen zoals CHACHA20_POLY1305en protocollen zoals TLS 1.3 die beschikbaar zullen zijn in OpenSSL 1.1.1(die op het moment van schrijven niet is vrijgegeven).



Leave a Comment

Kan AI vechten met toenemend aantal ransomware-aanvallen?

Kan AI vechten met toenemend aantal ransomware-aanvallen?

Ransomware-aanvallen nemen toe, maar kan AI helpen het nieuwste computervirus het hoofd te bieden? Is AI het antwoord? Lees hier weten is AI boezem of vloek

ReactOS: is dit de toekomst van Windows?

ReactOS: is dit de toekomst van Windows?

ReactOS, een open source en gratis besturingssysteem is hier met de nieuwste versie. Kan het voldoen aan de behoeften van moderne Windows-gebruikers en Microsoft uitschakelen? Laten we meer te weten komen over deze oude stijl, maar een nieuwere OS-ervaring.

Blijf verbonden via WhatsApp Desktop-app 24 * 7

Blijf verbonden via WhatsApp Desktop-app 24 * 7

WhatsApp heeft eindelijk de Desktop-app voor Mac- en Windows-gebruikers gelanceerd. Nu heb je eenvoudig toegang tot WhatsApp vanuit Windows of Mac. Beschikbaar voor Windows 8+ en Mac OS 10.9+

Hoe AI procesautomatisering naar een hoger niveau kan tillen?

Hoe AI procesautomatisering naar een hoger niveau kan tillen?

Lees dit om te weten hoe kunstmatige intelligentie populair wordt onder de kleinschalige bedrijven en hoe het de kansen vergroot om ze te laten groeien en hun concurrenten voorsprong te geven.

macOS Catalina 10.15.4 Supplement Update veroorzaakt meer problemen dan het oplost

macOS Catalina 10.15.4 Supplement Update veroorzaakt meer problemen dan het oplost

Onlangs heeft Apple macOS Catalina 10.15.4 uitgebracht, een aanvullende update om problemen op te lossen, maar het lijkt erop dat de update meer problemen veroorzaakt die ertoe leiden dat mac-machines worden gemetseld. Lees dit artikel voor meer informatie

13 Commerciële data-extractietools voor big data

13 Commerciële data-extractietools voor big data

13 Commerciële data-extractietools voor big data

Wat is een logboekbestandssysteem en hoe werkt het?

Wat is een logboekbestandssysteem en hoe werkt het?

Onze computer slaat alle gegevens op een georganiseerde manier op, het zogenaamde Journaling-bestandssysteem. Het is een efficiënte methode waarmee de computer bestanden kan zoeken en weergeven zodra u op zoeken drukt.https://wethegeek.com/?p=94116&preview=true

Technologische singulariteit: een verre toekomst van de menselijke beschaving?

Technologische singulariteit: een verre toekomst van de menselijke beschaving?

Naarmate de wetenschap zich snel ontwikkelt en veel van onze inspanningen overneemt, nemen ook de risico's toe om onszelf te onderwerpen aan een onverklaarbare singulariteit. Lees, wat singulariteit voor ons kan betekenen.

Een inzicht in 26 Big Data-analysetechnieken: deel 1

Een inzicht in 26 Big Data-analysetechnieken: deel 1

Een inzicht in 26 Big Data-analysetechnieken: deel 1

De impact van kunstmatige intelligentie in de gezondheidszorg 2021

De impact van kunstmatige intelligentie in de gezondheidszorg 2021

AI in de zorg heeft de afgelopen decennia grote sprongen gemaakt. De toekomst van AI in de gezondheidszorg groeit dus nog steeds met de dag.