Searching...
فارسی
EnglishEnglish
EspañolSpanish
简体中文Chinese
FrançaisFrench
DeutschGerman
日本語Japanese
PortuguêsPortuguese
ItalianoItalian
한국어Korean
РусскийRussian
NederlandsDutch
العربيةArabic
PolskiPolish
हिन्दीHindi
Tiếng ViệtVietnamese
SvenskaSwedish
ΕλληνικάGreek
TürkçeTurkish
ไทยThai
ČeštinaCzech
RomânăRomanian
MagyarHungarian
УкраїнськаUkrainian
Bahasa IndonesiaIndonesian
DanskDanish
SuomiFinnish
БългарскиBulgarian
עבריתHebrew
NorskNorwegian
HrvatskiCroatian
CatalàCatalan
SlovenčinaSlovak
LietuviųLithuanian
SlovenščinaSlovenian
СрпскиSerbian
EestiEstonian
LatviešuLatvian
فارسیPersian
മലയാളംMalayalam
தமிழ்Tamil
اردوUrdu
High Performance Browser Networking

High Performance Browser Networking

توسط Ilya Grigorik 2013 400 صفحات
4.51
833 امتیازها
گوش دادن
Try Full Access for 7 Days
Unlock listening & more!
Continue

نکات کلیدی

۱. اصول عملکرد شبکه: تأخیر و پهنای باند

سرعت یک ویژگی است و در واقع، برای برخی از برنامه‌ها، این ویژگی اصلی به شمار می‌رود.

تأخیر اهمیت بیشتری نسبت به پهنای باند دارد. در اغلب موارد، عملکرد برنامه‌های وب بیشتر به تأخیر وابسته است تا پهنای باند. تأخیر به زمانی گفته می‌شود که یک پیام از نقطه‌ی مبدأ به مقصد می‌رسد، در حالی که پهنای باند حداکثر ظرفیت انتقال داده در یک مسیر ارتباطی منطقی یا فیزیکی است.

عوامل مؤثر بر تأخیر:

  • تأخیر انتشار (فاصله)
  • تأخیر انتقال (حجم داده)
  • تأخیر پردازش (تجهیزات شبکه)
  • تأخیر صف‌بندی (ازدحام شبکه)

کاهش تأخیر برای بهبود تجربه کاربری حیاتی است، زیرا انسان‌ها تأخیرهای حتی به اندازه ۱۰۰ تا ۳۰۰ میلی‌ثانیه را احساس می‌کنند. برای بهینه‌سازی عملکرد باید بر موارد زیر تمرکز کرد:

  • کاهش تعداد رفت و برگشت‌ها
  • انتقال داده‌ها به نزدیکی کاربر (مثلاً با استفاده از شبکه‌های تحویل محتوا)
  • بهره‌گیری از تکنیک‌های کشینگ و فشرده‌سازی

۲. TCP و UDP: پایه‌های ارتباط اینترنتی

TCP انتزاعی از شبکه‌ای قابل اعتماد است که بر روی کانالی غیرقابل اعتماد اجرا می‌شود.

TCP تحویل مطمئن و مرتب داده‌ها را تضمین می‌کند. پروتکل کنترل انتقال (TCP) برای تحویل دقیق داده‌ها به جای تحویل سریع بهینه شده است. این پروتکل شامل ویژگی‌هایی مانند کنترل جریان، کنترل ازدحام و بررسی خطا است که آن را برای برنامه‌هایی که نیاز به دریافت کامل داده‌ها دارند، مناسب می‌سازد.

مفاهیم کلیدی TCP:

  • دست دادن سه مرحله‌ای
  • الگوریتم شروع آهسته
  • اجتناب از ازدحام

UDP سرعت را بر قابلیت اطمینان ترجیح می‌دهد. پروتکل دیتاگرام کاربر (UDP) پروتکلی ساده و بدون اتصال است که ارتباطی با تأخیر کم و تحمل از دست رفتن داده‌ها فراهم می‌کند. این پروتکل معمولاً برای برنامه‌های زمان واقعی مانند پخش ویدئو و بازی‌های آنلاین استفاده می‌شود.

ویژگی‌های UDP:

  • عدم تضمین تحویل یا ترتیب داده‌ها
  • بدون وضعیت اتصال یا کنترل ازدحام
  • سربار و تأخیر کمتر

