شروع دوره آزمایشی رایگان
Searching...
SoBrief
فارسی
EnglishEnglish
EspañolSpanish
简体中文Chinese
繁體中文Chinese (Traditional)
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
طراحی سیستم‌های توزیع‌شده

طراحی سیستم‌های توزیع‌شده

الگوها و پارادایم‌ها برای سرویس‌های مقیاس‌پذیر و قابل اعتماد
اثر برندن برنز 2018 162 صفحه
3.58
۵۰۰+ امتیاز
گوش دادن
۳ روز دسترسی کامل رایگان
قفل گوش دادن و امکانات بیشتر را باز کنید!
ادامه

نکات کلیدی

1. کانتینرها و ارکستراتورها توسعه سیستم‌های توزیع‌شده را متحول می‌کنند

کانتینرها و ارکستراتورهای کانتینر در سال‌های اخیر محبوبیت زیادی پیدا کرده‌اند زیرا آن‌ها پایه و اساس و بلوک‌های سازنده برای سیستم‌های توزیع‌شده قابل اعتماد هستند.

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

مزایای کانتینری‌سازی:

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

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

2. الگوهای تک‌گره: Sidecar، Ambassador و Adapter

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

سه الگوی کلیدی تک‌گره:

  1. Sidecar: تقویت و بهبود کانتینر اصلی برنامه
  2. Ambassador: پروکسی کردن اتصالات شبکه به و از کانتینر اصلی
  3. Adapter: استانداردسازی خروجی کانتینر اصلی

این الگوها مدولاریت و قابلیت استفاده مجدد در طراحی کانتینر را ترویج می‌کنند. آن‌ها به توسعه‌دهندگان اجازه می‌دهند تا نگرانی‌ها را جدا کرده و برنامه‌های قابل نگهداری و انعطاف‌پذیرتری ایجاد کنند. به عنوان مثال، یک کانتینر sidecar می‌تواند مدیریت لاگ یا نظارت را بر عهده بگیرد، یک ambassador می‌تواند مدیریت پایان SSL را انجام دهد و یک adapter می‌تواند فرمت‌های خروجی را برای برآورده کردن نیازهای خاص تغییر دهد.

3. الگوهای سرویس‌دهی: خدمات تکراری بارگذاری‌شده و شارد شده

ساده‌ترین الگوی توزیع‌شده، و یکی که بیشتر با آن آشنا هستند، یک سرویس تکراری بارگذاری‌شده است.

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

خدمات شارد شده امکان مدیریت داده‌های بزرگ‌مقیاس را فراهم می‌کنند:

  • داده‌ها در چندین سرور تقسیم می‌شوند
  • هر شارد مسئول یک زیرمجموعه از داده‌ها است
  • امکان پردازش مجموعه داده‌هایی که برای یک ماشین واحد بسیار بزرگ هستند

شاردینگ پیچیدگی‌هایی در سازگاری داده‌ها و مسیریابی کوئری‌ها معرفی می‌کند اما برای ساخت سیستم‌های بسیار مقیاس‌پذیر که می‌توانند مقادیر زیادی از داده‌ها یا ترافیک را مدیریت کنند، ضروری است.

4. الگوی Scatter/Gather برای پردازش موازی و تجمیع

Scatter/gather می‌تواند به عنوان شاردینگ محاسبات لازم برای سرویس‌دهی به درخواست، به جای شاردینگ داده‌ها (اگرچه شاردینگ داده‌ها نیز ممکن است بخشی از آن باشد) دیده شود.

پردازش موازی برای بهبود عملکرد. الگوی Scatter/Gather یک وظیفه را در چندین گره توزیع می‌کند، زیر وظایف را به صورت موازی پردازش می‌کند و سپس نتایج را تجمیع می‌کند. این رویکرد می‌تواند زمان پردازش را برای محاسبات پیچیده یا مجموعه داده‌های بزرگ به طور قابل توجهی کاهش دهد.

اجزای کلیدی:

  1. Scatter: تقسیم وظیفه به زیر وظایف کوچکتر
  2. Process: اجرای زیر وظایف به صورت موازی در چندین گره
  3. Gather: جمع‌آوری و ترکیب نتایج از همه گره‌ها

