{"id":21445832,"url":"https://github.com/developer-sujon/system-design-101","last_synced_at":"2026-02-03T20:05:43.697Z","repository":{"id":221145419,"uuid":"663165411","full_name":"developer-sujon/system-design-101","owner":"developer-sujon","description":null,"archived":false,"fork":false,"pushed_at":"2023-07-06T17:44:58.000Z","size":3378,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"main","last_synced_at":"2025-03-17T01:23:20.743Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":null,"language":null,"has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/developer-sujon.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":"CONTRIBUTING.md","funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null}},"created_at":"2023-07-06T17:44:18.000Z","updated_at":"2024-03-29T11:25:54.000Z","dependencies_parsed_at":"2024-02-06T13:57:25.250Z","dependency_job_id":null,"html_url":"https://github.com/developer-sujon/system-design-101","commit_stats":null,"previous_names":["developer-sujon/system-design-bangla-master","developer-sujon/system-design-101"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/developer-sujon/system-design-101","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/developer-sujon%2Fsystem-design-101","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/developer-sujon%2Fsystem-design-101/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/developer-sujon%2Fsystem-design-101/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/developer-sujon%2Fsystem-design-101/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/developer-sujon","download_url":"https://codeload.github.com/developer-sujon/system-design-101/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/developer-sujon%2Fsystem-design-101/sbom","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":265257787,"owners_count":23735806,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":[],"created_at":"2024-11-23T02:39:11.490Z","updated_at":"2026-02-03T20:05:38.664Z","avatar_url":"https://github.com/developer-sujon.png","language":null,"funding_links":[],"categories":[],"sub_categories":[],"readme":"# সিস্টেম ডিজাইন বাংলা\n\nএটি একটি রিপোজিটরি যেখানে সিস্টেম ডিজাইন এর মৌলিক জিনিসগুলো নিয়ে আলোচনা করা হয়েছে।\n\n[এই টিউটোরিয়াল এর উদ্দেশ্য আপনাকে মৌলিক জিনিসগুলোর ধারণা দেয়া]\n\n\u003cp align=\"center\"\u003e\n  \u003cimg src=\"./images/system-design-wallpaper.png\" alt=\"System Design Wallpaper\"\u003e\n\u003c/p\u003e\n\n### সুচিপত্র\n\n- [Section 1: System Design](#section-1-system-design)\n- [Section 2: Database - SQL and NoSQL]\n- [Section 3: Client Server Architecture](#section-3-client-server-architecture)\n- [Section 4: Reliability](#section-4-reliability)\n- [Section 5: Performance Metrics](#section-5-performance-metrics)\n- [Section 6: Distributed System](#section-6-distributed-system)\n- [Section 7: Domain Name System](#section-7-domain-name-system)\n- [Section 8: Proxy](#section-8-proxy)\n- [Section 9: REST API](#section-9-rest-api)\n- [Section 10: Scalability](#section-10-scalability)\n- [Section 11: Sharding](#section-11-sharding)\n- [Section 12: Database Replication](#section-12-database-replication)\n- [Section 13: Caching](#section-13-caching)\n- [Section 14: Content Delivery Network]\n- [Section 15: Consistent Hashing]\n- [Section 16: CAP Theorem]\n- [Section 17: Message Queue]\n- [Section 18: Design a Rate Limiter]\n- [Section 19: Design a Chat System]\n- [Section 20: Design a Notification System]\n- [Section 21: Resources](#section-21-resources)\n\n## Section 1: System Design\n\nআমরা যখন কোন এপ্লিকেশন ডেভেলপ করতে যাই আমাদের একটি নির্দিষ্ট প্রকারের ডিজাইন মেনে চলতে হয়, তার কারণ হল আমাদের এপ্লিকেশনে কোন এক সময় থেকে যদি প্রচুর মানুষ ব্যবহার করা শুরু করতে থাকে, তখন আমাদের এপ্লিকেশন যাতে প্রচুর লোড ভালোভাবে নিতে পারে কোন প্রকারের কানেকশন নষ্ট বা পারফরমেন্স ডাউন হওয়া ছাড়া সেজন্য। সেই ডিজাইন কে বলা হয় সিস্টেম ডিজাইন।\n\n(এই স্পেসিফিক সিস্টেম ডিজাইন মূলত ব্যাকএন্ড ইঞ্জিনিয়ারিং এর সাথে সম্পৃক্ত।)\n\n## Section 3: Client Server Architecture\n\nক্লায়েন্ট রিকুয়েস্ট করবে সার্ভারকে কিছু স্পেসিকিফ রিসোর্স এর জন্য, সার্ভার সেই রিকুয়েস্ট পাওয়ার পর সে তার যাবতীয় প্রসেস শেষ করে ক্লায়েন্টকে রেসপন্স দিয়ে দিবে, এটি ক্লায়েন্ট সার্ভার আর্কিটেকচার।\n\n\u003cp align=\"center\"\u003e\n  \u003cimg src=\"./images/csa.png\" alt=\"Client Server Architecture\"\u003e\n\u003c/p\u003e\n\nআমাদের সব উদাহরণ থাকবে ক্লায়েন্ট সার্ভার আর্কিটেকচারের উপর ভিত্তি করে।\n\n## Section 4: Reliability\n\nসিস্টেম যদি কোনো প্রকারের Fault/Error থাকার পরও ভালোভাবে কাজ করতে পারে কিংবা সিস্টেমটি যদি বন্ধ না হয়, তবে সেই সিস্টেমটি Reliable। আমাদের মনে রাখতে হবে এক বা একাধিক Fault এর কারণে সিস্টেম Failure হতে পারে।\n\nFault এরকম হতে পারে কোনো user সিস্টেমটি কে এমনভাবে ব্যবহার করেছে যাতে কোনো Failure হয়ে গেল, সেটা ইচ্ছাকৃত বা অনিচ্ছাকৃতভাবেও হতে পারে, তখন যদি সিস্টেমটি বন্ধ না হয়ে কোনো প্রকারের Warning message দেখালো তখন সেই সিস্টেমটিকে আমরা Reliable বলতে পারি।\n\n🔗 [**আরও পড়ুন: রিলাইবিলিটি**](./sections/reliability/README.md)\n\n## Section 5: Performance Metrics\n\n### Throughput\n\nএকটি নির্দিষ্ট সময়ের ভিত্তিতে কোনো সিস্টেম যতটুকু কাজ সম্পাদন করতে পারে সেটি হচ্ছে Throughput। যেমন, প্রতি ১০ সেকেন্ড এ সিস্টেম যদি ৫০ টি API request সম্পন্ন করতে পারে তাহলে তার Throughput হবে ৫০/১০ = ৫।\n\n### Time to First Byte\n\nক্লায়েন্ট Resource জন্য যখন সার্ভারকে Request করে এবং ক্লায়েন্ট সার্ভার থেকে FIRST BYTE of Response যখন গ্রহণ করে তার মধ্যকার সময়টুকু (Request করা থেকে শুরু করে এবং FIRST BYTE গ্রহণ করার সময় পর্যন্ত) হল Time to First Byte।\n\n🔗 [**আরও পড়ুন: পারফরম্যান্স ম্যাট্রিক্স**](./sections/performance-metrics/README.md)\n\n## Section 6: Distributed System\n\nএকাধিক কম্পিউটার (বা কম্পোনেন্ট) একসাথে কাজ করার ফলে কোন কাজ শেষ হয় এবং End User এর কাছে একটি কম্পিউটার (বা কম্পোনেন্ট) হিসেবে আসে, সেই সিস্টেমটি হল ডিস্ট্রিবিউটেড সিস্টেম। এই মেশিনগুলোতে শেয়ার্ড স্টেট(Shared State) থাকে, কঙ্কারেন্টলি (Concurrently) কাজ করতে পারে, প্রতিটি সিস্টেম একে অপরের সাথে Information শেয়ার করতে পারবে।\n\nবর্তমান সময়ে Distributed System এর উদাহরণ হল YouTube।\n\nYouTube কেন?\n\n- সার্ভার User থেকে রিকুয়েস্ট পায় Video Upload কিংবা Video Watch করার জন্য।\n- ভিডিও এনকোড।\n- ডাটাবেস সিস্টেম।\n\nএগুলো সবকিছু মিলে Distributed System YouTube তৈরি করে।\n\n## Section 7: Domain Name System\n\nDomain Name System কিংবা DNS একটি নির্দিষ্ট Human Readable Domain (যেমন www.google.com) কে একটি নির্দিষ্ট IP-তে রূপান্তর করে।\nএই রূপান্তর করার পদ্ধতিটা শুরু হয় DNS Resolver দিয়ে,\n\n- DNS Resolver মূলত Human Readable Domain কে নির্দিষ্ট IP-তে রূপান্তর করে থাকে। এর ৩টি পার্ট আছে,\n  - Root Server, এই সার্ভার মূলত .com, .org, .net ইত্যাদির তথ্য রাখে এবং সেগুলোর IP সেই DNS Resolver কে দিয়ে থাকে যেমন .com এর জন্য .com এর IP, .org এর জন্য .org এর IP\n  - Top Level Domain Server, এই সার্ভার মূলত প্রতিটি Top Level Domain (www.google.com এর TLD হল .com) এর Authorititve Server এর তথ্য নিজের মধ্যে রাখে।\n  - Authorititve Server, এই সার্ভারের মধ্যে সেই Human Readable Domain (যেমন www.google.com) এর IP পাওয়া যায়।\n\n\u003cp align=\"center\"\u003e\n  \u003cimg src=\"./images/dns.png\" alt=\"DNS\"\u003e\n\u003c/p\u003e\n\n## Section 8: Proxy\n\nক্লায়েন্ট যখন সার্ভারকে রিকুয়েস্ট পাঠানোর সময় সরাসরি সার্ভারকে রিকুয়েস্ট না করে অন্য একটি সার্ভাররের মাধ্যমে রিকুয়েস্ট করলে, সেই প্রসেস হচ্ছে প্রক্সি এবং যে সার্ভার দিয়ে রিকুয়েস্ট করবে সেটা হচ্ছে প্রক্সি সার্ভার।\n\nবাস্তব জীবনে প্রক্সির একটি উদাহরণ হচ্ছে NGINX।\n\n🔗 [**আরও পড়ুন: প্রক্সি**](./sections/proxy/README.md)\n\n## Section 9: REST Api\n\nরেস্ট এপিআই বুঝার পূর্বে আমাদের বুঝতে হবে রেস্ট(REST) মানে কি, REST মানে হল Representational State Transfer যার মানে দাড়ায় এটি একটি আর্কিটেকচারাল স্টাইল যা ব্যবহার করা হয় স্টেট ট্রান্সফার এর জন্য। এখন REST Api হল, এক প্রকারের এপিআই কনভেনশন যা ব্যবহার করা হয় দুটি এন্ড(যেমনঃ ক্লায়েন্ট এবং সার্ভার) এর মধ্যে স্টেট ট্রান্সফার করাকে নিশ্চিত করার জন্য।\n\nস্টেট ট্রান্সফার নিশ্চিত করতে কিছু স্পেসিফিক HTTP Methods ব্যবহার করা হয়, GET, POST, PUT, PATCH \u0026 DELETE, প্রতিটি ম্যাথোডের ব্যবহার জানতে REST Api সেকশনে ক্লিক করুন।\n\n🔗 [**আরও পড়ুন: রেস্ট এপিআই**](./sections/rest-api/README.md)\n\n## Section 10: Scalability\n\nস্কেলেবিলিটি সাধারণত সিস্টেমের ক্ষমতাকে বুঝায় যখন সিস্টেমে ট্রাফিকের পরিমাণ বাড়তে থাকে। উদাহরণ বলা যেতে পারে, একটি ওয়েবসাইটের ডাটাবেসে এখন একটি নির্দিষ্ট পরিমাণ রিকুয়েস্ট করা হচ্ছে কিন্তু আজ থেকে ৫ মাস পর রিকুয়েস্ট ২ গুণ হয়ে গেল তার ঠিক আরও ৫ মাস পর রিকুয়েস্ট ৪ গুণ হয়ে গেল, একটা সময় দেখা যেতে পারে ডাটাবেস সার্ভার এত পরিমাণ রিকুয়েস্ট লোড নিতে পারছে না, এই সমস্যার সমাধানের জন্য স্কেল করাকে স্কেলেবিলিটি বলে।\n\nস্কেলেবিলিটি সাধারণত 2 প্রকারের, ভার্টিকাল স্কেলেবিলিটি (Vertical Scalability) এবং হরাইজন্টাল স্কেলেবিলিটি (Horizontal Scalability)।\n\n🔗 [**আরও পড়ুন: স্কেলেবিলিটি**](./sections/scalability/README.md)\n\n## Section 11: Sharding\n\nHorizontal Scaling কে Sharding বলে। Sharding হল ডেটা পৃথক করা। উদাহরণ বলা যায়, ডাটাবেসের ডেটা যদি বাড়তে থাকে এবং এত পরিমাণ ডেটা Store করার ক্ষমতা যদি ডাটাবেসের না থাকে তখন আরও রিসোর্স (ডাটাবেসের সংখ্যা) বৃদ্ধি করে আমরা ডেটা পৃথক করে রাখি তাহলে সেটাই Sharding।\n\n(বিস্তারিত চলমান)\n\n\u003cp align=\"center\"\u003e\n  \u003cimg src=\"./images/sharding.png\" alt=\"Sharding\"\u003e\n\u003c/p\u003e\n\n## Section 12: Database Replication\n\nDatabase Replication এক প্রকারের Strategy, যেখানে একটি Master Database এবং একটি কিংবা একাধিক Slave Database থাকবে। Master Database এর মধ্যে Insert, Delete এবং Update এর কাজ হবে এবং Slave Database মধ্যে Master Database এর ডেটাগুলোর Copy থাকবে এবং তার মধ্যে শুধু Read Operation হবে।\n\n\u003cp align=\"center\"\u003e\n  \u003cimg src=\"./images/DB_replication.png\" alt=\"Database Replication\"\u003e\n\u003c/p\u003e\n\n🔗 [**আরও পড়ুন: ডেটাবেস রেপ্লিকেশন**](./sections/db_replication/README.md)\n\n## Section 13: Caching\n\nCaching একটি কৌশল যা দ্বারা কোন Expensive Response'কে কোনো মেমোরিতে রাখা হয়, যাতে বার বার আসা সেই রেস্পন্সের রিকোয়েস্ট কে দ্রুত রেসপন্সটি দিতে পারি। মূল সার্ভারে (যেমন ডাটাবেস) হিট করার পরিবর্তে ক্যাশিং সার্ভারে রিকোয়েস্ট করবে। এতে করে যে সুবিধাটুকু হবে,\n\n- Read API রিকোয়েস্ট Fast হবে\n- Latency Reduce হবে\n- Fault Tolarence এর ঝুঁকি কমবে\n\n\u003cp align=\"center\"\u003e\n  \u003cimg src=\"./images/caching1.png\" alt=\"Caching\"\u003e\n\u003c/p\u003e\n\n🔗 [**আরও পড়ুন: ক্যাশিং**](./sections/caching/README.md)\n\n## Section 21: Resources\n\n- \u003ca href=\"https://github.com/donnemartin/system-design-primer\" target=\"_blank\"\u003eSystem Design Primer by Donne Martin (free)\u003c/a\u003e\n- \u003ca href=\"https://www.amazon.com/Designing-Data-Intensive-Applications-Reliable-Maintainable/dp/1449373321\" target=\"_blank\"\u003eDesigning Data Intensive pplications (paid)\u003c/a\u003e\n- \u003ca href=\"amazon.com/System-Design-Interview-Insiders-Guide/dp/1736049119\" target=\"_blank\"\u003eSystem Design Interview by Alex Xu (paid)\u003c/a\u003e\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdeveloper-sujon%2Fsystem-design-101","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fdeveloper-sujon%2Fsystem-design-101","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdeveloper-sujon%2Fsystem-design-101/lists"}