۳. تکامل HTTP: از نسخه ۰.۹ تا ۲.۰

HTTP 2.0 برنامه‌های ما را سریع‌تر، ساده‌تر و مقاوم‌تر خواهد کرد؛ ترکیبی نادر و ارزشمند.

HTTP همواره برای پاسخگویی به نیازهای وب تکامل یافته است. پروتکل انتقال ابرمتن (HTTP) از زمان پیدایش تا نسخه کنونی HTTP/2 تغییرات قابل توجهی داشته است. هر نسخه بهبودهایی در عملکرد، قابلیت‌ها و کارایی به همراه داشته است.

خط زمانی تکامل HTTP:

  • HTTP/0.9 (۱۹۹۱): پروتکلی ساده و تک‌خطی
  • HTTP/1.0 (۱۹۹۶): افزودن هدرها، متدها و کدهای وضعیت
  • HTTP/1.1 (۱۹۹۷): معرفی اتصال‌های نگهدارنده و پایپلاینینگ
  • HTTP/2 (۲۰۱۵): چندگانه‌سازی، فشرده‌سازی هدرها، ارسال پیش‌دستی سرور

HTTP/2 بسیاری از محدودیت‌های نسخه‌های قبلی را برطرف کرده و امکاناتی مانند:

  • چندگانه‌سازی کامل درخواست‌ها و پاسخ‌ها
  • فشرده‌سازی هدرها
  • قابلیت ارسال پیش‌دستی سرور
  • اولویت‌بندی درخواست‌ها

را فراهم می‌کند. این بهبودها به طور چشمگیری تأخیر را کاهش داده و سرعت بارگذاری صفحات، به‌ویژه در برنامه‌های وب پیچیده، را افزایش می‌دهند.

۴. TLS: تأمین امنیت ارتباطات وب

امنیت و عملکرد دو مقوله متضاد نیستند و TLS می‌تواند به گونه‌ای بهینه شود که تأثیر آن بر عملکرد برنامه‌های وب به حداقل برسد.

TLS رمزنگاری، احراز هویت و یکپارچگی داده‌ها را فراهم می‌کند. امنیت لایه انتقال (TLS) پروتکلی است که مسئول تأمین امنیت ارتباطات در وب است. این پروتکل تضمین می‌کند که داده‌های مبادله شده بین کلاینت و سرور خصوصی و بدون تغییر باقی بمانند.

اجزای کلیدی TLS:

  • پروتکل دست دادن: احراز هویت طرفین و مذاکره پارامترهای رمزنگاری
  • پروتکل رکورد: رمزنگاری و انتقال داده‌های برنامه

اگرچه TLS مقداری سربار به ارتباطات وب اضافه می‌کند، اما تکنیک‌های بهینه‌سازی متعددی برای کاهش این تأثیر وجود دارد:

  • از سرگیری جلسه TLS
  • شروع کاذب TLS
  • منگنه‌کردن OCSP
  • رمزنگاری منحنی بیضوی

اجرای این بهینه‌سازی‌ها می‌تواند تأخیر ناشی از TLS را به طور قابل توجهی کاهش داده و امنیت و عملکرد را همزمان تضمین کند.

۵. شبکه‌های موبایل: چالش‌ها و بهینه‌سازی‌ها

عملکرد برنامه شما، به‌ویژه در بارگذاری اولیه و «زمان رندر»، مستقیماً به نحوه حل وابستگی بین نشانه‌گذاری، استایل‌ها و جاوااسکریپت بستگی دارد.

شبکه‌های موبایل چالش‌های خاص خود را دارند. شبکه‌های موبایل به دلیل تأخیرهای بیشتر، پهنای باند کمتر و اتصال‌های ناپایدارتر نسبت به شبکه‌های ثابت، پیچیدگی‌های اضافی ایجاد می‌کنند. درک این چالش‌ها برای بهینه‌سازی برنامه‌های وب برای کاربران موبایل ضروری است.

ویژگی‌های کلیدی شبکه‌های موبایل:

  • تأخیر و پهنای باند متغیر
  • انتقال وضعیت کنترل منابع رادیویی (RRC)
  • ملاحظات مصرف انرژی