این الگو به ویژه برای عملیات جستجو، تحلیل داده‌ها و سایر سناریوهایی که کار به راحتی قابل موازی‌سازی و نتایج قابل ادغام است، مفید است.

5. Function-as-a-Service (FaaS) برای پردازش رویدادمحور

FaaS به طور ذاتی یک مدل برنامه‌نویسی مبتنی بر رویداد است. توابع در پاسخ به رویدادهای مجزا که رخ می‌دهند و اجرای توابع را تحریک می‌کنند، اجرا می‌شوند.

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

مزایای FaaS:

  • مقیاس‌گذاری خودکار بر اساس تقاضا
  • مدل قیمت‌گذاری بر اساس اجرا
  • کاهش پیچیدگی عملیاتی
  • زمان سریع‌تر به بازار برای ویژگی‌های جدید

با این حال، FaaS چالش‌هایی در زمینه‌هایی مانند مدیریت حالت، ترکیب توابع و اشکال‌زدایی معرفی می‌کند. توسعه‌دهندگان باید به دقت مزایا و معایب را هنگام پذیرش این مدل برای برنامه‌های خود در نظر بگیرند.

6. انتخاب مالکیت و هماهنگی توزیع‌شده

تعیین کلید مناسب برای تابع شاردینگ شما برای طراحی سیستم شارد شده شما به خوبی حیاتی است.

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

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

  • انتخاب رهبر: انتخاب یک گره اصلی برای هماهنگی
  • قفل‌های توزیع‌شده: اطمینان از انحصار متقابل در میان گره‌ها
  • هشینگ سازگار: نگاشت کارآمد داده‌ها به شاردها

ابزارهایی مانند etcd، ZooKeeper و Consul ابزارهای اولیه برای پیاده‌سازی این الگوهای هماهنگی فراهم می‌کنند و توسعه سیستم‌های توزیع‌شده قوی و مقیاس‌پذیر را ممکن می‌سازند.

7. الگوهای پردازش دسته‌ای برای خطوط داده مقیاس‌پذیر

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

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

الگوهای رایج پردازش دسته‌ای:

  1. صف‌های کار: توزیع وظایف مستقل در میان کارگران
  2. MapReduce: پردازش موازی و تجمیع داده‌ها
  3. خطوط داده: زنجیره‌سازی چندین مرحله پردازش

این الگوها می‌توانند با استفاده از فناوری‌های مختلف، از سیستم‌های ساده مبتنی بر کانتینر تا چارچوب‌های پردازش توزیع‌شده پیچیده مانند Apache Spark یا Flink پیاده‌سازی شوند.

8. جریان‌های کاری رویدادمحور با استفاده از سیستم‌های ناشر/مشترک

یک رویکرد محبوب برای ساخت یک جریان کاری مانند این استفاده از یک API یا سرویس ناشر/مشترک (pub/sub) است.

ارتباط غیرمستقیم برای جریان‌های کاری پیچیده. سیستم‌های pub/sub امکان ایجاد معماری‌های رویدادمحور انعطاف‌پذیر را فراهم می‌کنند که در آن اجزا می‌توانند به صورت غیرهمزمان ارتباط برقرار کنند. این الگو به ویژه برای ساخت جریان‌های کاری مقیاس‌پذیر و قابل نگهداری مفید است.

مزایای کلیدی:

  • اتصال ضعیف بین اجزا
  • بهبود مقیاس‌پذیری و تحمل خطا
  • افزودن آسان مشترکان جدید بدون تأثیر بر ناشران

فناوری‌هایی مانند Apache Kafka، RabbitMQ یا خدمات مبتنی بر ابر مانند Google Cloud Pub/Sub پیاده‌سازی‌های قوی از الگوی pub/sub ارائه می‌دهند و توسعه سیستم‌های رویدادمحور پیچیده را ممکن می‌سازند.

9. پردازش دسته‌ای هماهنگ برای تجمیع داده‌های پیچیده

هماهنگی از طریق پیوستن اطمینان می‌دهد که هیچ داده‌ای قبل از انجام نوعی مرحله تجمیع (مثلاً یافتن مجموع مقداری در یک مجموعه) از دست نمی‌رود.

