SALE ON NOW! PROMOTIONS

Close Notification

Your cart does not contain any items

System Design Guide for Software Professionals

Build scalable solutions – from fundamental concepts to cracking top tech company interviews...

Dhirendra Sinha Tejas Chopra

$79.95   $68.29

Paperback

Not in-store but you can order this
How long will it take?

QTY:

English
Packt Publishing Limited
23 August 2024
Enhance your system design skills to build scalable and efficient systems by working through real-world case studies and expert strategies to excel in interviews

Key Features

Comprehensive coverage of distributed systems concepts and practical system design techniques. Insider tips and proven strategies from engineering leaders at top tech companies. Detailed case studies of widely used applications and their system architectures. Purchase of the print or Kindle book includes a free PDF eBook

Book DescriptionBuilding scalable software systems is more critical than ever. Yet, many software professionals struggle to navigate the complexities of system design, especially when aiming for positions at top tech companies. Written by Dhirendra Sinha, a seasoned Engineering Leader at Google with a blend of experience working at large companies such as Cisco, Oracle, and Yahoo, and Tejas Chopra, a Senior Software Engineer at Netflix, a TEDx speaker, and a Co-Founder of GoEB1, this comprehensive and authoritative resource on system design offers invaluable insights and strategies to help you excel in interviews with all major tech companies.

This guide covers the basics of system design, including the principles and techniques of distributed systems, and delves into core building blocks such as distributed system theorems, attributes, and the design and implementation of system components. Following examples of popular applications such as Uber, Twitter, Instagram, Google Docs, and Netflix, you’ll learn how to apply concepts to real-world scenarios. The book offers expert advice and strategies for preparing and acing system design interviews, along with a mind map/cheat sheet summarizing the key takeaways.

By the end of this book, you’ll be equipped with unique techniques and the confidence to solve any coding interview question.

What you will learn

Design for scalability and efficiency with expert insights Apply distributed system theorems and attributes Implement DNS, databases, caches, queues, and APIs Analyze case studies of real-world systems Discover tips to excel in system design interviews with confidence Apply industry-standard methodologies for system design and evaluation Explore the architecture and operation of cloud-based systems

Who this book is forThis book is a must-have resource for experienced software professionals, particularly those with 5-15 years of experience in building scalable distributed systems, web applications, and backend microservices. Whether you're a seasoned developer or an architect looking to deepen your expertise in system design, this book provides the insights and practical knowledge you need to excel in tech interviews and advance your career. A solid foundation in distributed systems, data structures/algorithms, and web development will help you get the most out of this comprehensive guide.
By:   ,
Imprint:   Packt Publishing Limited
Country of Publication:   United Kingdom
Dimensions:   Height: 235mm,  Width: 191mm, 
ISBN:   9781805124993
ISBN 10:   1805124994
Pages:   384
Publication Date:  
Audience:   General/trade ,  ELT Advanced
Format:   Paperback
Publisher's Status:   Active
Table of Contents Basics of System Design Distributed Systems Theorems Distributed Systems Attributes Design and Implementation of System Components: DNS & Load Balancers Design and Implementation of System Components: Databases and Storage Caching Pub/Sub & Distributed Queues Design and Implementation of System Components: API, Security, Metrics Designing URL Shortener Designing Uber Design Twitter Design Instagram Design Google Docs Design Netflix System Design Interview Tips for interviewee Expert opinions

Dhirendra Sinha is a Software Engineering Manager at Google. He is an angel investor and has served as a Strategic and Technology advisor at a few startups. Dhirendra has around two decades of experience in the Software Engineering field building highly scalable complex distributed systems and managing multiple Engineering teams. While he has experience in working at large companies such as Cisco, Oracle, Yahoo, and Google, he has also been involved with early and late-stage startups in leadership positions. In addition to his strong Software Engineering experience, he has been teaching the Distributed System Design course for the last seven years. He has also been coaching and mentoring Software Engineers and Software Engineering Managers for over a decade. He completed his Bachelor of Technology degree from IIT Guwahati and Master of Science from Texas A and M University, College Station, Texas. Tejas Chopra is a Senior Engineer at Netflix working on building the Machine Learning Platform powering Netflix recommendations and personalization. He is also a Co-founder at GoEB1, which is the world's first thought leadership platform for immigrants. Tejas is a recipient of the prestigious EB1A (Einstein) visa in the US. He is a Tech 40 under 40 Award winner, a 2xTEDx speaker, a British Computer Society (BCS) Fellow, and has spoken at conferences and panels on Cloud Computing, Blockchain, Machine Learning, Software Development, and Engineering Leadership. Tejas has been awarded the “International Achievers Award, 2023” by the Indian Achievers' Forum. He is an Adjunct Professor of Software Development at the University of Advancing Technology, Arizona, an Angel Investor, and has previously been an Advisor to startups such as Nillion, Inc. He is also a member of the Advisory Board for Future of Memory and Storage Summit. Tejas' experience has been in companies such as Box, Apple, Samsung, Cadence, and Datrium. Tejas holds a Masters Degree in Electrical and Computer Engineering from Carnegie Mellon University, Pittsburgh.

See Also