HTTP/s HTTP/s HTTP3
pengenalan
Ini adalah salah satu topik kegemaran saya, dan ini akan menjadi artikel yang berpengetahuan. Jadi baca dengan teliti.
Perkongsian Domain
- Perkongsian domain ialah teknik yang digunakan untuk meningkatkan kelajuan dan prestasi tapak web.
- Ia melibatkan pembahagian atau "sharding" sumber merentas berbilang domain.
- Apabila penyemak imbas memuatkan tapak web, ia membuat permintaan kepada pelayan tapak web untuk memuat turun pelbagai jenis sumber seperti HTML, CSS, JavaScript, imej, dll.
- Walau bagaimanapun, penyemak imbas mengehadkan bilangan sambungan serentak (muat turun) yang akan mereka buat kepada satu domain. (6, bergantung pada Penyemak Imbas)
- Dengan memecah sumber merentas berbilang domain (contohnya, menyajikan imej daripada domain yang berbeza daripada skrip), anda boleh memintas had ini dan memuat turun lebih banyak sumber pada masa yang sama, yang boleh membawa kepada masa pemuatan halaman yang lebih cepat.
Multiplexing
- yang membenarkan berbilang permintaan dan respons dihantar pada masa yang sama melalui satu sambungan (Lalai sekitar 100)
NOTA:-
- Walau bagaimanapun, adalah penting untuk ambil perhatian bahawa HTTP/2, versi terkini protokol HTTP, menyokong multiplexing,
Cara menerima pakai/menukar protokol semasa
Untuk bertukar daripada HTTP/1 kepada HTTP/2, anda perlu mengkonfigurasi pelayan anda untuk menyokong HTTP/2.
Langkah yang tepat bergantung pada perisian pelayan yang anda gunakan. Berikut ialah langkah umum untuk beberapa pelayan biasa:
Apache:
- Apache menyokong HTTP/2 dari versi 2.4.17 dan seterusnya. Untuk mendayakannya, anda perlu memasukkan modul mod_http2 dalam konfigurasi Apache anda dan kemudian menambah Protokol h2 http/1.1 pada konfigurasi anda.
Nginx:
- Nginx menyokong HTTP/2 dari versi 1.9.5 dan seterusnya. Untuk mendayakannya, masukkan http2 dalam arahan dengar anda dalam konfigurasi Nginx anda, seperti: dengar 443 ssl http2.
Node.js:
-Jika anda menggunakan Node.js, anda boleh menggunakan modul http2 terbina dalam untuk mencipta pelayan HTTP/2.
NOTA:-
Ingat, HTTP/2 memerlukan HTTPS dalam kebanyakan penyemak imbas, jadi anda juga perlu menyediakan sijil SSL untuk pelayan anda.
Dari perspektif Front-End apa sahaja yang kami lakukan ?
- Tidak, suis daripada HTTP/1 kepada HTTP/2 dikendalikan di peringkat pelayan, bukan di peringkat pelanggan atau bahagian hadapan.
- Walau bagaimanapun, sebaik sahaja pelayan anda menyokong HTTP/2, anda mungkin ingin mempertimbangkan semula teknik pengoptimuman prestasi tertentu yang biasa dengan HTTP/1, seperti pemecahan domain atau penyatuan aset, kerana ia boleh menjadi tidak perlu atau malah memudaratkan HTTP/2 .
Bagaimana sambungan Berlaku dalam Pelanggan dan Pelayan
HTTP/1
HTTP/1 beroperasi pada satu sambungan bagi setiap model permintaan/tindak balas. Ini bermakna untuk setiap permintaan daripada klien ke pelayan, sambungan TCP yang berasingan diwujudkan.
Jika halaman web memerlukan berbilang sumber (seperti imej, CSS, fail JavaScript), berbilang sambungan TCP perlu diwujudkan.
Ini boleh membawa kepada masalah yang dikenali sebagai "sekatan ketua baris", di mana pemuatan sumber boleh disekat dengan pemuatan sumber sebelumnya.
HTTP/1 tidak menyokong tolak pelayan, bermakna pelayan hanya boleh menghantar sumber yang diminta oleh pelanggan.
HTTP/2
HTTP/2 memperkenalkan pemultipleksan, yang membolehkan berbilang permintaan dan respons dihantar pada masa yang sama melalui satu sambungan TCP. Ini secara berkesan menghapuskan masalah penyekatan kepala baris.
HTTP/2 juga memperkenalkan tolak pelayan, di mana pelayan boleh menghantar sumber kepada klien secara proaktif sebelum pelanggan memintanya. Ini boleh meningkatkan prestasi dengan mengurangkan keperluan untuk permintaan pergi balik antara pelanggan dan pelayan.
HTTP/2 juga menyokong pemampatan pengepala, yang boleh mengurangkan overhed dan meningkatkan prestasi, terutamanya untuk pengguna mudah alih.
HTTP/2 turut menyokong pemampatan pengepala
HTTP/2 memperkenalkan ciri baharu yang dipanggil Mampatan Pengepala, yang mengurangkan overhed pengepala HTTP.
Dalam HTTP/1, pengepala dihantar sebagai teks biasa, yang boleh menjadi agak besar dan menambah overhed yang ketara pada setiap permintaan dan respons.
Ini terutama berlaku untuk permintaan yang menyertakan kuki atau token dalam pengepala.
HTTP/2 menggunakan mekanisme yang dipanggil Mampatan HPACK untuk memampatkan pengepala.
HPACK ialah skim mampatan rentetan yang mudah dan selamat yang mengurangkan saiz pengepala, menjadikan permintaan dan respons HTTP/2 lebih pantas dan cekap.
Mampatan HPACK berfungsi Secara Dalaman
Ia dengan mengekalkan senarai medan pengepala yang dihantar sebelum ini pada kedua-dua bahagian klien dan pelayan, yang dikenali sebagai jadual dinamik.
Apabila medan pengepala diulang dalam permintaan atau respons berikutnya, bukannya menghantar keseluruhan medan pengepala, indeks yang merujuk masukan dalam jadual dinamik dihantar.
Ini mengurangkan dengan ketara saiz pengepala untuk permintaan dan respons, terutamanya apabila banyak pengepala diulang merentas permintaan.
HTTP/3
- HTTP/3 ialah versi utama protokol HTTP yang seterusnya. Ia dibina di atas QUIC, protokol lapisan pengangkutan dibangunkan oleh Google.
Berikut ialah beberapa kelebihan HTTP/3 berbanding HTTP/2:
Kelajuan yang Dipertingkatkan:
- HTTP/3 menggunakan QUIC, yang direka bentuk untuk menjadi lebih pantas dan lebih dipercayai daripada TCP, protokol pengangkutan yang digunakan oleh HTTP/1 dan HTTP/2.
- QUIC mengurangkan masa penubuhan sambungan, menjadikan sambungan awal ke pelayan lebih cepat.
Pengendalian Kehilangan Paket yang Lebih Baik:
- Dalam HTTP/2, paket yang hilang memperlahankan semua strim (permintaan/tindak balas). QUIC menyelesaikan masalah ini dengan mengendalikan aliran secara bebas, jadi paket yang hilang hanya menjejaskan satu aliran.
Migrasi Sambungan:
QUIC menyokong pemindahan sambungan, yang bermaksud jika pengguna menukar rangkaian mereka (seperti menukar daripada Wi-Fi kepada 4G), sambungan sedia ada boleh dikekalkan dan dipindahkan ke rangkaian baharu.
Ini tidak boleh dilakukan dengan TCP, yang terikat pada alamat IP asal.
Penyulitan secara Lalai:
- QUIC termasuk penyulitan TLS 1.3 secara lalai. Ini menjadikan protokol lebih selamat dan mengurangkan bilangan perjalanan pergi dan balik yang diperlukan untuk menyediakan sambungan.
Tekan Pelayan:
- Seperti HTTP/2, HTTP/3 juga menyokong tolak pelayan, di mana pelayan boleh menghantar sumber kepada klien secara proaktif, sebelum pelanggan memintanya.
NOTA:-
Adalah penting untuk ambil perhatian bahawa walaupun HTTP/3 mempunyai beberapa kelebihan, ia masih tidak disokong atau digunakan secara meluas setakat ini.
Rujukan:-
- https://frontendmasters.com/courses/realtime/
- https://developer.mozilla.org/en-US/docs/Web/HTTP
- https://developer.mozilla.org/en-US/docs/Glossary/HTTP_2
- https://developer.mozilla.org/en-US/docs/Glossary/HTTP_3
Atas ialah kandungan terperinci HTTP/s HTTP/s HTTP3. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undress AI Tool
Gambar buka pakaian secara percuma

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Skop JavaScript menentukan skop kebolehcapaian pembolehubah, yang dibahagikan kepada skop global, fungsi dan tahap blok; Konteks menentukan arah ini dan bergantung kepada kaedah panggilan fungsi. 1. Skop termasuk skop global (boleh diakses di mana sahaja), skop fungsi (hanya sah dalam fungsi), dan skop peringkat blok (biarkan dan const sah dalam {}). 2. Konteks pelaksanaan mengandungi objek pembolehubah, rantaian skop dan nilai -nilai ini. Ini menunjukkan kepada global atau tidak ditentukan dalam fungsi biasa, kaedah panggilan kaedah ke objek panggilan, pembina menunjuk ke objek baru, dan juga boleh ditentukan secara jelas oleh panggilan/memohon/mengikat. 3. Penutupan merujuk kepada fungsi mengakses dan mengingati pembolehubah skop luaran. Mereka sering digunakan untuk enkapsulasi dan cache, tetapi boleh menyebabkan