تکنیک‌های پیشرفته پردازش داده‌ها. الگوهای پردازش دسته‌ای هماهنگ امکان تبدیل و تجمیع داده‌های پیچیده را در مجموعه داده‌های توزیع‌شده فراهم می‌کنند. این الگوها برای ساخت خطوط پردازش داده‌های پیچیده و سیستم‌های تحلیل حیاتی هستند.

الگوهای کلیدی:

  1. پیوستن (همگام‌سازی مانع): اطمینان از تکمیل همه وظایف موازی قبل از ادامه
  2. کاهش: تجمیع نتایج از چندین وظیفه موازی
  3. هیستوگرام: ساخت توزیع‌های آماری از داده‌های توزیع‌شده

این الگوها اغلب بر روی مفاهیم ساده‌تر پردازش دسته‌ای ساخته می‌شوند اما مکانیزم‌های هماهنگی را برای اطمینان از سازگاری و کامل بودن داده‌ها در نتایج نهایی معرفی می‌کنند.

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

الگوهایی مانند sidecars، ambassadors، خدمات شارد شده، FaaS، صف‌های کار و موارد دیگر می‌توانند پایه‌ای باشند که سیستم‌های توزیع‌شده مدرن بر روی آن ساخته می‌شوند.

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

مزایای استفاده از الگوها:

  • کاهش زمان و هزینه توسعه
  • بهبود قابلیت اطمینان و نگهداری سیستم
  • تسهیل ارتباط بین اعضای تیم
  • تسهیل انتقال دانش و ورود به کار

با ادامه تکامل حوزه سیستم‌های توزیع‌شده، الگوهای جدیدی ظهور خواهند کرد و الگوهای موجود بهبود خواهند یافت. آگاهی از این الگوها و درک زمان و چگونگی استفاده از آن‌ها برای توسعه‌دهندگان و معماران نرم‌افزار مدرن حیاتی است.

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

Report Issue

خلاصه نقدها

3.58 از 5
میانگین ۵۰۰+ امتیاز از Goodreads و Amazon.

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

Your rating:
4.19
113 امتیاز
Want to read the full book?

سؤالات متداول

1. What is "Designing Distributed Systems" by Brendan Burns about?

  • Comprehensive guide to patterns: The book introduces and explains reusable patterns and paradigms for building scalable, reliable distributed systems, focusing on practical implementation.
  • Focus on containers and orchestration: It emphasizes the role of containers and container orchestrators (like Kubernetes) as foundational tools for modern distributed system design.
  • Bridging theory and practice: Brendan Burns provides both conceptual overviews and hands-on examples, making complex distributed systems more accessible to developers.
  • Pattern-driven approach: The book organizes distributed system design into repeatable, generic patterns, aiming to transform system building from a black art into a more scientific, standardized process.

2. Why should I read "Designing Distributed Systems" by Brendan Burns?

  • Demystifies distributed systems: The book makes the design and development of distributed systems approachable, even for those without deep prior experience.
  • Reusable knowledge and tools: It provides a shared vocabulary and set of patterns, enabling developers to avoid reinventing the wheel and to build on proven solutions.
  • Practical, hands-on focus: Readers gain actionable advice, code samples, and real-world deployment scenarios, especially using containers and Kubernetes.
  • For all experience levels: Whether you’re new to distributed systems or an experienced engineer, the book offers insights and best practices to improve your efficiency and system reliability.

3. What are the key takeaways from "Designing Distributed Systems" by Brendan Burns?

  • Patterns accelerate development: Recognizing and applying distributed system patterns saves time, reduces errors, and improves system quality.
  • Containers enable modularity: Containers and orchestrators like Kubernetes are essential for building, deploying, and managing reusable system components.
  • Separation of concerns: Patterns like sidecar, ambassador, and adapter help modularize functionality, making systems easier to scale, maintain, and evolve.
  • Community and reuse: Open source and shared patterns foster a collaborative environment where developers can leverage each other’s work for faster, more reliable results.