راهبردهای بهینه‌سازی برای موبایل:

  • کاهش و تجمیع درخواست‌های شبکه
  • پیاده‌سازی مکانیزم‌های کشینگ مؤثر
  • استفاده از فشرده‌سازی برای انتقال داده‌ها
  • بهینه‌سازی تصاویر و رسانه‌ها برای دستگاه‌های موبایل
  • بهره‌گیری از قابلیت‌های آفلاین (مانند سرویس‌ورکرها)

با تطبیق برنامه‌های وب با محدودیت‌های خاص شبکه‌های موبایل، توسعه‌دهندگان می‌توانند عملکرد و تجربه کاربری را برای کاربران موبایل به طور چشمگیری بهبود بخشند.

۶. APIهای مرورگر: XMLHttpRequest، رویدادهای ارسال شده از سرور و WebSockets

سریع‌ترین درخواست شبکه، درخواستی است که اصلاً ارسال نمی‌شود.

مرورگرهای مدرن APIهای قدرتمندی برای شبکه ارائه می‌دهند. توسعه‌دهندگان وب به مجموعه‌ای از APIها برای ارتباط شبکه‌ای کارآمد دسترسی دارند که هرکدام برای موارد استفاده خاصی مناسب است.

مقایسه APIهای شبکه مرورگر:
XMLHttpRequest (XHR):

  • روش سنتی برای درخواست‌های AJAX
  • پشتیبانی از ارسال و دریافت داده
  • محدود به سیاست مبدأ یکسان (مگر با استفاده از CORS)

رویدادهای ارسال شده از سرور (SSE):

  • امکان به‌روزرسانی‌های زمان واقعی از سرور به کلاینت
  • یک‌طرفه (فقط از سرور به کلاینت)
  • مدیریت خودکار اتصال مجدد

WebSockets:

  • ارتباط دوطرفه و تمام‌دوطرفه
  • تأخیر کم، مناسب برای برنامه‌های زمان واقعی
  • نیازمند پشتیبانی ویژه سرور

انتخاب API مناسب بستگی به نیازهای خاص برنامه شما دارد. برای به‌روزرسانی‌های زمان واقعی، SSE یا WebSockets معمولاً کارآمدتر از پرس‌وجوی مکرر با XHR هستند. با این حال، XHR همچنان برای الگوهای سنتی درخواست-پاسخ مفید است.

۷. WebRTC: فراهم کردن ارتباط همتا به همتا در مرورگرها

WebRTC فراتر از یک API معمولی مرورگر است.

WebRTC انقلابی در ارتباطات مبتنی بر مرورگر ایجاد کرده است. ارتباط بلادرنگ وب (WebRTC) امکان ارتباط مستقیم همتا به همتا بین مرورگرها را فراهم می‌کند و برنامه‌هایی مانند تماس ویدئویی، اشتراک فایل و ویرایش مشترک را بدون نیاز به افزونه یا نرم‌افزارهای جانبی ممکن می‌سازد.

اجزای کلیدی WebRTC:

  • MediaStream: مدیریت ضبط صدا و تصویر
  • RTCPeerConnection: مدیریت ارتباطات همتا و انتقال داده
  • RTCDataChannel: امکان تبادل داده دلخواه بین همتاها

WebRTC از UDP به عنوان پروتکل انتقال خود استفاده می‌کند و تأخیر کم را بر تحویل تضمینی ترجیح می‌دهد. این فناوری چندین پروتکل دیگر را برای مدیریت جنبه‌های مختلف ارتباط همتا به همتا به کار می‌گیرد:

  • ICE، STUN و TURN برای عبور از NAT
  • DTLS برای تأمین امنیت انتقال داده‌ها
  • SCTP و SRTP برای چندگانه‌سازی و کنترل ازدحام

اگرچه WebRTC امکانات جدیدی برای برنامه‌های وب فراهم می‌کند، اما پیچیدگی‌هایی در زمینه برقراری اتصال و عبور از NAT به همراه دارد که توسعه‌دهندگان باید هنگام پیاده‌سازی ویژگی‌های مبتنی بر WebRTC به دقت مدنظر قرار دهند.

آخرین به‌روزرسانی::

FAQ

What's High Performance Browser Networking about?

  • Focus on Networking Protocols: The book explores foundational networking protocols like TCP, UDP, and HTTP, which are essential for web development.
  • Performance Optimization: It emphasizes optimizing network performance to enhance user experience, offering insights on reducing latency and improving throughput.
  • Modern Web Technologies: Covers advancements like HTTP/2, WebSockets, and WebRTC, crucial for developing modern web applications.

