Hoe Nginx vanuit de bron te compileren op Fedora 25

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 tutorial gebruik ik de hoofdversie , die op het moment van schrijven 1.13.3 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.41
  • 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 dnf check-update || sudo dnf upgrade -y
    

Bouw NGINX vanaf de bron

  1. Installeer "Development Tools", Vim editor, wget en gcc-c ++:

    sudo dnf install -y @development-tools && sudo dnf install -y vim wget gcc-c++
    
  2. Download de nieuwste mainline- versie van de NGINX-broncode en pak deze uit:

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

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

    # 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. Download en installeer optionele NGINX-afhankelijkheden:

    # 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. Verwijder alle .tar.gzbestanden. We hebben ze niet meer nodig:

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

    cd ~/nginx-1.13.3
    
  7. Voor een goede maatregel, vermeld NGINX broncodebestanden en mappen:

    ls
    # auto  CHANGES  CHANGES.ru  conf  configure  contrib  html  LICENSE  man  README  src
    
  8. Kopieer de NGINX-handleiding naar /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. Voor hulp kunt u de beschikbare configuratieswitches weergeven door het volgende uit te voeren:

    ./configure --help
    # To see want core modules can be build as dynamic run:
    ./configure --help | grep -F =dynamic
    
  10. 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=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. Druk de NGINX-versie, compilerversie af en configureer scriptparameters:

    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. Maak de NGINX-systeemgebruiker en groep aan:

    sudo useradd --system --home /var/cache/nginx --shell /sbin/nologin --comment "nginx user" --user-group nginx
    
  13. 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
    
  14. Maak een systemd-eenheidsbestand voor NGINX:

    sudo vim /etc/systemd/system/nginx.service
    
  15. Kopieer / plak de volgende inhoud:

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

    [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. Start NGINX:

    sudo systemctl start nginx.service
    
  17. Schakel NGINX in om automatisch te starten bij het opstarten:

    sudo systemctl enable nginx.service
    
  18. Controleer of NGINX zal opstarten na een herstart:

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

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

    sudo shutdown -r now
    
  21. Verwijder archaïsche bestanden uit de /etc/nginx/map:

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

    mkdir ~/.vim/
    cp -r ~/nginx-1.13.3/contrib/vim/* ~/.vim/
    
  23. Maak een conf.d/directory in de /etc/nginx/directory. In deze directory kunt u virtuele servers en upstreams plaatsen:

    sudo mkdir /etc/nginx/conf.d/
    
  24. Verwijderde mappen en bestanden uit uw thuismap:

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

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

Hoe Matomo Analytics op Fedora te installeren 28

Hoe Matomo Analytics op Fedora te installeren 28

Gebruikt u een ander systeem? Matomo (voorheen Piwik) is een open source analyseplatform, een open alternatief voor Google Analytics. Matomo source wordt gehost o

Hoe Subrion 4.1 CMS te installeren op een Fedora 26 LAMP VPS

Hoe Subrion 4.1 CMS te installeren op een Fedora 26 LAMP VPS

Gebruikt u een ander systeem? Subrion 4.1 CMS is een krachtig en flexibel open source Content Management Systeem (CMS) dat een intuïtieve en duidelijke inhoud

Hoe Couch CMS 2.0 te installeren op een Fedora 26 LAMP VPS

Hoe Couch CMS 2.0 te installeren op een Fedora 26 LAMP VPS

Gebruikt u een ander systeem? Couch CMS is een eenvoudig en flexibel, gratis en open source Content Management Systeem (CMS) waarmee webdesigners kunnen ontwerpen

WonderCMS installeren op Fedora 29

WonderCMS installeren op Fedora 29

Gebruikt u een ander systeem? WonderCMS is een open source, snel en klein, plat bestand CMS geschreven in PHP. WonderCMS-broncode wordt gehost op Github. Deze gids zal

Fork CMS installeren op Fedora 28

Fork CMS installeren op Fedora 28

Gebruikt u een ander systeem? Fork is een open source CMS geschreven in PHP. De broncode van Forks wordt gehost op GitHub. In deze handleiding wordt uitgelegd hoe u Fork CM installeert

Hoe RainLoop Webmail op Fedora 28 te installeren

Hoe RainLoop Webmail op Fedora 28 te installeren

Gebruikt u een ander systeem? RainLoop is een eenvoudige, moderne en snelle webgebaseerde e-mailclient. De broncode van RainLoop wordt gehost op GitHub. Deze gids laat je zien ho

Hoe Tiny Tiny RSS Reader te installeren op een Fedora 26 LAMP VPS

Hoe Tiny Tiny RSS Reader te installeren op een Fedora 26 LAMP VPS

Gebruikt u een ander systeem? Tiny Tiny RSS Reader is een gratis en open source zelf-gehoste webgebaseerde nieuwsfeed (RSS / Atom) lezer en aggregator, ontworpen om allo

Hoe BigTree CMS te installeren op een Fedora 26 LAMP VPS

Hoe BigTree CMS te installeren op een Fedora 26 LAMP VPS

Gebruikt u een ander systeem? BigTree CMS 4.2 is een snel en lichtgewicht, gratis en open source, enterprise-grade content management systeem (CMS) met uitgebreide en

Hoe Gitea op Fedora te installeren 29

Hoe Gitea op Fedora te installeren 29

Gebruikt u een ander systeem? Gitea is een alternatief open source, zelf gehost versiebeheersysteem, mogelijk gemaakt door Git. Gitea is geschreven in Golang en is

Hoe MyBB op Fedora te installeren 28

Hoe MyBB op Fedora te installeren 28

Gebruikt u een ander systeem? MyBB is een gratis en open source, intuïtief en uitbreidbaar forumprogramma. De MyBB-broncode wordt gehost op GitHub. Deze gids zal sho

Installeer HTMLDoc op Fedora 29

Installeer HTMLDoc op Fedora 29

Gebruikt u een ander systeem? HTMLDoc zal Postscript (PDF 1.6) -documenten dynamisch parseren uit correct geschreven Hypertext (HTML 3.2). Dit zal je toelaten

Hoe Cachet op Fedora te installeren 28

Hoe Cachet op Fedora te installeren 28

Gebruikt u een ander systeem? Cachet is een open source statuspaginasysteem geschreven in PHP. De broncode van Cachet wordt gehost in deze Github-repo. In thi

Hoe ImpressPages CMS 5.0 te installeren op een Fedora 26 LAMP VPS

Hoe ImpressPages CMS 5.0 te installeren op een Fedora 26 LAMP VPS

Gebruikt u een ander systeem? ImpressPages CMS 5.0 is een eenvoudig en effectief, gratis en open source, gebruiksvriendelijk, op MVC gebaseerd Content Management Systeem (CMS)

Hoe Pagekit 1.0 CMS te installeren op een Fedora 26 LAMP VPS

Hoe Pagekit 1.0 CMS te installeren op een Fedora 26 LAMP VPS

Gebruikt u een ander systeem? Pagekit 1.0 CMS is een mooi, modulair, uitbreidbaar en lichtgewicht, gratis en open source Content Management Systeem (CMS) met

Hoe osTicket op Fedora 30 te installeren

Hoe osTicket op Fedora 30 te installeren

Gebruikt u een ander systeem? osTicket is een open source ticketingsysteem voor klantenondersteuning. De broncode van osTicket wordt openbaar gehost op Github. In deze tutorial

Hoe ProcessWire CMS 3.0 te installeren op een Fedora 26 LAMP VPS

Hoe ProcessWire CMS 3.0 te installeren op een Fedora 26 LAMP VPS

Gebruikt u een ander systeem? ProcessWire CMS 3.0 is een eenvoudig, flexibel en krachtig, gratis en open source Content Management System (CMS). ProcessWire CMS 3.

Ghost op Fedora inzetten 25

Ghost op Fedora inzetten 25

Gebruikt u een ander systeem? Ghost is een open source blogplatform dat sinds de release in 2013 aan populariteit wint onder ontwikkelaars en gewone gebruikers. ik

Hoe Omeka Classic 2.4 CMS op Fedora 26 LAMP VPS te installeren

Hoe Omeka Classic 2.4 CMS op Fedora 26 LAMP VPS te installeren

Gebruikt u een ander systeem? Omeka Classic 2.4 CMS is een gratis en open source digitaal publicatieplatform en Content Management System (CMS) voor het delen van digita

Hoe Ghost v0.11 LTS op Fedora 25 te implementeren

Hoe Ghost v0.11 LTS op Fedora 25 te implementeren

Gebruikt u een ander systeem? Ghost is een open source blogplatform dat sinds zijn populariteit aan populariteit wint onder ontwikkelaars en gewone gebruikers

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.