Pemutus jenis adalah tingkah laku secara automatik menukar satu jenis nilai kepada jenis lain dalam JavaScript. Senario biasa termasuk: 1. Apabila menggunakan pengendali, jika satu sisi adalah rentetan, sisi lain juga akan ditukar kepada rentetan, seperti '5' 5. Hasilnya ialah "55"; 2. 3. Null mengambil bahagian dalam operasi berangka dan akan ditukar kepada 0, dan undefined akan ditukar kepada NAN; 4. Masalah yang disebabkan oleh penukaran tersirat boleh dielakkan melalui fungsi penukaran eksplisit seperti nombor (), rentetan (), dan boolean (). Menguasai peraturan ini membantu

COMPOSISAPI dalam VUE3 lebih sesuai untuk logik dan jenis derivasi yang kompleks, dan OptionsAPI sesuai untuk senario dan pemula yang mudah; 1. Optionsapi menganjurkan kod mengikut pilihan seperti data dan kaedah, dan mempunyai struktur yang jelas tetapi komponen kompleks dipecah -pecah; 2. CompositionAPI menggunakan persediaan untuk menumpukan logik yang berkaitan, yang kondusif untuk penyelenggaraan dan penggunaan semula; 3. Compositionapi menyedari penggunaan semula logik bebas konflik dan parameternya melalui fungsi kompos yang lebih baik daripada Mixin; 4. CompositionAPI mempunyai sokongan yang lebih baik untuk typescript dan derivasi jenis yang lebih tepat; 5. Tidak terdapat perbezaan yang signifikan dalam jumlah prestasi dan pembungkusan kedua -duanya; 6.

