Iespējojiet HTTP/2 programmā Nginx Ubuntu 16.04

HTTP/2 ir novecojušā HTTP/1.1 protokola jaunā versija, kas tika standartizēta 1999. gadā. Kopš tā laika tīmeklī ir daudz kas mainījies. Mūsu lietojumprogrammas ir sarežģītākas, nekā tās bija atpakaļ, tāpēc, lai ar to tiktu galā, bija nepieciešamas izmaiņas pamatā esošajā transporta protokolā. Pats svarīgākais HTTP/2 ir tas, ka tas galalietotājiem padarīs jūsu tīmekļa lapu ātrāku.

Īsumā HTTP/2 pievieno 5 galvenās funkcijas:

  • Vienots, pastāvīgs savienojums
  • Multipleksēšana
  • Galvenes saspiešana
  • Resursu prioritāšu noteikšana
  • Nodrošina transporta slāni (derīgs tikai pārlūkprogrammām)

Visu šo funkciju izskaidrošana neietilpst šajā apmācībā, taču, ja vēlaties iedziļināties šajā tēmā, es varu ieteikt fragmentu no grāmatas High Performance Browser Networking — HTTP/2 fragments .

Šajā rokasgrāmatā mēs instalēsim jaunāko stabilo Nginx versiju operētājsistēmā Ubuntu 16.04 (Xenial), ģenerēsim pašparakstītu SSL sertifikātu, iespējosim HTTP/2 protokolu Nginx un instalēsim teksta pārlūkprogrammu, elinkslai tā darbotos kā HTTP klients.

Instalējiet Nginx

Lai instalētu jaunāko stabilo Nginx versiju, mums ir jāizdod dažas komandas:

  1. Mums ir jālejupielādē Nginx publiskā PGP atslēga, ko izmanto pakotņu un repozitoriju parakstīšanai, un jāpievieno tā atslēgu piekariņam, ko izmanto pakotņu pārvaldnieks, lai pārbaudītu no krātuves lejupielādēto pakotņu autentiskumu.

    wget https://nginx.org/keys/nginx_signing.key && apt-key add nginx_signing.key
    
  2. Izdzēsiet PGP atslēgu no failu sistēmas:

    rm nginx_signing.key
    
  3. Pievienojiet jaunu repozitoriju

    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. Atjauniniet pakotņu sarakstu un instalējiet Nginx:

    apt update && apt install nginx -y
    
  5. Lai pārbaudītu Nginx versiju, mēs varam izmantot šo:

    nginx -v 
    # nginx version: nginx/1.10.1
    

    Ja viss iet labi 1.10.x, palaižot nginx -vkomandu, izvadē vajadzētu redzēt līdzīgu modeli .

Pašparakstīts sertifikāts un 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.