Why should I read High Performance Browser Networking?

  • Essential for Developers: It's a must-read for web developers to understand networking behaviors and tackle complex performance issues.
  • Actionable Insights: Provides practical advice with real-world examples, making it easier to apply concepts in your applications.
  • Stay Updated: Helps you stay current with the latest practices and protocols that impact performance significantly.

What are the key takeaways of High Performance Browser Networking?

  • Latency and Bandwidth: Emphasizes the roles of latency and bandwidth in network performance, noting that latency is often the bottleneck.
  • Connection Reuse: Highlights the importance of reusing connections to minimize latency, as new connections incur a full roundtrip of latency.
  • Mobile Network Optimization: Discusses challenges and strategies for optimizing applications for mobile networks with higher latency and lower bandwidth.

What are the best quotes from High Performance Browser Networking and what do they mean?

  • "Good developers know how things work. Great developers know why things work.": Stresses understanding the principles behind technology, not just its use.
  • "Speed is a feature.": Highlights that performance is a critical aspect of web development, influencing user engagement and retention.
  • "Latency, not bandwidth, is the performance bottleneck for most websites!": Corrects the misconception that increasing bandwidth solves performance issues, emphasizing latency reduction instead.

How does High Performance Browser Networking address latency issues?

  • Identifying Latency Sources: Breaks down components like propagation, transmission, and queuing delays to help pinpoint optimization areas.
  • Practical Solutions: Suggests actions like using CDNs to serve content closer to users, offering significant performance benefits.
  • Connection Management: Emphasizes managing connections effectively with techniques like connection keep-alive and TCP Fast Open.

What are the main networking protocols discussed in High Performance Browser Networking?

  • TCP (Transmission Control Protocol): Describes TCP's role in reliable communication, including error correction and flow control.
  • UDP (User Datagram Protocol): Highlights UDP's advantages for low-latency applications like video streaming and gaming.
  • HTTP (Hypertext Transfer Protocol): Covers HTTP's evolution, including the transition to HTTP/2 and its performance improvements.

How does High Performance Browser Networking explain the impact of mobile networks on performance?

  • Unique Challenges: Outlines challenges like higher latency and variable bandwidth in mobile networks.
  • RRC State Management: Explains how Radio Resource Controller impacts latency and battery life, aiding efficient app design.
  • Optimizing for Battery Life: Discusses strategies like reducing network request frequency and leveraging WiFi to minimize battery consumption.

What is the significance of HTTP/2 in High Performance Browser Networking?

  • Multiplexing Requests: Allows multiple requests over a single connection, reducing latency and improving performance.
  • Header Compression: Efficiently compresses HTTP header fields, minimizing protocol overhead and enhancing performance.
  • Server Push: Introduces server push capabilities, allowing proactive resource sending to clients, improving load times.

What is the significance of WebSocket in High Performance Browser Networking?

  • Bidirectional Communication: Enables real-time, bidirectional communication, crucial for interactive applications like chat and live updates.
  • Low Latency: Reduces latency compared to traditional HTTP requests, ideal for immediate data exchange in gaming and finance.
  • Custom Protocols: Allows custom application protocols, providing flexibility and efficient data handling tailored to specific needs.

How does High Performance Browser Networking explain WebRTC?

  • Peer-to-Peer Communication: Describes WebRTC as enabling peer-to-peer audio, video, and data sharing, reducing latency and improving performance.
  • Complex Architecture: Outlines protocols and APIs like ICE, STUN, and TURN, essential for effective WebRTC solutions.
  • Real-Time Applications: Emphasizes WebRTC's potential for real-time applications like video conferencing and collaborative tools.

How does High Performance Browser Networking suggest optimizing for mobile networks?

  • Battery Preservation: Emphasizes strategies like minimizing network requests and optimizing data transfers to preserve battery life.
  • Adaptive Techniques: Discusses adjusting to varying network conditions to maintain responsiveness, including data quality adjustments.
  • Efficient Resource Management: Provides guidance on managing resources to reduce latency and improve performance on mobile networks.

What are the challenges of implementing HTTP/2 and WebSocket as discussed in High Performance Browser Networking?

  • Compatibility Issues: Highlights potential issues with existing infrastructure when transitioning to these protocols.
  • Performance Trade-offs: Discusses trade-offs like connection and resource management, essential for optimizing performance.
  • Operational Complexity: Notes the complexity of implementing these technologies, requiring additional configuration and monitoring.

