Omogućite HTTP/2 u Nginxu na Ubuntu 16.04

HTTP/2 je nova verzija sada zastarjelog HTTP/1.1 protokola koji je standardiziran još 1999. godine. Od tada se mnogo toga promijenilo na webu. Naše su aplikacije složenije nego što su bile unatrag, pa je bila potrebna promjena osnovnog transportnog protokola da bismo se nosili s tim. Najvažnija stvar kod HTTP/2 je da će vašu web stranicu učiniti bržom za krajnje korisnike.

Ukratko, HTTP/2 dodaje 5 ključnih značajki:

  • Jedna, trajna veza
  • Multipleksiranje
  • Kompresija zaglavlja
  • Određivanje prioriteta resursa
  • Osigurava transportni sloj (vrijedi samo za preglednike)

Objašnjenje svih ovih značajki je izvan dosega ovog vodiča, ali ako želite dublje proučiti ovu temu, mogu preporučiti izvadak iz knjige High Performance Browser Networking - HTTP/2 izvadak .

U ovom vodiču ćemo instalirati najnoviju stabilnu verziju Nginxa na Ubuntu 16.04 (Xenial), generirati samopotpisani SSL certifikat, omogućiti HTTP/2 protokol u Nginxu i instalirati tekstualni preglednik koji elinksće djelovati kao HTTP klijent.

Instalirajte Nginx

Da bismo instalirali najnoviju stabilnu verziju Nginxa, moramo izdati nekoliko naredbi:

  1. Moramo preuzeti Nginx javni PGP ključ koji se koristi za potpisivanje paketa i repozitorija i dodati ga u prsten ključeva koji koristi upravitelj paketa da provjeri autentičnost paketa preuzetih iz spremišta.

    wget https://nginx.org/keys/nginx_signing.key && apt-key add nginx_signing.key
    
  2. Izbrišite PGP ključ iz datotečnog sustava:

    rm nginx_signing.key
    
  3. Dodajte novo spremište

    printf "deb http://nginx.org/packages/ubuntu/ xenial nginx \ndeb-src http://nginx.org/packages/ubuntu/ xenial nginx \n" >> /etc/apt/sources.list.d/nginx.list
    
  4. Ažurirajte popis paketa i instalirajte Nginx:

    apt update && apt install nginx -y
    
  5. Za provjeru verzije Nginxa možemo koristiti sljedeće:

    nginx -v 
    # nginx version: nginx/1.10.1
    

    Ako sve prođe dobro, trebali biste vidjeti uzorak kao 1.10.xu izlazu kada izvodite nginx -vnaredbu.

Samopotpisani certifikat i HTTP/2

Although HTTP/2 spec doesn’t force browsers to implement HTTP/2 over TLS, all major browsers decided to only implement HTTP/2 over TLS, but not any TLS version, only TLS 1.2 or higher.