4. Who is the intended audience for "Designing Distributed Systems" by Brendan Burns?

  • Developers of all levels: The book is suitable for both newcomers to distributed systems and seasoned professionals seeking to formalize their knowledge.
  • Cloud-native practitioners: Those working with containers, Kubernetes, or cloud APIs will find the book especially relevant and practical.
  • Teams building scalable services: It’s valuable for organizations aiming to improve reliability, scalability, and agility in their software systems.
  • Anyone interested in patterns: Readers who appreciate structured approaches and reusable solutions in software engineering will benefit from the book’s pattern-centric methodology.

5. How does Brendan Burns define and use patterns in "Designing Distributed Systems"?

  • General blueprints, not recipes: Patterns are described as reusable, technology-agnostic blueprints for organizing distributed systems, rather than step-by-step instructions for specific technologies.
  • Shared language and best practices: Patterns provide a common vocabulary, enabling teams to communicate more effectively and learn from each other’s experiences.
  • Basis for reusable components: By formalizing patterns, developers can create modular, containerized components that are easily shared and reused across projects.
  • Examples throughout the book: The book details specific patterns like sidecar, ambassador, adapter, replicated services, sharded services, and more, illustrating their application with real-world scenarios.

6. What are the main single-node patterns discussed in "Designing Distributed Systems" by Brendan Burns?

  • Sidecar pattern: Augments an application container with additional functionality (e.g., adding HTTPS, dynamic configuration) without modifying the original application.
  • Ambassador pattern: Acts as a proxy or broker between the application and external services, enabling sharding, service brokering, or request splitting.
  • Adapter pattern: Modifies the interface of an application container to conform to expected standards (e.g., for monitoring, logging, or health checks).
  • Emphasis on modularity: These patterns encourage breaking up applications into focused, reusable containers, improving maintainability and scalability.

7. How does "Designing Distributed Systems" by Brendan Burns address multi-node (serving) patterns?

  • Replicated load-balanced services: Describes how to scale stateless services using replication and load balancing for high availability and performance.
  • Sharded services: Explains partitioning stateful services across multiple nodes to handle large data sets and improve scalability.
  • Scatter/gather pattern: Details parallelizing computation across nodes to reduce response time for complex queries or processing tasks.
  • Ownership election: Covers distributed coordination for assigning exclusive ownership or master roles among replicas, ensuring reliability and failover.

8. What role do containers and Kubernetes play in "Designing Distributed Systems" by Brendan Burns?

  • Foundational building blocks: Containers are presented as the atomic units for encapsulating application logic, dependencies, and configuration.
  • Orchestration for reliability: Kubernetes and similar orchestrators automate deployment, scaling, and management of containerized applications, making distributed patterns practical.
  • Pattern implementation: Many patterns in the book are illustrated with Kubernetes YAML files, showing how to deploy and manage complex systems using container orchestration.
  • Reusable, language-agnostic components: By packaging patterns as containers, they can be reused across different programming languages and environments.

9. How does "Designing Distributed Systems" by Brendan Burns approach batch computational patterns?

  • Work queue systems: Introduces generic, reusable work queue architectures for parallel batch processing, with clear interfaces for sources and workers.
  • Event-driven batch processing: Describes chaining and coordinating work queues using patterns like copier, filter, splitter, sharder, and merger to build complex workflows.
  • Coordinated batch processing: Explains aggregation patterns such as join (barrier synchronization) and reduce (as in MapReduce) for combining results from parallel tasks.
  • Hands-on examples: Provides practical scenarios (e.g., video thumbnailing, image tagging) to demonstrate how these batch patterns are implemented with containers and orchestration.

10. What are the most important concepts and definitions introduced in "Designing Distributed Systems" by Brendan Burns?

  • Pattern: A reusable, general solution to a recurring problem in distributed system design, independent of specific technologies.
  • Sidecar, Ambassador, Adapter: Key single-node patterns for modularizing and extending containerized applications.
  • Replicated, Sharded, Scatter/Gather: Core multi-node patterns for scaling, partitioning, and parallelizing distributed services.
  • Ownership election: Mechanisms for distributed coordination and master selection, often using tools like etcd or ZooKeeper.
  • Batch processing patterns: Work queues, event-driven workflows, and coordinated aggregation (join/reduce) for large-scale data processing.