نقد و بررسی

4.51 از 5
میانگین از 833 امتیازات از Goodreads و Amazon.

کتاب «شبکه‌سازی مرورگر با عملکرد بالا» به‌خاطر پوشش جامع خود در زمینه‌ی عملکرد وب و اصول شبکه‌سازی بسیار مورد تحسین قرار گرفته است. خوانندگان از توضیحات عمیق آن درباره‌ی پروتکل‌ها، شبکه‌های بی‌سیم و رابط‌های برنامه‌نویسی مرورگر (API) استقبال می‌کنند. این کتاب به‌عنوان منبعی ضروری برای توسعه‌دهندگان وب شناخته می‌شود و نکات عملی بهینه‌سازی و بینش‌های ارزشمندی درباره‌ی پیچیدگی‌های فناوری‌های مدرن وب ارائه می‌دهد. اگرچه برخی بخش‌ها برای برخی خوانندگان چالش‌برانگیز یا کمی قدیمی به نظر می‌رسد، اما بیشتر نقدها توانایی نویسنده در توضیح واضح مفاهیم پیچیده و ارائه راهکارهای مؤثر بهینه‌سازی عملکرد برای برنامه‌های وب و موبایل را ستایش می‌کنند.

Your rating:
4.71
42 امتیازها

درباره نویسنده

ایلیا گریگوریک یکی از چهره‌های برجسته در مهندسی عملکرد وب است که در حال حاضر در شرکت گوگل فعالیت می‌کند. او به‌عنوان هم‌رئیس گروه کاری عملکرد وب در کنسرسیوم W3C نقش مهمی در تعیین استانداردهای عملکرد وب ایفا می‌کند. ایلیا گریگوریک بیشتر به‌خاطر تألیف کتاب «شبکه‌سازی مرورگر با عملکرد بالا» شناخته شده است که توسط انتشارات اوریلی منتشر شده است. این کتاب به منبعی معتبر و مرجع برای توسعه‌دهندگانی تبدیل شده که به دنبال بهینه‌سازی عملکرد وب و برنامه‌های موبایل هستند. تخصص گریگوریک در پروتکل‌های شبکه، فناوری‌های مرورگر و تکنیک‌های بهینه‌سازی عملکرد، او را به صدایی معتبر در جامعه توسعه وب بدل کرده است. فعالیت‌های او در گوگل و مشارکت‌هایش در تدوین استانداردهای وب همچنان بر جهت‌گیری مهندسی عملکرد وب تأثیرگذار است.

Listen
Now playing
High Performance Browser Networking
0:00
-0:00
Now playing
High Performance Browser Networking
0:00
-0:00
1x
Voice
Speed
Dan
Andrew
Michelle
Lauren
1.0×
+
200 words per minute
Queue
Home
Library
Get App
Create a free account to unlock:
Recommendations: Personalized for you
Requests: Request new book summaries
Bookmarks: Save your favorite books
History: Revisit books later
Ratings: Rate books & see your ratings
100,000+ readers
Try Full Access for 7 Days
Listen, bookmark, and more
Compare Features Free Pro
📖 Read Summaries
All summaries are free to read in 40 languages
🎧 Listen to Summaries
Listen to unlimited summaries in 40 languages
❤️ Unlimited Bookmarks
Free users are limited to 4
📜 Unlimited History
Free users are limited to 4
📥 Unlimited Downloads
Free users are limited to 1
Risk-Free Timeline
Today: Get Instant Access
Listen to full summaries of 73,530 books. That's 12,000+ hours of audio!
Day 4: Trial Reminder
We'll send you a notification that your trial is ending soon.
Day 7: Your subscription begins
You'll be charged on Jul 13,
cancel anytime before.
Consume 2.8x More Books
2.8x more books Listening Reading
Our users love us
100,000+ readers
"...I can 10x the number of books I can read..."
"...exceptionally accurate, engaging, and beautifully presented..."
"...better than any amazon review when I'm making a book-buying decision..."
Save 62%
Yearly
$119.88 $44.99/year
$3.75/mo
Monthly
$9.99/mo
Start a 7-Day Free Trial
7 days free, then $44.99/year. Cancel anytime.
Scanner
Find a barcode to scan

Settings
General
Widget
Loading...