Napravit ćemo samopotpisane certifikate za izmišljenu example.comdomenu, za proizvodnju vam je potrebna valjana domena i korištenje pouzdanog CA.

  1. Generirajte privatni ključ:

    openssl genrsa -aes128 -out example.com.key 2048
    

    Nakon što pokrenete ovu naredbu, morat ćete unijeti lozinku 2 puta. Budući da su zaporke dosadne, uklonit ćemo ih.

  2. Ukloni šifru iz privatnog ključa:

    openssl rsa -in example.com.key -out example.com.key
    
  3. Generiraj zahtjev za potpisivanje certifikata (CSR):

    openssl req -new -sha256 -key example.com.key -out cert-request.csr 
    

    We are creating single-domain certificate so we need to set common-name field equal to example.com domain

  4. Napravite certifikat:

    openssl x509 -req -days 365 -in cert-request.csr -signkey example.com.key -out example.com.crt
    
  5. Odredite certifikat i privatni ključ:

    mkdir -p /etc/ssl/testing/private && mkdir /etc/ssl/testing/certs
    mv example.com.key /etc/ssl/testing/private && mv example.com.crt /etc/ssl/testing/certs
    
  6. Napravite nginx virtualne host direktorije

    mkdir /etc/nginx/sites-available && mkdir /etc/nginx/sites-enabled
    
  7. Zatim pokrenite nano /etc/nginx/nginx.confi pronađite direktivu include /etc/nginx/conf.d/*.conf;. Ispod ove direktive dodajte include /etc/nginx/sites-enabled/*;Spremi ( CTRL+O ), a zatim zatvorite ( CTRL+X ).

    ##
    # Virtual Hosts
    ##
    include /etc/nginx/conf.d/*.conf;
    include /etc/nginx/sites-enabled/*;
    
  8. Napravite datoteku nazvanu example.com.confunutar /etc/nginx/sites-availabledirektorija ovom naredbom nano /etc/nginx/sites-available/example.com.confi kopirajte/zalijepite sljedeći kod:

    server {
        listen 80;
        listen [::]:80;
        server_name example.com;
        return 301 https://$host$request_uri;
    }
    server {
        listen 443 ssl http2;
        listen [::]:443 ssl http2;
        server_name example.com;
        root /var/www/html;
        index index.nginx-debian.html;
    
        ssl_certificate /etc/ssl/testing/certs/example.com.crt;
        ssl_certificate_key /etc/ssl/testing/private/example.com.key;
    
        ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
        ssl_ciphers 'ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-CHACHA20-POLY1305:ECDHE-RSA-CHACHA20-POLY1305:ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES256-SHA384:ECDHE-RSA-AES256-SHA384:ECDHE-ECDSA-AES128-SHA256:ECDHE-RSA-AES128-SHA256';
        ssl_prefer_server_ciphers on;
    }
    

    Čestitamo, sada imate web poslužitelj s omogućenim HTTP/2 . Dodavanje http2parametra u listendirektivu unutar HTTPS virtualnog hosta dat će vam HTTP/2 podršku.

  9. Napravite simboličku vezu za /etc/nginx/sites-available/example.com.confs ovom naredbom:

    ln -s /etc/nginx/sites-available/example.com.conf /etc/nginx/sites-enabled
    
  10. Testirajte sintaksu konfiguracije

    nginx -t
    
  11. Ponovo pokrenite Nginx da biste primijenili svoje promjene:

    systemctl restart nginx
    
  12. Dodajte example.comdomenu u /etc/hostsdatoteku

    echo '127.0.0.1    example.com' >> /etc/hosts
    

Za testiranje vašeg virtualnog hosta potreban nam je tekstualni preglednik - elinkovi.

  1. Da biste instalirali elinks, koristite sljedeću naredbu:

    apt install elinks
    
  2. Za testiranje example.compokretanja virtualnog hosta:

    elinks https://example.com
    
  3. Za izlaz iz preglednika elinks pritisnite q na tipkovnici, a zatim Enter .

Testirajte HTTP/2

Da biste vidjeli koje protokole poslužitelj oglašava najlakši način je korištenje opensslalata.

    openssl s_client -connect example.com:443 -nextprotoneg ''

U izlazu ove naredbe trebali biste vidjeti nešto poput ovoga:

    CONNECTED(00000003)
    Protocols advertised by server: h2, http/1.1      

Da biste vidjeli HTTP/2 u akciji, možete koristiti alate za razvojne programere preglednika. HTTP/2 protokol je označen h2ili HTTP/2.0identifikatorima ili . Otvorite mrežnu ploču u alatima za razvojne programere i osvježite svoju stranicu.

Zaključak

Sada biste trebali biti svjesni koliko je "lako" omogućiti HTTP/2 u Nginx konfiguraciji, ali to nije cijeli dio cjelokupne slike. Prvo biste trebali razmisliti o omogućavanju TLS/SSL-a na svom poslužitelju s jakim paketima šifri i provjerite da li ne koristite šifre s crne liste . Tek nakon što omogućite jak TLS/SSL na svom poslužitelju, možete početi razmišljati o omogućavanju HTTP/2 .


Instalirajte Plesk na CentOS 7

Instalirajte Plesk na CentOS 7

Korištenje drugog sustava? Plesk je vlasnička upravljačka ploča web hosta koja omogućuje korisnicima da administriraju svoje osobne i/ili klijentske web stranice, baze podataka

Postavite Cacti na Debian Jessie

Postavite Cacti na Debian Jessie

Uvod Cacti je alat otvorenog koda za praćenje i crtanje koji se u potpunosti temelji na RRD podacima. Putem Cactusa možete pratiti gotovo sve vrste uređaja

Instalirajte Lets Encrypt SSL na WordPress aplikaciju jednim klikom

Instalirajte Lets Encrypt SSL na WordPress aplikaciju jednim klikom

Uvod Lets Encrypt je usluga za izdavanje certifikata koja nudi besplatne TLS/SSL certifikate. Certbot pojednostavljuje proces instalacije,

Kako postaviti Tekkit Classic Server na Ubuntu 16.10

Kako postaviti Tekkit Classic Server na Ubuntu 16.10

Korištenje drugog sustava? Što je Tekkit Classic? Tekkit Classic je modpack za igru ​​koju svi znaju i vole; Minecraft. Sadrži neke od ver

Postavite iRedMail na Debian Wheezy

Postavite iRedMail na Debian Wheezy

Korištenje drugog sustava? Ovaj vodič će vam pokazati kako instalirati grupni softver iRedMail na novu instalaciju Debian Wheezyja. Trebali biste koristiti servis

Izrada Jekyll bloga na Ubuntu 16.04

Izrada Jekyll bloga na Ubuntu 16.04

Korištenje drugog sustava? Jekyll je izvrsna alternativa WordPressu za bloganje ili dijeljenje sadržaja. Ne zahtijeva nikakve baze podataka i vrlo je jednostavan i

Kako postaviti nenadzirane nadogradnje na Debianu 9 (protežu)

Kako postaviti nenadzirane nadogradnje na Debianu 9 (protežu)

Korištenje drugog sustava? Ako kupite Debian poslužitelj, uvijek biste trebali imati najnovije sigurnosne zakrpe i ažuriranja, bez obzira spavate li ili ne

Kako instalirati i konfigurirati PHP 7.0 ili PHP 7.1 na Ubuntu 16.04

Kako instalirati i konfigurirati PHP 7.0 ili PHP 7.1 na Ubuntu 16.04

PHP i povezani paketi najčešće su korištene komponente prilikom postavljanja web poslužitelja. U ovom članku ćemo naučiti kako postaviti PHP 7.0 ili PHP 7.1 o

Kako instalirati Squid proxy na CentOS

Kako instalirati Squid proxy na CentOS

Squid je popularan besplatni program za Linux koji vam omogućuje stvaranje web proxyja za prosljeđivanje. U ovom vodiču vidjet ćete kako instalirati Squid na CentOS da vas preokrene

Kako instalirati Lighttpd (LLMP Stack) na CentOS 6

Kako instalirati Lighttpd (LLMP Stack) na CentOS 6

Uvod Lighttpd je fork Apachea koji ima za cilj da bude puno manje intenzivan prema resursima. Lagan je, otuda mu i naziv, i prilično je jednostavan za korištenje. Instaliraj

Korištenje zaslona na Ubuntu 14.04

Korištenje zaslona na Ubuntu 14.04

Screen je aplikacija koja omogućuje višestruko korištenje terminalskih sesija unutar jednog prozora. To vam omogućuje da simulirate više prozora terminala gdje je ma

Postavite svoj vlastiti DNS poslužitelj na Debian/Ubuntu

Postavite svoj vlastiti DNS poslužitelj na Debian/Ubuntu

Ovaj vodič objašnjava kako postaviti DNS poslužitelj pomoću Bind9 na Debianu ili Ubuntu. U cijelom članku u skladu s tim zamijenite your-domain-name.com. Na th

Konfiguriranje statičkog umrežavanja i IPv6 na CentOS 7

Konfiguriranje statičkog umrežavanja i IPv6 na CentOS 7

VULTR je nedavno napravio promjene na svojoj strani i sada bi sve trebalo raditi dobro iz kutije s omogućenim NetworkManagerom. Želite li onemogućiti

Promjena Icinga2 za korištenje modela Master/Client na CentOS 6 ili CentOS 7

Promjena Icinga2 za korištenje modela Master/Client na CentOS 6 ili CentOS 7

Icinga2 je moćan sustav nadzora, a kada se koristi u modelu master-client, može zamijeniti potrebu za provjerama praćenja na temelju NRPE. Glavni klijent

Postavite Red5 Media Server na Ubuntu 16.04

Postavite Red5 Media Server na Ubuntu 16.04

Korištenje drugog sustava? Red5 je medijski poslužitelj otvorenog koda implementiran u Javi koji vam omogućuje pokretanje Flash višekorisničkih aplikacija kao što je live streamin

Prevedite i instalirajte Nginx s modulom PageSpeed ​​na Debian 8

Prevedite i instalirajte Nginx s modulom PageSpeed ​​na Debian 8

U ovom članku ćemo vidjeti kako sastaviti i instalirati Nginx mainline iz službenih izvora Nginxa s modulom PageSpeed, koji vam omogućuje da

Kako instalirati Vanilla Forum na Ubuntu 16.04

Kako instalirati Vanilla Forum na Ubuntu 16.04

Korištenje drugog sustava? Vanilla forum je aplikacija otvorenog koda napisana u PHP-u. Potpuno je prilagodljiv, jednostavan za korištenje i podržava eksterne

Kako instalirati Kanboard na Ubuntu 18.04 LTS

Kako instalirati Kanboard na Ubuntu 18.04 LTS

Korištenje drugog sustava? Uvod Kanboard je besplatni softver za upravljanje projektima otvorenog koda koji je dizajniran za olakšavanje i vizualizaciju

Kako instalirati Kanboard na Debian 9

Kako instalirati Kanboard na Debian 9

Korištenje drugog sustava? Uvod Kanboard je besplatni softver za upravljanje projektima otvorenog koda koji je dizajniran za olakšavanje i vizualizaciju

Kako instalirati Giteu na Debian 9

Kako instalirati Giteu na Debian 9

Korištenje drugog sustava? Gitea je alternativni sustav za kontrolu verzija otvorenog koda s vlastitim hostom koji pokreće Git. Gitea je napisana na Golangu i jest

Uspon strojeva: primjene AI u stvarnom svijetu

Uspon strojeva: primjene AI u stvarnom svijetu

Umjetna inteligencija nije u budućnosti, ovdje je upravo u sadašnjosti. U ovom blogu Pročitajte kako su aplikacije umjetne inteligencije utjecale na različite sektore.

DDOS napadi: kratak pregled

DDOS napadi: kratak pregled

Jeste li i vi žrtva DDOS napada i zbunjeni ste metodama prevencije? Pročitajte ovaj članak kako biste riješili svoje upite.

Jeste li se ikada zapitali kako hakeri zarađuju novac?

Jeste li se ikada zapitali kako hakeri zarađuju novac?

Možda ste čuli da hakeri zarađuju mnogo novca, ali jeste li se ikada zapitali kako zarađuju toliki novac? raspravimo.

Revolucionarni Googleovi izumi koji će vam olakšati život.

Revolucionarni Googleovi izumi koji će vam olakšati život.

Želite li vidjeti revolucionarne izume Googlea i kako su ti izumi promijenili život svakog čovjeka danas? Zatim čitajte na blogu kako biste vidjeli Googleove izume.

Friday Essential: Što se dogodilo s automobilima s umjetnom inteligencijom?

Friday Essential: Što se dogodilo s automobilima s umjetnom inteligencijom?

Koncept samovozećih automobila koji će krenuti na ceste uz pomoć umjetne inteligencije san je koji već neko vrijeme imamo. No, unatoč nekoliko obećanja, nigdje ih nema. Pročitajte ovaj blog kako biste saznali više…

Tehnološka singularnost: daleka budućnost ljudske civilizacije?

Tehnološka singularnost: daleka budućnost ljudske civilizacije?

Kako se znanost razvija velikom brzinom, preuzimajući mnoge naše napore, raste i rizik da se podvrgnemo neobjašnjivoj Singularnosti. Pročitajte što bi za nas mogla značiti singularnost.

Evolucija pohrane podataka – Infografika

Evolucija pohrane podataka – Infografika

Metode pohrane podataka su se razvijale možda od rođenja podataka. Ovaj blog pokriva evoluciju pohrane podataka na temelju infografike.

Funkcionalnosti slojeva referentne arhitekture velikih podataka

Funkcionalnosti slojeva referentne arhitekture velikih podataka

Pročitajte blog kako biste na najjednostavniji način upoznali različite slojeve u arhitekturi velikih podataka i njihove funkcionalnosti.

6 nevjerojatnih prednosti posjedovanja pametnih kućnih uređaja u našim životima

6 nevjerojatnih prednosti posjedovanja pametnih kućnih uređaja u našim životima

U ovom digitalnom svijetu, pametni kućni uređaji postali su ključni dio života. Evo nekoliko nevjerojatnih prednosti pametnih kućnih uređaja o tome kako naš život čine vrijednim življenja i jednostavnijim.

Ažuriranje dodataka macOS Catalina 10.15.4 uzrokuje više problema nego što ih rješava

Ažuriranje dodataka macOS Catalina 10.15.4 uzrokuje više problema nego što ih rješava

Nedavno je Apple izdao macOS Catalina 10.15.4 dodatak ažuriranju kako bi riješio probleme, ali čini se da ažuriranje uzrokuje više problema koji dovode do zalijevanja mac strojeva. Pročitajte ovaj članak da biste saznali više