Mēs izveidosim pašparakstītus sertifikātus izdomātam example.comdomēnam, lai ražotu, jums ir nepieciešams derīgs domēns un jāizmanto uzticama CA.

  1. Ģenerēt privāto atslēgu:

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

    Pēc šīs komandas palaišanas jums būs jāievada ieejas frāze 2 reizes. Tā kā ieejas frāzes ir kaitinošas, mēs tās noņemsim.

  2. Noņemt ieejas frāzi no privātās atslēgas:

    openssl rsa -in example.com.key -out example.com.key
    
  3. Izveidot sertifikāta parakstīšanas pieprasījumu (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. Izveidot sertifikātu:

    openssl x509 -req -days 365 -in cert-request.csr -signkey example.com.key -out example.com.crt
    
  5. Kārtot sertifikātu un privāto atslēgu:

    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. Izveidojiet nginx virtuālo resursdatoru direktorijus

    mkdir /etc/nginx/sites-available && mkdir /etc/nginx/sites-enabled
    
  7. Pēc tam palaidiet nano /etc/nginx/nginx.confun atrodiet direktīvu include /etc/nginx/conf.d/*.conf;. Zem šīs direktīvas pievienojiet include /etc/nginx/sites-enabled/*;Saglabāt ( CTRL+O ) un pēc tam aizveriet ( CTRL+X ).

    ##
    # Virtual Hosts
    ##
    include /etc/nginx/conf.d/*.conf;
    include /etc/nginx/sites-enabled/*;
    
  8. Izveidot failu ar nosaukumu example.com.confiekšā /etc/nginx/sites-availabledirektorijā ar šo komandu nano /etc/nginx/sites-available/example.com.confun kopēt / ielīmēt šo kodu:

    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;
    }
    

    Apsveicam! Tagad jums ir iespējots HTTP/2 tīmekļa serveris. Pievienojot http2parametru listendirektīvai HTTPS virtuālajā resursdatorā, jūs iegūsit HTTP/2 atbalstu.

  9. Izveidojiet simbolisku saiti /etc/nginx/sites-available/example.com.confar šo komandu:

    ln -s /etc/nginx/sites-available/example.com.conf /etc/nginx/sites-enabled
    
  10. Testa konfigurācijas sintakse

    nginx -t
    
  11. Restartējiet Nginx, lai lietotu izmaiņas:

    systemctl restart nginx
    
  12. Pievienojiet failam example.comdomēnu/etc/hosts

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

Lai pārbaudītu savu virtuālo resursdatoru, mums ir nepieciešama teksta pārlūkprogramma - elinks.

  1. Lai instalētu elinks, izmantojiet šādu komandu:

    apt install elinks
    
  2. Lai pārbaudītu example.comvirtuālā saimniekdatora darbību, veiciet tālāk norādītās darbības.

    elinks https://example.com
    
  3. Lai izietu no pārlūka elinks, nospiediet tastatūras taustiņu q un pēc tam Enter .

Pārbaudiet HTTP/2

Lai redzētu, kādus protokolus serveris reklamē, vienkāršākais veids ir izmantot opensslrīku komplektu.

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

Šīs komandas izvadē jums vajadzētu redzēt kaut ko līdzīgu šim:

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

Lai redzētu HTTP/2 darbību, varat izmantot pārlūkprogrammas izstrādātāju rīkus. HTTP/2 protokols tiek norādīts ar h2vai HTTP/2.0identifikatoriem. Atveriet tīkla paneli izstrādātāju rīkos un atsvaidziniet savu lapu.

Secinājums

Tagad jums vajadzētu zināt, cik "viegli" ir iespējot HTTP/2 Nginx konfigurācijā, taču tā nav visa kopējā attēla daļa. Vispirms jums vajadzētu padomāt par TLS/SSL iespējošanu savā serverī, izmantojot spēcīgus šifru komplektus, un pārliecinieties, ka neizmantojat melnajā sarakstā iekļautos šifrus . Tikai pēc spēcīga TLS/SSL iespējošanas savā serverī varat sākt domāt par HTTP/2 iespējošanu .


Statiskā tīkla un IPv6 konfigurēšana operētājsistēmā CentOS 7

Statiskā tīkla un IPv6 konfigurēšana operētājsistēmā CentOS 7

VULTR nesen veica izmaiņas, un tagad visam vajadzētu darboties labi, ja ir iespējots NetworkManager. Ja vēlaties atspējot

Docker CE instalēšana Ubuntu 16.04

Docker CE instalēšana Ubuntu 16.04

Vai izmantojat citu sistēmu? Docker ir lietojumprogramma, kas ļauj izvietot programmas, kas tiek darbinātas kā konteineri. Tas tika uzrakstīts populārajā Go programmā

Netīrās govs eksploīta ielāgošana vietnē CentOS

Netīrās govs eksploīta ielāgošana vietnē CentOS

Kas ir netīrā govs (CVE-2016-5195)? Netīrās govs ievainojamība tiek izmantota, izmantojot to, kā Linux apstrādā kodu. Tas ļauj nepievilinātam lietotājam gai

Iestatiet laika joslu un NTP operētājsistēmā Ubuntu 14.04

Iestatiet laika joslu un NTP operētājsistēmā Ubuntu 14.04

Vultr serveri var nebūt izvietoti ar jūsu serverī nepieciešamo laika joslu/datumu/laiku. Par laimi mēs varam manuāli iestatīt laika joslu, lai novērstu problēmas

Rust instalēšana Ubuntu 14.04

Rust instalēšana Ubuntu 14.04

Rust, plaši pazīstama kā Rust-Lang, ir sistēmas programmēšanas valoda, ko izstrādā Mozilla un atbalsta LLVM. Rūsa ir pazīstama ar programmu novēršanu

Kā instalēt osTicket uz FreeBSD 12

Kā instalēt osTicket uz FreeBSD 12

Vai izmantojat citu sistēmu? osTicket ir atvērtā koda klientu atbalsta biļešu sistēma. osTicket pirmkods ir publiski mitināts vietnē Github. Šajā apmācībā

Darbs ar Linux iespējām

Darbs ar Linux iespējām

Ievads Linux iespējas ir īpaši atribūti Linux kodolā, kas piešķir procesiem un binārajiem izpildāmajiem failiem īpašas privilēģijas, kas ir normālas.

Kā instalēt JuliaLang Ubuntu 17.04

Kā instalēt JuliaLang Ubuntu 17.04

Julia, plaši pazīstama kā JuliaLang, ir programmēšanas valoda skaitliskajai skaitļošanai. Džūlija ir tikpat ātra kā C, taču tas neupurē lasāmību

Augsta pieejamība, izmantojot privāto tīklu Ubuntu 16.04 ar Keepalived

Augsta pieejamība, izmantojot privāto tīklu Ubuntu 16.04 ar Keepalived

Dažām augstas pieejamības arhitektūrām nepieciešama peldoša IP adrese. Šī funkcionalitāte ir pieejama Vultr platformā, tiklīdz ir izveidots privātais tīkls

Iestatiet tikai SFTP lietotāju kontus Ubuntu 14

Iestatiet tikai SFTP lietotāju kontus Ubuntu 14

Ievads Dažos gadījumos ir nepieciešams izveidot lietotājus ar lasīšanas un rakstīšanas piekļuvi vienam direktorijam, tikai izmantojot FTP. Šis raksts jums parādīs, kā t

Kā iestatīt Node.js pastāvīgās lietojumprogrammas Ubuntu 16.04

Kā iestatīt Node.js pastāvīgās lietojumprogrammas Ubuntu 16.04

Node.js lietojumprogrammas ir populāras to mērogošanas spējas dēļ. Vairāku vienlaicīgu procesu palaišana vairākos serveros nodrošina mazāku latentumu un ilgāku darbības laiku

Kā instalēt SuiteCRM operētājsistēmā Ubuntu 16.04

Kā instalēt SuiteCRM operētājsistēmā Ubuntu 16.04

SuiteCRM ir bezmaksas atvērtā koda alternatīva populārajai klientu attiecību pārvaldības (CRM) sistēmai SugarCRM. Tas kļuva populārs, kad SugarCRM nolēma

Kā instalēt Open Eshop operētājsistēmā Ubuntu 16.04

Kā instalēt Open Eshop operētājsistēmā Ubuntu 16.04

Open Eshop ir bezmaksas atvērtā koda e-komercijas programmatūra digitālo preču, piemēram, MP3, e-grāmatu, filmu, programmatūras un daudz ko citu, pārdošanai. Šajā apmācībā mēs vēlēsimies

Instalējiet NixOS vietnē Vultr

Instalējiet NixOS vietnē Vultr

NixOS ir tīri funkcionāls Linux izplatīšana. To var atrast vietnē nixos.org. Galvenais NixOS izmantošanas iemesls ir tas, ka tas ir pilnībā deklaratīvs, kas padara

Instalējiet Nginx + PHP FPM + Caching + MySQL Ubuntu 12.04

Instalējiet Nginx + PHP FPM + Caching + MySQL Ubuntu 12.04

Iespējams, daudzi cilvēki izmantos savus Vultr VPS kā tīmekļa serverus, laba izvēle būtu Nginx kā tīmekļa serveris. Šajā tēmā es aprakstīšu o

Hosts faila izmantošana vietņu pārbaudei

Hosts faila izmantošana vietņu pārbaudei

Hosts fails ir īpašs fails jūsu darbstacijas datorā, kurā tiks saglabāta IP un nosaukuma informācija. Šis fails tiek pārbaudīts pirms DNS, tādēļ, ja ievietojat a

Kā instalēt Xubuntu darbvirsmu Vultr serveros, izmantojot Ubuntu 15.10

Kā instalēt Xubuntu darbvirsmu Vultr serveros, izmantojot Ubuntu 15.10

Xubuntu ir XFCE + Ubuntu! XFCE ir viegla Ubuntu GUI/darbvirsma. Vultr serveriem ir nepieciešamas papildu atkarības, kas pēc noklusējuma nav instalētas

Iestatīšana ļauj šifrēt ar Lighttpd Ubuntu 16.04

Iestatīšana ļauj šifrēt ar Lighttpd Ubuntu 16.04

Ievads Let's Encrypt ir sertifikācijas iestāde (CA), kas izsniedz bezmaksas SSL/TLS sertifikātus. Lighttpd ir viegls tīmekļa serveris, kas darbojas uz lo

Apache optimizācija zemas klases VPS operētājsistēmā Ubuntu 14.04

Apache optimizācija zemas klases VPS operētājsistēmā Ubuntu 14.04

Apache ir ļoti viegli instalēt un inicializēt, taču tas ir aprīkots ar daudziem iepriekš instalētiem moduļiem, kā rezultātā, palaižot, var rasties veiktspējas problēmas.

Kā novērst vienlaicīgus savienojumus operētājsistēmā Linux, izmantojot IPTables

Kā novērst vienlaicīgus savienojumus operētājsistēmā Linux, izmantojot IPTables

iptables ir ugunsmūra programmatūra, ko var atrast daudzos izplatījumos, tostarp CentOS un Ubuntu. Šajā dokumentā jūs redzēsit, kā jūs varat novērst vienlaicīgumu

Mašīnu pieaugums: AI reālās pasaules lietojumi

Mašīnu pieaugums: AI reālās pasaules lietojumi

Mākslīgais intelekts nav nākotnē, tas ir šeit, tagadnē. Šajā emuārā lasiet, kā mākslīgā intelekta lietojumprogrammas ir ietekmējušas dažādas nozares.

DDOS uzbrukumi: īss pārskats

DDOS uzbrukumi: īss pārskats

Vai arī jūs esat DDOS uzbrukumu upuris un esat neizpratnē par profilakses metodēm? Izlasiet šo rakstu, lai atrisinātu savus jautājumus.

Vai esat kādreiz domājis, kā hakeri pelna naudu?

Vai esat kādreiz domājis, kā hakeri pelna naudu?

Iespējams, esat dzirdējuši, ka hakeri pelna daudz naudas, bet vai esat kādreiz domājuši, kā viņi nopelna šādu naudu? pārrunāsim.

Google revolucionāri izgudrojumi, kas atvieglos jūsu dzīvi.

Google revolucionāri izgudrojumi, kas atvieglos jūsu dzīvi.

Vai vēlaties redzēt revolucionārus Google izgudrojumus un to, kā šie izgudrojumi mainīja katra cilvēka dzīvi mūsdienās? Pēc tam lasiet emuārā, lai redzētu Google izgudrojumus.

Piektdiena: kas notika ar AI vadītām automašīnām?

Piektdiena: kas notika ar AI vadītām automašīnām?

Pašpiedziņas automobiļu koncepcija izbraukt uz ceļiem ar mākslīgā intelekta palīdzību ir mūsu sapnis jau kādu laiku. Bet, neskatoties uz vairākiem solījumiem, tie nekur nav redzami. Lasiet šo emuāru, lai uzzinātu vairāk…

Tehnoloģiskā singularitāte: cilvēces civilizācijas tāla nākotne?

Tehnoloģiskā singularitāte: cilvēces civilizācijas tāla nākotne?

Zinātnei strauji attīstoties, pārņemot lielu daļu mūsu pūļu, palielinās arī risks pakļaut sevi neizskaidrojamai singularitātei. Izlasiet, ko singularitāte varētu nozīmēt mums.

Datu glabāšanas evolūcija – infografika

Datu glabāšanas evolūcija – infografika

Datu uzglabāšanas metodes ir attīstījušās kopš datu dzimšanas. Šajā emuārā ir aprakstīta datu uzglabāšanas attīstība, pamatojoties uz infografiku.

Lielo datu atsauces arhitektūras slāņu funkcijas

Lielo datu atsauces arhitektūras slāņu funkcijas

Lasiet emuāru, lai vienkāršākā veidā uzzinātu dažādus lielo datu arhitektūras slāņus un to funkcijas.

6 brīnišķīgas priekšrocības, ko sniedz viedo mājas ierīču izmantošana mūsu dzīvē

6 brīnišķīgas priekšrocības, ko sniedz viedo mājas ierīču izmantošana mūsu dzīvē

Šajā digitālajā pasaulē viedās mājas ierīces ir kļuvušas par būtisku dzīves sastāvdaļu. Šeit ir daži pārsteidzoši viedo mājas ierīču ieguvumi, lai padarītu mūsu dzīvi dzīves vērtu un vienkāršāku.

MacOS Catalina 10.15.4 papildinājuma atjauninājums rada vairāk problēmu nekā to risināšana

MacOS Catalina 10.15.4 papildinājuma atjauninājums rada vairāk problēmu nekā to risināšana

Nesen Apple izlaida macOS Catalina 10.15.4 papildinājuma atjauninājumu, lai novērstu problēmas, taču šķiet, ka atjauninājums rada vairāk problēmu, kas izraisa Mac datoru bloķēšanu. Izlasiet šo rakstu, lai uzzinātu vairāk