11. What practical advice does Brendan Burns give for designing modular, reusable distributed systems in "Designing Distributed Systems"?

  • Parameterize containers: Expose configuration via environment variables or command-line arguments to make containers flexible and reusable.
  • Define clear APIs: Treat each container’s interface as a contract, maintaining backward compatibility and documenting expected inputs/outputs.
  • Document containers: Use Dockerfile comments, labels, and metadata to provide usage instructions and maintainability information.
  • Leverage orchestration: Use Kubernetes features like Deployments, Services, ConfigMaps, and Jobs to automate and manage distributed patterns effectively.

12. What are some of the best quotes from "Designing Distributed Systems" by Brendan Burns, and what do they mean?

  • “Patterns are the basis for the definition and development of such reusable components.”
    This highlights the central thesis that formalizing patterns enables the creation of shared, modular building blocks for distributed systems.
  • “Distributed system design continues to be more of a black art practiced by wizards than a science applied by laypeople.”
    Burns points out the historical complexity of distributed systems and the need for standardization and democratization through patterns.
  • “Standing on the shoulders of giants.”
    The book encourages learning from established best practices and the experiences of others, rather than reinventing solutions.
  • “Containers are the foundational building block for the patterns in this book.”
    This underscores the importance of containers in enabling modularity, reuse, and automation in modern distributed system design.
  • “The identification of common patterns and practices has regularized and improved the practice of algorithmic development and object-oriented programming. It is this book’s goal to do the same for distributed systems.”
    Burns draws a parallel between the evolution of programming paradigms and the current need for standardized distributed system patterns.

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

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

Follow
گوش دادن
Now playing
طراحی سیستم‌های توزیع‌شده
0:00
-0:00
Now playing
طراحی سیستم‌های توزیع‌شده
0:00
-0:00
1x
Queue
Home
Swipe
Library
Get App
Try Full Access for 3 Days
Listen, bookmark, and more
Compare Features Free Pro
📖 Read Summaries
Read unlimited summaries. Free users get 3 per month
🎧 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
امروز: دسترسی فوری
گوش دادن به خلاصه کامل بیش از ۲۶,۰۰۰ کتاب. بیش از ۱۲,۰۰۰ ساعت محتوای صوتی!
روز دوم: یادآوری دوره آزمایشی
به شما اطلاع می‌دهیم که دوره آزمایشی‌تان به‌زودی پایان می‌یابد.
روز سوم: شروع اشتراک شما
مبلغ اشتراک در تاریخ Jun 13,
کسر می‌شود. هر زمان قبل از آن می‌توانید لغو کنید.
Consume 2.8× More Books
2.8× more books Listening Reading
Our users love us
600,000+ readers
Trustpilot Rating
TrustPilot
4.6 Excellent
This site is a total game-changer. I've been flying through book summaries like never before. Highly, highly recommend.
— Dave G
Worth my money and time, and really well made. I've never seen this quality of summaries on other websites. Very helpful!
— Em
Highly recommended!! Fantastic service. Perfect for those that want a little more than a teaser but not all the intricate details of a full audio book.
— Greg M
Save 62%
Yearly
$119.88 $44.99/year/yr
$3.75/mo
Monthly
$9.99/mo
Start a 3-Day Free Trial
3 days free, then $44.99/year. Cancel anytime.
Unlock a world of fiction & nonfiction books
26,000+ books for the price of 2 books
Read any book in 10 minutes
Discover new books like Tinder
Request any book if it's not summarized
Read more books than anyone you know
#1 app for book lovers
Lifelike & immersive summaries
30-day money-back guarantee
Download summaries in EPUBs or PDFs
Cancel anytime in a few clicks
Scanner
Find a barcode to scan

We have a special gift for you
Open
38% OFF
DISCOUNT FOR YOU
$79.99
$49.99/year
only $4.16 per month
Continue
2 taps to start, super easy to cancel
Settings
General
Widget
Loading...
We have a special gift for you
Open
38% OFF
DISCOUNT FOR YOU
$79.99
$49.99/year
only $4.16 per month
Continue
2 taps to start, super easy to cancel