Terdapat perbezaan penting antara pekerja web JavaScript dan Javathreads dalam pemprosesan serentak. 1. JavaScript mengamalkan model tunggal-thread. WebWorkers adalah benang bebas yang disediakan oleh penyemak imbas. Ia sesuai untuk melaksanakan tugas-tugas yang memakan masa yang tidak menghalang UI, tetapi tidak dapat mengendalikan DOM; 2. Java menyokong multithreading sebenar dari tahap bahasa, yang dibuat melalui kelas thread, sesuai untuk logik serentak dan pemprosesan sisi serentak; 3. WebWorkers menggunakan postmessage () untuk berkomunikasi dengan benang utama, yang sangat selamat dan terpencil; Benang Java boleh berkongsi ingatan, jadi isu penyegerakan perlu diberi perhatian; 4. Pekerja web lebih sesuai untuk pengkomputeran selari depan, seperti pemprosesan imej, dan

Gunakan document.createelement () untuk membuat elemen baru; 2. Sesuaikan elemen melalui textContent, classlist, setAttribute dan kaedah lain; 3. Gunakan kaedah tambahan () atau lebih fleksibel () untuk menambah elemen ke DOM; 4. Secara pilihan menggunakan InsertBefore (), sebelum () dan kaedah lain untuk mengawal kedudukan penyisipan; Proses lengkap adalah untuk membuat → Sesuaikan → Tambah, dan anda boleh mengemas kini kandungan halaman secara dinamik.

Memulakan projek dan buat pakej.json; 2. Buat skrip kemasukan index.js dengan shebang; 3. Daftar perintah melalui medan bin dalam pakej.json; 4. Gunakan Yargs dan perpustakaan lain untuk menghuraikan parameter baris arahan; 5. Gunakan ujian tempatan NPMLink; 6. Tambah bantuan, versi dan pilihan untuk meningkatkan pengalaman; 7. Secara pilihan menerbitkan melalui NPMPublish; 8. Secara pilihan mencapai penyelesaian automatik dengan YARGS; Akhirnya buat alat CLI praktikal melalui struktur yang munasabah dan reka bentuk pengalaman pengguna, tugas automasi lengkap atau mengedarkan widget, dan berakhir dengan ayat lengkap.

Tarikh format dalam JavaScript boleh dilaksanakan melalui kaedah asli atau perpustakaan pihak ketiga. 1. Gunakan Jahitan Objek Tarikh Asli: Dapatkan bahagian tarikh melalui getfuleear, getmonth, getdate dan kaedah lain, dan secara manual menyambungkannya ke yyyy-mm-dd dan format lain, yang sesuai untuk keperluan ringan dan tidak bergantung pada perpustakaan pihak ketiga; 2. Gunakan kaedah tolocaledatestring: anda boleh output seperti format mm/dd/yyyy mengikut tabiat tempatan, menyokong pelbagai bahasa, tetapi formatnya mungkin tidak konsisten kerana persekitaran yang berbeza; 3. Gunakan perpustakaan pihak ketiga seperti hari.js atau tarikh-FNS: Menyediakan sintaks ringkas dan fungsi yang kaya, sesuai untuk operasi yang kerap atau apabila kelanjutan diperlukan, seperti dayjs ()

Jenis Keadaan Lanjutan TypeScript Melaksanakan penghakiman logik antara jenis melalui Textendsu? X: Y Sintaks. Keupayaan terasnya ditunjukkan dalam jenis keadaan yang diedarkan, kesimpulan jenis kesimpulan dan pembinaan alat jenis kompleks. 1. Jenis bersyarat diedarkan dalam parameter jenis kosong dan secara automatik boleh memecah jenis bersama, seperti toarray untuk mendapatkan rentetan [] | number []. 2. Menggunakan Pengagihan untuk Membina Alat Penapisan dan Pengekstrakan: Tidak termasuk Kecualikan Jenis Melalui Textendsu? Tidak pernah: T, Ekstrak Ekstrak Persamaan melalui Textendsu? 3
