system-design-primer/README-ta.md

245 KiB
Raw Blame History

English日本語 ∙ [简体中文](C ∙ 繁體中文 | العَرَبِيَّة‎বাংলাPortuguês do BrasilDeutschελληνικάעבריתItaliano한국어فارسیPolskiрусский языкEspañolภาษาไทยTürkçetiếng ViệtFrançais . Tamil | Add Translation

Help translate this guide!

The System Design Primer | சிஸ்டம் டிசைன் ப்ரைமர்


முயற்சி

பெரிய அளவிலான அமைப்புகளை எப்படி வடிவமைப்பது என்பதை அறிக.

கணினி வடிவமைப்பு நேர்காணலுக்கான தயாரிப்பு.

பெரிய அளவிலான அமைப்புகளை எப்படி வடிவமைப்பது என்பதை அறிக

அளவிடக்கூடிய அமைப்புகளை எவ்வாறு வடிவமைப்பது என்பதைக் கற்றுக்கொள்வது, சிறந்த பொறியாளராக மாற உதவும்.

கணினி வடிவமைப்பு ஒரு பரந்த தலைப்பு. கணினி வடிவமைப்பு கொள்கைகளில் இணையம் முழுவதும் பரந்த அளவிலான வளங்கள் உள்ளன.

இந்த ரெப்போ என்பது ஒரு ஒழுங்கமைக்கப்பட்ட சேகரிப்பு ஆகும்

திறந்த மூல சமூகத்திலிருந்து கற்றுக்கொள்ளுங்கள்

இது தொடர்ந்து புதுப்பிக்கப்பட்ட, திறந்த மூல திட்டமாகும்.

பங்களிப்புகள் வரவேற்கிறோம்!

கணினி வடிவமைப்பு நேர்காணலுக்கான தயாரிப்பு

குறியீட்டு நேர்காணல்களுடன் கூடுதலாக, கணினி வடிவமைப்பு என்பது பல தொழில்நுட்ப நிறுவனங்களில் தொழில்நுட்ப நேர்காணல் செயல்முறையின் தேவையான கூறு ஆகும்.

பொதுவான சிஸ்டம் வடிவமைப்பு நேர்காணல் கேள்விகளைப் பயிற்சி செய்யவும் மற்றும் **உங்கள் முடிவுகளை மாதிரி தீர்வுகளுடன் ஒப்பிடவும்: விவாதங்கள், குறியீடு மற்றும் வரைபடங்கள்.

நேர்முகத் தயாரிப்புக்கான கூடுதல் தலைப்புகள்:

அங்கி ஃபிளாஷ் கார்டுகள்


வழங்கப்பட்டுள்ள [Anki flashcard decks](https://apps.ankiweb.net/) முக்கிய சிஸ்டம் வடிவமைப்புக் கருத்துகளைத் தக்கவைக்க உங்களுக்கு உதவ, இடைவெளியில் திரும்பத் திரும்பப் பயன்படுத்துகிறது. * [System design deck](https://github.com/donnemartin/system-design-primer/tree/master/resources/flash_cards/System%20Design.apkg) * [System design exercises deck](https://github.com/donnemartin/system-design-primer/tree/master/resources/flash_cards/System%20Design%20Exercises.apkg) * [Object oriented design exercises deck](https://github.com/donnemartin/system-design-primer/tree/master/resources/flash_cards/OO%20Design.apkg)

பயணத்தின் போது பயன்படுத்த சிறந்தது.

குறியீட்டு ஆதாரம்: ஊடாடும் குறியீட்டு சவால்கள்

குறியீட்டு நேர்காணலுக்கு தயாராவதற்கு உங்களுக்கு உதவ ஆதாரங்களைத் தேடுகிறீர்களா?


சகோதரி ரெப்போவைப் பாருங்கள் [**ஊடாடும் குறியீட்டு சவால்கள்**](https://github.com/donnemartin/interactive-coding-challenges), இதில் கூடுதல் Anki டெக் உள்ளது: . [Coding deck](https://github.com/donnemartin/interactive-coding-challenges/tree/master/anki_cards/Coding.apkg) ## பங்களிக்கிறது > சமூகத்திலிருந்து கற்றுக்கொள்ளுங்கள்.

உதவிக்கு இழுக்கும் கோரிக்கைகளைச் சமர்ப்பிக்க தயங்க வேண்டாம்:

  • பிழைகளை சரிசெய்யவும்
  • பிரிவுகளை மேம்படுத்தவும்
  • புதிய பிரிவுகளைச் சேர்க்கவும்
  • Translate சில மெருகூட்டல் தேவைப்படும் உள்ளடக்கம் [வளர்ச்சியில்] (#குறை வளர்ச்சி) வைக்கப்படுகிறது.

[பங்களிப்பு வழிகாட்டுதல்கள்] மதிப்பாய்வு செய்யவும்(CONTRIBUTING.md).

Index of system design topics

Summaries of various system design topics, including pros and cons. Everything is a trade-off.

Each section contains links to more in-depth resources.


* [System design topics: start here](#system-design-topics-start-here) * [Step 1: Review the scalability video lecture](#step-1-review-the-scalability-video-lecture) * [Step 2: Review the scalability article](#step-2-review-the-scalability-article) * [Next steps](#next-steps) * [Performance vs scalability](#performance-vs-scalability) * [Latency vs throughput](#latency-vs-throughput) * [Availability vs consistency](#availability-vs-consistency) * [CAP theorem](#cap-theorem) * [CP - consistency and partition tolerance](#cp---consistency-and-partition-tolerance) * [AP - availability and partition tolerance](#ap---availability-and-partition-tolerance) * [Consistency patterns](#consistency-patterns) * [Weak consistency](#weak-consistency) * [Eventual consistency](#eventual-consistency) * [Strong consistency](#strong-consistency) * [Availability patterns](#availability-patterns) * [Fail-over](#fail-over) * [Replication](#replication) * [Availability in numbers](#availability-in-numbers) * [Domain name system](#domain-name-system) * [Content delivery network](#content-delivery-network) * [Push CDNs](#push-cdns) * [Pull CDNs](#pull-cdns) * [Load balancer](#load-balancer) * [Active-passive](#active-passive) * [Active-active](#active-active) * [Layer 4 load balancing](#layer-4-load-balancing) * [Layer 7 load balancing](#layer-7-load-balancing) * [Horizontal scaling](#horizontal-scaling) * [Reverse proxy (web server)](#reverse-proxy-web-server) * [Load balancer vs reverse proxy](#load-balancer-vs-reverse-proxy) * [Application layer](#application-layer) * [Microservices](#microservices) * [Service discovery](#service-discovery) * [Database](#database) * [Relational database management system (RDBMS)](#relational-database-management-system-rdbms) * [Master-slave replication](#master-slave-replication) * [Master-master replication](#master-master-replication) * [Federation](#federation) * [Sharding](#sharding) * [Denormalization](#denormalization) * [SQL tuning](#sql-tuning) * [NoSQL](#nosql) * [Key-value store](#key-value-store) * [Document store](#document-store) * [Wide column store](#wide-column-store) * [Graph Database](#graph-database) * [SQL or NoSQL](#sql-or-nosql) * [Cache](#cache) * [Client caching](#client-caching) * [CDN caching](#cdn-caching) * [Web server caching](#web-server-caching) * [Database caching](#database-caching) * [Application caching](#application-caching) * [Caching at the database query level](#caching-at-the-database-query-level) * [Caching at the object level](#caching-at-the-object-level) * [When to update the cache](#when-to-update-the-cache) * [Cache-aside](#cache-aside) * [Write-through](#write-through) * [Write-behind (write-back)](#write-behind-write-back) * [Refresh-ahead](#refresh-ahead) * [Asynchronism](#asynchronism) * [Message queues](#message-queues) * [Task queues](#task-queues) * [Back pressure](#back-pressure) * [Communication](#communication) * [Transmission control protocol (TCP)](#transmission-control-protocol-tcp) * [User datagram protocol (UDP)](#user-datagram-protocol-udp) * [Remote procedure call (RPC)](#remote-procedure-call-rpc) * [Representational state transfer (REST)](#representational-state-transfer-rest) * [Security](#security) * [Appendix](#appendix) * [Powers of two table](#powers-of-two-table) * [Latency numbers every programmer should know](#latency-numbers-every-programmer-should-know) * [Additional system design interview questions](#additional-system-design-interview-questions) * [Real world architectures](#real-world-architectures) * [Company architectures](#company-architectures) * [Company engineering blogs](#company-engineering-blogs) * [Under development](#under-development) * [Credits](#credits) * [Contact info](#contact-info) * [License](#license) ## கல்வி வழிகாட்டி > உங்கள் நேர்காணல் காலவரிசையின் (குறுகிய, நடுத்தர, நீண்ட) அடிப்படையில் மதிப்பாய்வு செய்ய பரிந்துரைக்கப்பட்ட தலைப்புகள். > ![Imgur](images/OfVllex.png) > **கே: நேர்காணல்களுக்கு, நான் இங்கே அனைத்தையும் தெரிந்து கொள்ள வேண்டுமா?**

ப: இல்லை, நேர்காணலுக்குத் தயாராவதற்கு நீங்கள் இங்கே அனைத்தையும் தெரிந்து கொள்ள வேண்டியதில்லை. ஒரு நேர்காணலில் உங்களிடம் கேட்கப்படுவது போன்ற மாறிகளைப் பொறுத்தது:

  • உங்களுக்கு எவ்வளவு அனுபவம் இருக்கிறது
  • உங்கள் தொழில்நுட்ப பின்னணி என்ன
  • எந்தெந்த பதவிகளுக்கு நேர்காணல் செய்கிறீர்கள்
  • எந்தெந்த நிறுவனங்களுடன் நேர்காணல் செய்கிறீர்கள்
  • அதிர்ஷ்டம்

அதிக அனுபவம் வாய்ந்த விண்ணப்பதாரர்கள் பொதுவாக கணினி வடிவமைப்பைப் பற்றி மேலும் அறிந்து கொள்வார்கள் என்று எதிர்பார்க்கப்படுகிறது. தனிப்பட்ட பங்களிப்பாளர்களை விட கட்டிடக் கலைஞர்கள் அல்லது குழுத் தலைவர்கள் அதிகம் அறிந்திருப்பார்கள் என்று எதிர்பார்க்கலாம். சிறந்த தொழில்நுட்ப நிறுவனங்கள் ஒன்று அல்லது அதற்கு மேற்பட்ட வடிவமைப்பு நேர்காணல் சுற்றுகளைக் கொண்டிருக்கும்.

அகலமாகத் தொடங்கி ஒரு சில பகுதிகளில் ஆழமாகச் செல்லவும். பல்வேறு முக்கிய கணினி வடிவமைப்பு தலைப்புகளைப் பற்றி கொஞ்சம் தெரிந்துகொள்ள இது உதவுகிறது. உங்கள் காலக்கெடு, அனுபவம், எந்தெந்த பதவிகளுக்கு நேர்காணல் செய்கிறீர்கள், எந்தெந்த நிறுவனங்களுடன் நேர்காணல் செய்கிறீர்கள் என்பதன் அடிப்படையில் பின்வரும் வழிகாட்டியைச் சரிசெய்யவும்.

  • குறுகிய காலவரிசை - கணினி வடிவமைப்பு தலைப்புகளுடன் அகலம்க்கான நோக்கம். சில நேர்காணல் கேள்விகளைத் தீர்ப்பதன் மூலம் பயிற்சி செய்யுங்கள்.
  • நடுத்தர காலவரிசை - கணினி வடிவமைப்பு தலைப்புகளுடன் அகலம் மற்றும் சிறிது ஆழம் ஆகியவற்றை நோக்கமாகக் கொண்டது. பல நேர்காணல் கேள்விகளைத் தீர்ப்பதன் மூலம் பயிற்சி செய்யுங்கள்.
  • நீண்ட காலவரிசை - கணினி வடிவமைப்பு தலைப்புகளுடன் அகலம் மற்றும் அதிக ஆழம். பெரும்பாலான நேர்காணல் கேள்விகளைத் தீர்ப்பதன் மூலம் பயிற்சி செய்யுங்கள்.
குறுகிய நடுத்தர நீண்ட
கணினிகள் எவ்வாறு செயல்படுகின்றன என்பதைப் பற்றிய விரிவான புரிதலைப் பெற கணினி வடிவமைப்பு தலைப்புகள் மூலம் படிக்கவும் 👍 👍 👍
நீங்கள் நேர்காணல் செய்யும் நிறுவனங்களுக்கான கம்பெனி இன்ஜினியரிங் வலைப்பதிவுகளில் சில கட்டுரைகளைப் படிக்கவும் 👍 👍 👍
சில உண்மையான உலக கட்டிடக்கலை மூலம் படிக்கவும் 👍 👍 👍
மதிப்பாய்வு கணினி வடிவமைப்பு நேர்காணல் கேள்வியை எப்படி அணுகுவது 👍 👍 👍
[கணினி வடிவமைப்பு நேர்காணல் கேள்விகள் தீர்வுகளுடன்] (#system-design-interview-quesions-with-solutions) மூலம் வேலை செய்யுங்கள் சில பல பெரும்பாலான
[பொருள் சார்ந்த வடிவமைப்பு நேர்காணல் கேள்விகள் தீர்வுகளுடன்] (#பொருள் சார்ந்த வடிவமைப்பு-நேர்காணல்-கேள்விகள்-தீர்வுகளுடன்) சில பல பெரும்பாலான
மதிப்பாய்வு கூடுதல் கணினி வடிவமைப்பு நேர்காணல் கேள்விகள் சில பல பெரும்பாலான

கணினி வடிவமைப்பு நேர்காணல் கேள்வியை எவ்வாறு அணுகுவது

கணினி வடிவமைப்பு நேர்காணல் கேள்வியை எவ்வாறு சமாளிப்பது.

கணினி வடிவமைப்பு நேர்காணல் ஒரு திறந்த உரையாடலாகும். நீங்கள் அதை வழிநடத்துவீர்கள் என்று எதிர்பார்க்கப்படுகிறது.

விவாதத்தை வழிநடத்த பின்வரும் படிகளைப் பயன்படுத்தலாம். இந்த செயல்முறையை உறுதிப்படுத்த உதவ, பின்வரும் படிகளைப் பயன்படுத்தி கணினி வடிவமைப்பு நேர்காணல் கேள்விகள் தீர்வுகளுடன் பிரிவின் மூலம் வேலை செய்யுங்கள்.

படி 1: பயன்பாட்டு வழக்குகள், கட்டுப்பாடுகள் மற்றும் அனுமானங்களை கோடிட்டுக் காட்டுங்கள்

தேவைகளைச் சேகரித்து சிக்கலைக் கண்டறியவும். பயன்பாட்டு வழக்குகள் மற்றும் தடைகளைத் தெளிவுபடுத்த கேள்விகளைக் கேளுங்கள். அனுமானங்களைப் பற்றி விவாதிக்கவும்.

  • அதைப் பயன்படுத்தப் போவது யார்?
  • அதை எப்படிப் பயன்படுத்தப் போகிறார்கள்?
  • எத்தனை பயனர்கள் உள்ளனர்?
  • அமைப்பு என்ன செய்கிறது?
  • கணினியின் உள்ளீடுகள் மற்றும் வெளியீடுகள் என்ன?
  • எவ்வளவு டேட்டாவை கையாள வேண்டும் என்று எதிர்பார்க்கிறோம்?
  • ஒரு வினாடிக்கு எத்தனை கோரிக்கைகளை எதிர்பார்க்கிறோம்? *எதிர்பார்க்கும் படிக்கும் எழுத்து விகிதம் என்ன?

படி 2: உயர்நிலை வடிவமைப்பை உருவாக்கவும்

அனைத்து முக்கிய கூறுகளுடன் உயர் மட்ட வடிவமைப்பை கோடிட்டுக் காட்டுங்கள்.

  • முக்கிய கூறுகள் மற்றும் இணைப்புகளை வரையவும்
  • உங்கள் எண்ணங்களை நியாயப்படுத்துங்கள்

படி 3: முக்கிய கூறுகளை வடிவமைக்கவும்

ஒவ்வொரு முக்கிய கூறுகளின் விவரங்களுக்கு முழுக்கு. எடுத்துக்காட்டாக, நீங்கள் URL சுருக்குதல் சேவையை வடிவமைக்க கேட்கப்பட்டால், விவாதிக்கவும்:

  • முழு url இன் ஹாஷை உருவாக்குதல் மற்றும் சேமித்தல்
    • MD5 மற்றும் Base62
    • ஹாஷ் மோதல்கள்
    • SQL அல்லது NoSQL
    • தரவுத்தளத் திட்டம்
  • ஹாஷ் செய்யப்பட்ட urlஐ முழு urlக்கு மொழிபெயர்த்தல்
    • தரவுத்தள தேடல்
  • API மற்றும் பொருள் சார்ந்த வடிவமைப்பு

படி 4: வடிவமைப்பை அளவிடவும்

தடைகளைக் கண்டறிந்து, தடைகளுக்கு தீர்வு காணவும். எடுத்துக்காட்டாக, அளவிடுதல் சிக்கல்களைத் தீர்க்க உங்களுக்கு பின்வருபவை தேவையா?

  • லோட் பேலன்சர்
  • கிடைமட்ட அளவிடுதல்
  • கேச்சிங்
  • தரவுத்தள பகிர்வு

சாத்தியமான தீர்வுகள் மற்றும் வர்த்தக பரிமாற்றங்களைப் பற்றி விவாதிக்கவும். எல்லாமே வியாபாரம்தான். [அளவிடக்கூடிய கணினி வடிவமைப்பின் கோட்பாடுகள்] (#அமைப்பு-வடிவமைப்பு-தலைப்புகளின் குறியீட்டு) பயன்படுத்தி இடையூறுகளைச் சரிசெய்யவும்.

உறையின் பின் கணக்கீடுகள்

கையால் சில மதிப்பீடுகளைச் செய்யும்படி நீங்கள் கேட்கப்படலாம். பின்வரும் ஆதாரங்களுக்கு [இணைப்பு](#பின் இணைப்பு) பார்க்கவும்:

ஆதாரம்(கள்) மற்றும் மேலதிக வாசிப்பு

என்ன எதிர்பார்க்கலாம் என்பது பற்றிய சிறந்த யோசனையைப் பெற பின்வரும் இணைப்புகளைப் பார்க்கவும்:

தீர்வுகளுடன் கூடிய சிஸ்டம் டிசைன் நேர்காணல் கேள்விகள்

மாதிரி விவாதங்கள், குறியீடு மற்றும் வரைபடங்களுடன் பொதுவான கணினி வடிவமைப்பு நேர்காணல் கேள்விகள்.

solutions/ கோப்புறையில் உள்ள உள்ளடக்கத்துடன் தீர்வுகள் இணைக்கப்பட்டுள்ளன.

கேள்வி
வடிவமைப்பு Pastebin.com (அல்லது Bit.ly) தீர்வு
Twitter டைம்லைனை வடிவமைத்து தேடவும் (அல்லது Facebook ஊட்டம் மற்றும் தேடல்) தீர்வு
ஒரு வலை கிராலர் வடிவமைப்பு தீர்வு
வடிவமைப்பு Mint.com தீர்வு
ஒரு சமூக வலைப்பின்னலுக்கான தரவு கட்டமைப்புகளை வடிவமைக்கவும் தீர்வு
ஒரு தேடுபொறிக்கான முக்கிய மதிப்பு கடையை வடிவமைத்தல் தீர்வு
வகை அம்சத்தின் அடிப்படையில் Amazon இன் விற்பனை தரவரிசையை வடிவமைக்கவும் தீர்வு
AWS இல் மில்லியன் கணக்கான பயனர்களை அளவிடும் ஒரு அமைப்பை வடிவமைக்கவும் தீர்வு
சிஸ்டம் டெஸைச் சேர்க்கவும்ign கேள்வி பங்களிக்கவும்

வடிவமைப்பு Pastebin.com (அல்லது Bit.ly)

உடற்பயிற்சி மற்றும் தீர்வைக் காண்க

இம்குர்

ட்விட்டர் காலவரிசையை வடிவமைத்து தேடுங்கள் (அல்லது Facebook ஊட்டம் மற்றும் தேடல்)

உடற்பயிற்சி மற்றும் தீர்வைக் காண்க

இம்குர்

வலை கிராலரை வடிவமைக்கவும்

உடற்பயிற்சி மற்றும் தீர்வைக் காண்க

இம்குர்

Design Mint.com

உடற்பயிற்சி மற்றும் தீர்வைக் காண்க

இம்குர்

ஒரு சமூக வலைப்பின்னலுக்கான தரவு கட்டமைப்புகளை வடிவமைக்கவும்

உடற்பயிற்சி மற்றும் தீர்வைக் காண்க

Imgur

ஒரு தேடுபொறிக்கான முக்கிய மதிப்பு கடையை வடிவமைக்கவும்

உடற்பயிற்சி மற்றும் தீர்வைக் காண்க

இம்குர்

அமேசானின் விற்பனை தரவரிசையை வகை அம்சத்தின்படி வடிவமைக்கவும்

உடற்பயிற்சி மற்றும் தீர்வைக் காண்க

இம்குர்

AWS இல் மில்லியன் கணக்கான பயனர்களை அளவிடும் ஒரு அமைப்பை வடிவமைக்கவும்

உடற்பயிற்சி மற்றும் தீர்வைக் காண்க

இம்குர்

பொருள் சார்ந்த வடிவமைப்பு நேர்காணல் கேள்விகள் தீர்வுகளுடன்

மாதிரி விவாதங்கள், குறியீடு மற்றும் வரைபடங்களுடன் பொதுவான பொருள் சார்ந்த வடிவமைப்பு நேர்காணல் கேள்விகள்.

solutions/ கோப்புறையில் உள்ள உள்ளடக்கத்துடன் தீர்வுகள் இணைக்கப்பட்டுள்ளன.

குறிப்பு: இந்தப் பிரிவு வளர்ச்சியில் உள்ளது

கேள்வி
ஹாஷ் வரைபடத்தை வடிவமைக்கவும் தீர்வு
குறைந்தது சமீபத்தில் பயன்படுத்தப்பட்ட தற்காலிக சேமிப்பை வடிவமைக்கவும் தீர்வு
ஒரு கால் சென்டரை வடிவமைக்கவும் தீர்வு
அட்டைகளின் தளத்தை வடிவமைக்கவும் தீர்வு
வாகன நிறுத்துமிடத்தை வடிவமைத்தல் தீர்வு
அரட்டை சேவையகத்தை வடிவமைக்கவும் தீர்வு
ஒரு வட்ட வரிசையை வடிவமைக்கவும் பங்களிக்கவும்
பொருள் சார்ந்த வடிவமைப்பு கேள்வியைச் சேர்க்கவும் பங்களிக்கவும்

கணினி வடிவமைப்பு தலைப்புகள்: இங்கே தொடங்கவும்

கணினி வடிவமைப்பில் புதியதா?

முதலில், பொதுவான கொள்கைகள், அவை என்ன, அவை எவ்வாறு பயன்படுத்தப்படுகின்றன, அவற்றின் நன்மை தீமைகள் ஆகியவற்றைப் பற்றிய அடிப்படை புரிதல் உங்களுக்குத் தேவைப்படும்.

படி 1: அளவிடுதல் வீடியோ விரிவுரையை மதிப்பாய்வு செய்யவும்

ஹார்வர்டில் அளவிடுதல் விரிவுரை

  • உள்ளடக்கப்பட்ட தலைப்புகள்:
    • செங்குத்து அளவிடுதல்
    • கிடைமட்ட அளவிடுதல்
    • கேச்சிங்
    • சுமை சமநிலை
    • தரவுத்தள நகல்
    • தரவுத்தள பகிர்வு

படி 2: அளவிடுதல் கட்டுரையை மதிப்பாய்வு செய்யவும்

அளவிடுதல்

அடுத்த படிகள்

அடுத்து, உயர்நிலை வர்த்தக பரிமாற்றங்களைப் பார்ப்போம்:

  • செயல்திறன் எதிராக ** அளவிடுதல்**
  • தாமதம் எதிராக த்ரூபுட்
  • கிடைக்கும் எதிராக நிலைத்தன்மை

எல்லாம் ஒரு பரிவர்த்தனை என்பதை நினைவில் கொள்ளுங்கள்.

பிறகு, DNS, CDNகள் மற்றும் லோட் பேலன்சர்கள் போன்ற இன்னும் குறிப்பிட்ட தலைப்புகளில் முழுக்கு போடுவோம்.

செயல்திறன் மற்றும் அளவிடுதல்

ஒரு சேவையானது அளவிடக்கூடியது அது அதிகரித்த செயல்திறன் ஆதாரங்களுக்கு விகிதாசாரமாக இருந்தால். பொதுவாக, செயல்திறனை அதிகரிப்பது என்பது அதிக வேலை அலகுகளுக்கு சேவை செய்வதாகும், ஆனால் தரவுத்தொகுப்புகள் வளரும்போது, ​​பெரிய அளவிலான வேலைகளைக் கையாளவும் முடியும்.1

செயல்திறன் மற்றும் அளவிடுதல் ஆகியவற்றைப் பார்க்க மற்றொரு வழி:

  • உங்களுக்கு செயல்திறன் சிக்கல் இருந்தால், உங்கள் கணினி ஒரு பயனருக்கு மெதுவாக இருக்கும். அளவிடுதல் சிக்கல் இருந்தால், உங்கள் கணினி ஒரு பயனருக்கு வேகமாக இருக்கும், ஆனால் அதிக சுமையின் கீழ் மெதுவாக இருக்கும்.

ஆதாரம்(கள்) மற்றும் மேலதிக வாசிப்பு

தாமதம் மற்றும் செயல்திறன்

தாமதம் என்பது சில செயல்களைச் செய்ய அல்லது சில முடிவுகளைத் தரும் நேரம்.

மூலம் என்பது ஒரு யூனிட் நேரத்திற்கு இதுபோன்ற செயல்கள் அல்லது முடிவுகளின் எண்ணிக்கை.

பொதுவாக, நீங்கள் அதிகபட்ச செயல்திறனை ஏற்றுக்கொள்ளக்கூடிய தாமதத்துடன் நோக்க வேண்டும்.

ஆதாரம்(கள்) மற்றும் மேலதிக வாசிப்பு

கிடைக்கும் தன்மை vs நிலைத்தன்மை

CAP தேற்றம்


ஆதாரம்: CAP தேற்றம் மறுபரிசீலனை செய்யப்பட்டது

விநியோகிக்கப்பட்ட கணினி அமைப்பில், பின்வரும் இரண்டு உத்தரவாதங்களை மட்டுமே நீங்கள் ஆதரிக்க முடியும்:

  • நிலைத்தன்மை - ஒவ்வொரு வாசிப்பும் மிக சமீபத்திய எழுத்து அல்லது பிழையைப் பெறுகிறது
  • கிடைக்கும் - ஒவ்வொரு கோரிக்கையும் பதிலைப் பெறுகிறது, அது தகவலின் சமீபத்திய பதிப்பைக் கொண்டுள்ளது என்பதற்கான உத்தரவாதம் இல்லாமல்
  • பகிர்வு சகிப்புத்தன்மை - நெட்வொர்க் தோல்விகள் காரணமாக தன்னிச்சையான பகிர்வு இருந்தாலும் கணினி தொடர்ந்து இயங்குகிறது

நெட்வொர்க்குகள் நம்பகமானவை அல்ல, எனவே நீங்கள் பகிர்வு சகிப்புத்தன்மையை ஆதரிக்க வேண்டும். நிலைத்தன்மைக்கும் கிடைக்கும் தன்மைக்கும் இடையே நீங்கள் மென்பொருள் பரிமாற்றத்தை மேற்கொள்ள வேண்டும்.

CP - நிலைத்தன்மை மற்றும் பகிர்வு சகிப்புத்தன்மை

பகிர்ந்த முனையிலிருந்து பதிலுக்காகக் காத்திருப்பது காலாவதி பிழையை ஏற்படுத்தக்கூடும். உங்கள் வணிகத் தேவைகளுக்கு அணு வாசிப்பு மற்றும் எழுதுதல் தேவைப்பட்டால் CP ஒரு நல்ல தேர்வாகும்.

AP - கிடைக்கும் தன்மை மற்றும் பகிர்வு சகிப்புத்தன்மை

பதில்கள் எந்த முனையிலும் கிடைக்கும் தரவின் மிக எளிதாகக் கிடைக்கும் பதிப்பை வழங்கும், இது சமீபத்தியதாக இருக்காது. பகிர்வு தீர்க்கப்படும் போது எழுதுதல்கள் பிரச்சாரம் செய்ய சிறிது நேரம் ஆகலாம்.

வணிகத் தேவைகள் [இறுதி நிலைத்தன்மை] (#இறுதி-நிலைத்தன்மை) அல்லது வெளிப்புறப் பிழைகள் இருந்தபோதிலும் கணினி தொடர்ந்து செயல்பட வேண்டும் எனில், AP ஒரு நல்ல தேர்வாகும்.

ஆதாரம்(கள்) மற்றும் மேலதிக வாசிப்பு

நிலைத்தன்மை வடிவங்கள்

ஒரே தரவின் பல நகல்களுடன், அவற்றை எவ்வாறு ஒத்திசைக்க வேண்டும் என்பதற்கான விருப்பங்களை நாங்கள் எதிர்கொள்கிறோம், அதனால் வாடிக்கையாளர்கள் தரவைப் பற்றிய நிலையான பார்வையைப் பெறுவார்கள். CAP தேற்றம் இலிருந்து நிலைத்தன்மையின் வரையறையை நினைவுபடுத்தவும் - ஒவ்வொரு வாசிப்பும் மிக சமீபத்திய எழுத்து அல்லது பிழையைப் பெறுகிறது.

பலவீனமான நிலைத்தன்மை

எழுதிய பிறகு, படித்தவர்கள் பார்க்கலாம் அல்லது பார்க்காமல் போகலாம். ஒரு சிறந்த முயற்சி அணுகுமுறை எடுக்கப்படுகிறது.

இந்த அணுகுமுறை memcached போன்ற அமைப்புகளில் காணப்படுகிறது. VoIP, வீடியோ அரட்டை மற்றும் நிகழ்நேர மல்டிபிளேயர் கேம்கள் போன்ற நிகழ்நேர பயன்பாட்டு நிகழ்வுகளில் பலவீனமான நிலைத்தன்மை நன்றாக வேலை செய்கிறது. எடுத்துக்காட்டாக, நீங்கள் ஒரு தொலைபேசி அழைப்பில் இருந்து சில நொடிகள் வரவேற்பை இழந்தால், மீண்டும் இணைப்பைப் பெறும்போது, ​​இணைப்பு இழப்பின் போது என்ன பேசப்பட்டது என்பதை நீங்கள் கேட்க மாட்டீர்கள்.

இறுதி நிலைத்தன்மை

எழுதப்பட்ட பிறகு, படித்தவர்கள் இறுதியில் அதைப் பார்க்கும் (பொதுவாக மில்லி விநாடிகளுக்குள்). தரவு ஒத்திசைவற்ற முறையில் நகலெடுக்கப்படுகிறது.

இந்த அணுகுமுறை DNS மற்றும் மின்னஞ்சல் போன்ற அமைப்புகளில் காணப்படுகிறது. மிகவும் கிடைக்கக்கூடிய அமைப்புகளில் இறுதி நிலைத்தன்மை நன்றாக வேலை செய்கிறது.

வலுவான நிலைத்தன்மை

எழுதிய பிறகு, படித்தவர்கள் பார்க்கிறார்கள். தரவு ஒத்திசைவாக நகலெடுக்கப்படுகிறது.

இந்த அணுகுமுறை கோப்பு முறைமைகள் மற்றும் RDBMSகளில் காணப்படுகிறது. பரிவர்த்தனைகள் தேவைப்படும் அமைப்புகளில் வலுவான நிலைத்தன்மை நன்றாக வேலை செய்கிறது.

ஆதாரம்(கள்) மற்றும் மேலதிக வாசிப்பு

கிடைக்கும் வடிவங்கள்

அதிக கிடைக்கும் தன்மையை ஆதரிக்க இரண்டு நிரப்பு வடிவங்கள் உள்ளன: தோல்வி மற்றும் பிரதி.

தோல்விக்கு

செயலில்-செயலற்ற

ஆக்டிவ்-பாசிவ் ஃபெயில்-ஓவர் மூலம், காத்திருப்பில் உள்ள செயலில் மற்றும் செயலற்ற சேவையகத்திற்கு இடையே இதயத் துடிப்புகள் அனுப்பப்படும். இதயத் துடிப்பு தடைபட்டால், செயலற்ற சேவையகம் செயலில் உள்ளவரின் ஐபி முகவரியை எடுத்துக் கொண்டு சேவையை மீண்டும் தொடங்கும்.

செயலற்ற சேவையகம் ஏற்கனவே 'ஹாட்' காத்திருப்பில் இயங்குகிறதா அல்லது 'கோல்ட்' காத்திருப்பில் இருந்து தொடங்க வேண்டுமா என்பதன் மூலம் வேலையில்லா நேரத்தின் நீளம் தீர்மானிக்கப்படுகிறது. செயலில் உள்ள சேவையகம் மட்டுமே போக்குவரத்தைக் கையாளும்.

செயலில்-செயலற்ற தோல்வியை மாஸ்டர்-ஸ்லேவ் ஃபெயில்ஓவர் என்றும் குறிப்பிடலாம்.

செயலில்-செயலில்

செயலில்-செயலில், இரண்டு சேவையகங்களும் போக்குவரத்தை நிர்வகிக்கின்றன, அவற்றுக்கிடையே சுமைகளை பரப்புகின்றன.

சேவையகங்கள் பொது முகமாக இருந்தால், இரண்டு சேவையகங்களின் பொது ஐபிகளைப் பற்றி DNS தெரிந்து கொள்ள வேண்டும். சேவையகங்கள் உள்முகமாக இருந்தால், பயன்பாட்டு தர்க்கம் இரண்டு சேவையகங்களைப் பற்றியும் தெரிந்து கொள்ள வேண்டும்.

செயலில் செயலில் தோல்வியை மாஸ்டர்-மாஸ்டர் ஃபெயில்ஓவர் என்றும் குறிப்பிடலாம்.

குறைபாடு(கள்): தோல்வி

  • ஃபெயில்-ஓவர் அதிக வன்பொருள் மற்றும் கூடுதல் சிக்கலைச் சேர்க்கிறது.
  • புதிதாக எழுதப்பட்ட எந்தவொரு தரவையும் செயலற்றதாக மாற்றுவதற்கு முன், செயலில் உள்ள அமைப்பு தோல்வியுற்றால், தரவு இழப்பு சாத்தியமாகும்.

பிரதிசெய்கை

எஜமானன்-அடிமை மற்றும் எஜமானன்

இந்த தலைப்பு தரவுத்தளம் பிரிவில் மேலும் விவாதிக்கப்படுகிறது:

எண்களில் கிடைக்கும்

சேவை கிடைக்கும் நேரத்தின் சதவீதமாக, கிடைக்கும் நேரத்தின் மூலம் (அல்லது வேலையில்லா நேரம்) பெரும்பாலும் கணக்கிடப்படுகிறது. கிடைக்கும் தன்மை பொதுவாக 9களின் எண்ணிக்கையில் அளவிடப்படுகிறது - 99.99% கிடைக்கும் சேவை நான்கு 9கள் கொண்டதாக விவரிக்கப்படுகிறது.

99.9% கிடைக்கும் - மூன்று 9கள்

கால அளவு ஏற்றுக்கொள்ளக்கூடிய வேலையில்லா நேரம்
வருடத்திற்கு வேலையில்லா நேரம் 8 மணி 45 நிமிடம் 57 வி
மாதத்திற்கு வேலையில்லா நேரம் 43மீ 49.7வி
ஒர் டபிள்யூ
ஈக் 10மீ 4.8வி
ஒரு நாளைக்கு வேலையில்லா நேரம் 1மீ 26.4வி

99.99% கிடைக்கும் - நான்கு 9கள்

கால அளவு ஏற்றுக்கொள்ளக்கூடிய வேலையில்லா நேரம்
வருடத்திற்கு வேலையில்லா நேரம் 52நிமிடம் 35.7வி
மாதத்திற்கு வேலையில்லா நேரம் 4மீ 23வி
வாரத்திற்கு வேலையில்லா நேரம் 1மீ 5வி
ஒரு நாளைக்கு வேலையில்லா நேரம் 8.6வி

இணையாக vs வரிசையில் கிடைக்கும்

ஒரு சேவையானது செயலிழக்கக்கூடிய பல கூறுகளைக் கொண்டிருந்தால், சேவையின் ஒட்டுமொத்த கிடைக்கும் தன்மை கூறுகள் வரிசையில் உள்ளதா அல்லது இணையாக உள்ளதா என்பதைப் பொறுத்தது.

வரிசையில்

100% <100% கிடைக்கும் இரண்டு கூறுகள் வரிசையில் இருக்கும்போது ஒட்டுமொத்த கிடைக்கும் தன்மை குறைகிறது:

கிடைக்கும் தன்மை (மொத்தம்) = கிடைக்கும் தன்மை (Foo) * கிடைக்கும் தன்மை (பார்)

Foo மற்றும் Bar ஆகிய இரண்டும் ஒவ்வொன்றும் 99.9% கிடைக்கும் எனில், அவற்றின் மொத்தக் கிடைக்கும் தன்மை வரிசையில் 99.8% ஆக இருக்கும்.

இணையாக

இரண்டு கூறுகள் <100% இணையாக இருக்கும்போது ஒட்டுமொத்த கிடைக்கும் தன்மை அதிகரிக்கிறது:

கிடைக்கும் (மொத்தம்) = 1 - (1 - கிடைக்கும் (Foo)) * (1 - கிடைக்கும் (பார்))

Foo மற்றும் Bar இரண்டும் ஒவ்வொன்றும் 99.9% இருந்தால், அவற்றின் மொத்தக் கிடைக்கும் தன்மை இணையாக 99.9999% ஆக இருக்கும்.

டொமைன் பெயர் அமைப்பு


ஆதாரம்: DNS பாதுகாப்பு விளக்கக்காட்சி

ஒரு டொமைன் பெயர் அமைப்பு (DNS) www.example.com போன்ற டொமைன் பெயரை ஐபி முகவரிக்கு மொழிபெயர்க்கிறது.

டிஎன்எஸ் படிநிலையானது, சில அதிகாரப்பூர்வ சேவையகங்கள் மேல் மட்டத்தில் உள்ளன. உங்கள் திசைவி அல்லது ISP தேடும் போது தொடர்பு கொள்ள வேண்டிய DNS சேவையகத்தைப் பற்றிய தகவலை வழங்குகிறது. கீழ் நிலை DNS சேவையகங்களின் கேச் மேப்பிங், இது DNS பரவல் தாமதங்கள் காரணமாக பழையதாகிவிடும். DNS முடிவுகளை உங்கள் உலாவி அல்லது OS மூலம் ஒரு குறிப்பிட்ட காலத்திற்கு தேக்ககப்படுத்தலாம், இது நேரத்திற்கான நேரத்தால் (TTL) தீர்மானிக்கப்படுகிறது.

  • NS பதிவு (பெயர் சேவையகம்) - உங்கள் டொமைன்/துணை டொமைனுக்கான DNS சேவையகங்களைக் குறிப்பிடுகிறது.
  • MX பதிவு (அஞ்சல் பரிமாற்றம்) - செய்திகளை ஏற்றுக்கொள்வதற்கான அஞ்சல் சேவையகங்களைக் குறிப்பிடுகிறது.
  • ஒரு பதிவு (முகவரி) - ஒரு ஐபி முகவரிக்கு ஒரு பெயரை சுட்டிக்காட்டுகிறது.
  • CNAME (நியாயமான) - ஒரு பெயரை மற்றொரு பெயருக்கு அல்லது CNAME (example.com இலிருந்து www.example.com) அல்லது A பதிவில் சுட்டிக்காட்டுகிறது.

CloudFlare மற்றும் Route 53 போன்ற சேவைகள் நிர்வகிக்கப்பட்ட DNS சேவைகளை வழங்குகின்றன. சில DNS சேவைகள் பல்வேறு முறைகள் மூலம் போக்குவரத்தை வழிநடத்தலாம்:

குறைபாடு(கள்): DNS

  • மேலே விவரிக்கப்பட்ட கேச்சிங் மூலம் குறைக்கப்பட்டாலும், டிஎன்எஸ் சேவையகத்தை அணுகுவது சிறிது தாமதத்தை அறிமுகப்படுத்துகிறது.
  • DNS சர்வர் மேலாண்மை சிக்கலானதாக இருக்கலாம் மற்றும் பொதுவாக [அரசுகள், ISPகள் மற்றும் பெரிய நிறுவனங்களால்] (http://superuser.com/questions/472695/who-controls-the-dns-servers/472729) நிர்வகிக்கப்படுகிறது.
  • DNS சேவைகள் சமீபத்தில் [DDoS attack] (http://dyn.com/blog/dyn-analysis-summary-of-friday-october-21-attack/) கீழ் வந்துள்ளன, இது பயனர்கள் ட்விட்டர் போன்ற இணையதளங்களைத் தெரியாமல் அணுகுவதைத் தடுக்கிறது. Twitter இன் IP முகவரி(கள்).

ஆதாரம்(கள்) மற்றும் மேலதிக வாசிப்பு

உள்ளடக்க விநியோக நெட்வொர்க்


ஆதாரம்: ஏன் CDN ஐப் பயன்படுத்த வேண்டும்

உள்ளடக்க டெலிவரி நெட்வொர்க் (சிடிஎன்) என்பது உலகளவில் விநியோகிக்கப்பட்ட ப்ராக்ஸி சர்வர்களின் நெட்வொர்க் ஆகும், இது பயனருக்கு நெருக்கமான இடங்களிலிருந்து உள்ளடக்கத்தை வழங்குகிறது. பொதுவாக, HTML/CSS/JS போன்ற நிலையான கோப்புகள், புகைப்படங்கள் மற்றும் வீடியோக்கள் CDN இலிருந்து வழங்கப்படுகின்றன, இருப்பினும் Amazon's CloudFront போன்ற சில CDNகள் மாறும் உள்ளடக்கத்தை ஆதரிக்கின்றன. தளத்தின் DNS தெளிவுத்திறன் வாடிக்கையாளர்களுக்கு எந்த சேவையகத்தை தொடர்பு கொள்ள வேண்டும் என்று தெரிவிக்கும்.

CDNகளில் இருந்து உள்ளடக்கத்தை வழங்குவது இரண்டு வழிகளில் செயல்திறனை கணிசமாக மேம்படுத்தலாம்:

  • பயனர்கள் தங்களுக்கு அருகிலுள்ள தரவு மையங்களிலிருந்து உள்ளடக்கத்தைப் பெறுகிறார்கள்
  • CDN நிறைவேற்றும் கோரிக்கைகளை உங்கள் சர்வர்கள் வழங்க வேண்டியதில்லை

புஷ் CDNகள்

உங்கள் சர்வரில் மாற்றங்கள் ஏற்படும் போதெல்லாம் புஷ் CDNகள் புதிய உள்ளடக்கத்தைப் பெறும். உள்ளடக்கத்தை வழங்குவதற்கும், CDN க்கு நேரடியாகப் பதிவேற்றுவதற்கும் மற்றும் CDN ஐ சுட்டிக்காட்டும் வகையில் URLகளை மீண்டும் எழுதுவதற்கும் நீங்கள் முழுப் பொறுப்பையும் ஏற்கிறீர்கள். உள்ளடக்கம் காலாவதியாகும் போது மற்றும் அது புதுப்பிக்கப்படும் போது நீங்கள் கட்டமைக்கலாம். உள்ளடக்கம் புதியதாகவோ அல்லது மாற்றமாகவோ இருக்கும்போது மட்டுமே பதிவேற்றப்படும், ட்ராஃபிக்கைக் குறைக்கிறது, ஆனால் சேமிப்பகத்தை அதிகப்படுத்துகிறது.

சிறிய அளவிலான டிராஃபிக்கைக் கொண்ட தளங்கள் அல்லது அடிக்கடி புதுப்பிக்கப்படாத உள்ளடக்கத்தைக் கொண்ட தளங்கள் புஷ் சிடிஎன்களுடன் நன்றாக வேலை செய்கின்றன . சீரான இடைவெளியில் மீண்டும் இழுக்கப்படுவதற்குப் பதிலாக ஒருமுறை CDNகளில் உள்ளடக்கம் வைக்கப்படும்.

CDNகளை இழுக்கவும்

முதல் பயனர் உள்ளடக்கத்தைக் கோரும் போது, CDNகள் உங்கள் சர்வரிலிருந்து புதிய உள்ளடக்கத்தைப் பிடிக்கும். உங்கள் சர்வரில் உள்ள உள்ளடக்கத்தை விட்டுவிட்டு, CDNஐ சுட்டிக்காட்ட URLகளை மீண்டும் எழுதுகிறீர்கள். CDN இல் உள்ளடக்கம் தற்காலிகமாக சேமிக்கப்படும் வரை இது மெதுவான கோரிக்கையை விளைவிக்கிறது.

ஒரு time-to-live (TTL) உள்ளடக்கம் எவ்வளவு நேரம் தற்காலிகமாக சேமிக்கப்படுகிறது என்பதை தீர்மானிக்கிறது. CDNகளை இழுப்பது CDN இல் சேமிப்பக இடத்தைக் குறைக்கிறது, ஆனால் கோப்புகள் காலாவதியாகி, அவை உண்மையில் மாறுவதற்கு முன்பே இழுக்கப்பட்டால் தேவையற்ற போக்குவரத்தை உருவாக்கலாம்.

ட்ராஃபிக் அதிகமாக உள்ள தளங்கள் புல் CDNகளுடன் நன்றாக வேலை செய்கின்றன, ஏனெனில் CDN இல் சமீபத்தில் கோரப்பட்ட உள்ளடக்கம் மட்டுமே மீதமுள்ளதால் ட்ராஃபிக் மிகவும் சீராக பரவுகிறது.

குறைபாடு(கள்): CDN

  • சிடிஎன் செலவுகள் போக்குவரத்தைப் பொறுத்து குறிப்பிடத்தக்கதாக இருக்கலாம், இருப்பினும் இது சிடிஎன் பயன்படுத்தாமல் இருக்கும் கூடுதல் செலவுகளுடன் எடைபோட வேண்டும்.
  • TTL காலாவதியாகும் முன் உள்ளடக்கம் புதுப்பிக்கப்பட்டால் பழையதாக இருக்கலாம்.
  • CDN களுக்கு CDN ஐ சுட்டிக்காட்ட நிலையான உள்ளடக்கத்திற்கான URLகளை மாற்ற வேண்டும்.

ஆதாரம்(கள்) மற்றும் மேலதிக வாசிப்பு

லோட் பேலன்சர்


ஆதாரம்: அளவிடக்கூடிய கணினி வடிவமைப்பு வடிவங்கள்

பயன்பாட்டு சேவையகங்கள் மற்றும் தரவுத்தளங்கள் போன்ற கம்ப்யூட்டிங் ஆதாரங்களுக்கு உள்வரும் கிளையன்ட் கோரிக்கைகளை ஏற்ற சமநிலையாளர்கள் விநியோகிக்கின்றனர். ஒவ்வொரு சந்தர்ப்பத்திலும், சுமை சமநிலையானது கணினி வளத்திலிருந்து பொருத்தமான கிளையண்டிற்கு பதிலை வழங்குகிறது. சுமை பேலன்சர்கள் இதில் பயனுள்ளதாக இருக்கும்:

  • ஆரோக்கியமற்ற சேவையகங்களுக்கு கோரிக்கைகள் செல்வதைத் தடுக்கிறது
  • வளங்களை ஓவர்லோடிங் செய்வதைத் தடுத்தல்
  • தோல்வியின் ஒரு புள்ளியை அகற்ற உதவுகிறது

சுமை பேலன்சர்களை வன்பொருள் (விலையுயர்ந்த) அல்லது HAProxy போன்ற மென்பொருள் மூலம் செயல்படுத்தலாம்.

கூடுதல் நன்மைகள் அடங்கும்:

  • SSL முடித்தல் - உள்வரும் கோரிக்கைகளை டிக்ரிப்ட் செய்து சர்வர் பதில்களை என்க்ரிப்ட் செய்யவும், எனவே பின்தள சேவையகங்கள் இந்த விலையுயர்ந்த செயல்பாடுகளைச் செய்ய வேண்டியதில்லை
  • அமர்வு நிலைத்தன்மை - குக்கீகளை வழங்கவும் மற்றும் வலை பயன்பாடுகள் அமர்வுகளைக் கண்காணிக்கவில்லை என்றால், குறிப்பிட்ட கிளையண்டின் கோரிக்கைகளை அதே நிகழ்விற்கு அனுப்பவும்

தோல்விகளிலிருந்து பாதுகாக்க, பல சுமை பேலன்சர்களை செயலில்-செயலற்ற அல்லது ஆக்டிவ்-ஆக்டிவ் முறையில் அமைப்பது பொதுவானது.

சுமை பேலன்சர்கள் பல்வேறு அளவீடுகளின் அடிப்படையில் போக்குவரத்தை வழிநடத்தலாம், அவற்றுள்:

அடுக்கு 4 சுமை சமநிலை

லேயர் 4 லோட் பேலன்சர்கள் கோரிக்கைகளை எவ்வாறு விநியோகிப்பது என்பதைத் தீர்மானிக்க போக்குவரத்து அடுக்கு இல் உள்ள தகவலைப் பார்க்கிறார்கள். பொதுவாக, இது மூல, இலக்கு ஐபி முகவரிகள் மற்றும் தலைப்பில் உள்ள போர்ட்களை உள்ளடக்கியது, ஆனால் பாக்கெட்டின் உள்ளடக்கங்கள் அல்ல. லேயர் 4 லோட் பேலன்சர்கள் நெட்வொர்க் பாக்கெட்டுகளை அப்ஸ்ட்ரீம் சேவையகத்திற்கு அனுப்புகிறது.

அடுக்கு 7 சுமை சமநிலை

லேயர் 7 லோட் பேலன்சர்கள் கோரிக்கைகளை எவ்வாறு விநியோகிப்பது என்பதைத் தீர்மானிக்க பயன்பாட்டு அடுக்கு பார்க்கவும். இது தலைப்பு, செய்தி மற்றும் குக்கீகளின் உள்ளடக்கங்களை உள்ளடக்கியிருக்கலாம். லேயர் 7 லோட் பேலன்சர்கள் நெட்வொர்க் ட்ராஃபிக்கை நிறுத்துகின்றன, செய்தியைப் படிக்கின்றன, சுமை சமநிலை முடிவை எடுக்கின்றன, பின்னர் தேர்ந்தெடுக்கப்பட்ட சேவையகத்திற்கான இணைப்பைத் திறக்கின்றன. எடுத்துக்காட்டாக, லேயர் 7 லோட் பேலன்சர் வீடியோ டிராஃபிக்கை வீடியோக்களை ஹோஸ்ட் செய்யும் சேவையகங்களுக்கு வழிநடத்தும் அதே வேளையில் அதிக உணர்திறன் வாய்ந்த பயனர் பில்லிங் போக்குவரத்தை பாதுகாப்பு-கடினப்படுத்தப்பட்ட சேவையகங்களுக்கு இயக்குகிறது.

நெகிழ்வுத்தன்மையின் விலையில், அடுக்கு 4 சுமை சமநிலைக்கு லேயர் 7 ஐ விட குறைவான நேரமும் கணினி வளங்களும் தேவைப்படுகின்றன, இருப்பினும் செயல்திறன் தாக்கம் நவீன கமாடிட்டி வன்பொருளில் குறைவாகவே இருக்கும்.

கிடைமட்ட அளவிடுதல்

லோட் பேலன்சர்கள் கிடைமட்ட அளவீடு, செயல்திறன் மற்றும் கிடைக்கும் தன்மையை மேம்படுத்தவும் உதவும். வெர்டிகல் ஸ்கேலிங் எனப்படும் அதிக விலையுயர்ந்த வன்பொருளில் ஒற்றை சர்வரை அளவிடுவதை விட, கமாடிட்டி மெஷின்களைப் பயன்படுத்தி அளவிடுதல் அதிக செலவுத் திறன் கொண்டது மற்றும் அதிக கிடைக்கும் தன்மையை விளைவிக்கிறது. சிறப்பு நிறுவன அமைப்புகளை விட கமாடிட்டி ஹார்டுவேரில் பணிபுரியும் திறமைசாலிகளை பணியமர்த்துவதும் எளிதானது.

குறைபாடு(கள்): கிடைமட்ட அளவிடுதல்

  • கிடைமட்டமாக அளவிடுதல் சிக்கலான தன்மையை அறிமுகப்படுத்துகிறது மற்றும் குளோனிங் சர்வர்களை உள்ளடக்கியது
    • சேவையகங்கள் நிலையற்றதாக இருக்க வேண்டும்: அவை அமர்வுகள் அல்லது சுயவிவரப் படங்கள் போன்ற பயனர் தொடர்பான எந்தத் தரவையும் கொண்டிருக்கக்கூடாது
    • அமர்வுகள் டேட்டாபேஸ் (SQL, NoSQL) அல்லது ஒரு நிலையான கேச் (ரெடிஸ், மெம்கேச்) போன்ற மையப்படுத்தப்பட்ட தரவு சேமிப்பகத்தில் சேமிக்கப்படும்.
      • கீழ்நிலை சேவையகங்களான கேச்கள் மற்றும் தரவுத்தளங்கள், அப்ஸ்ட்ரீம் சர்வர்கள் அளவிடப்படுவதால் ஒரே நேரத்தில் அதிக இணைப்புகளைக் கையாள வேண்டும்

குறைபாடு(கள்): சுமை சமநிலை

  • லோட் பேலன்சர் போதுமான ஆதாரங்களைக் கொண்டிருக்கவில்லை என்றாலோ அல்லது சரியாக உள்ளமைக்கப்படாமல் இருந்தாலோ செயல்திறன் தடையாக மாறும்.
  • ஒரு தோல்வியின் ஒரு புள்ளியை அகற்ற உதவும் ஒரு சுமை சமநிலையை அறிமுகப்படுத்துவது சிக்கலான தன்மையை அதிகரிக்கிறது.
  • ஒரு ஒற்றை சுமை சமநிலையானது தோல்வியின் ஒரு புள்ளியாகும், பல சுமை சமநிலையாளர்களை கட்டமைப்பது சிக்கலை மேலும் அதிகரிக்கிறது.

ஆதாரம்(கள்) மற்றும் மேலதிக வாசிப்பு

ரிவர்ஸ் ப்ராக்ஸி (வலை சேவையகம்)


ஆதாரம்: விக்கிபீடியா

தலைகீழ் ப்ராக்ஸி என்பது ஒரு இணைய சேவையகமாகும், இது உள் சேவைகளை மையப்படுத்துகிறது மற்றும் பொதுமக்களுக்கு ஒருங்கிணைந்த இடைமுகங்களை வழங்குகிறது. கிளையண்டுகளிடமிருந்து வரும் கோரிக்கைகள், சேவையகத்திற்கு ரிவர்ஸ் ப்ராக்ஸி சேவையகத்தின் பதிலை வழங்கும் முன், அதை நிறைவேற்றக்கூடிய சர்வருக்கு அனுப்பப்படும்.

கூடுதல் நன்மைகள் அடங்கும்:

  • அதிகரித்த பாதுகாப்பு - பின்தள சேவையகங்கள், பிளாக்லிஸ்ட் ஐபிகள், ஒரு கிளையண்டிற்கான இணைப்புகளின் வரம்பு பற்றிய தகவல்களை மறை
  • அதிகரிப்பு மற்றும் நெகிழ்வுத்தன்மை - வாடிக்கையாளர்கள் ரிவர்ஸ் ப்ராக்ஸியின் ஐபியை மட்டுமே பார்க்கிறார்கள், இது உங்களை சர்வர்களை அளவிட அல்லது அவற்றின் உள்ளமைவை மாற்ற அனுமதிக்கிறது.
  • SSL முடித்தல் - உள்வரும் கோரிக்கைகளை டிக்ரிப்ட் செய்து சர்வர் பதில்களை என்க்ரிப்ட் செய்யவும், எனவே பின்தள சேவையகங்கள் இந்த விலையுயர்ந்த செயல்பாடுகளைச் செய்ய வேண்டியதில்லை
  • அமுக்கம் - சர்வர் பதில்களை சுருக்கவும்
  • கேச்சிங் - கேச் செய்யப்பட்ட கோரிக்கைகளுக்கான பதிலைத் திருப்பி அனுப்பவும்
  • நிலையான உள்ளடக்கம் - நிலையான உள்ளடக்கத்தை நேரடியாக வழங்கவும்
    • HTML/CSS/JS
    • புகைப்படங்கள்
    • வீடியோக்கள்
    • முதலியன

லோட் பேலன்சர் vs ரிவர்ஸ் ப்ராக்ஸி

  • உங்களிடம் பல சேவையகங்கள் இருக்கும் போது, ​​சுமை பேலன்சரைப் பயன்படுத்துவது பயனுள்ளதாக இருக்கும். பெரும்பாலும், லோட் பேலன்சர்கள் ஒரே செயல்பாட்டைச் செய்யும் சேவையகங்களின் தொகுப்பிற்கு போக்குவரத்தை வழிநடத்துகின்றன.
  • ஒரே ஒரு இணைய சேவையகம் அல்லது பயன்பாட்டு சேவையகத்துடன் கூட தலைகீழ் ப்ராக்ஸிகள் பயனுள்ளதாக இருக்கும், முந்தைய பிரிவில் விவரிக்கப்பட்ட நன்மைகளைத் திறக்கும்.
  • NGINX மற்றும் HAProxy போன்ற தீர்வுகள் லேயர் 7 ரிவர்ஸ் ப்ராக்ஸிங் மற்றும் லோட் பேலன்சிங் ஆகிய இரண்டையும் ஆதரிக்கும்.

குறைபாடு(கள்): ரிவர்ஸ் ப்ராக்ஸி

  • ரிவர்ஸ் ப்ராக்ஸியை அறிமுகப்படுத்துவது சிக்கலான தன்மையை அதிகரிக்கிறது.
  • ஒற்றை தலைகீழ் ப்ராக்ஸி தோல்வியின் ஒற்றை புள்ளியாகும், பல தலைகீழ் ப்ராக்ஸிகளை (அதாவது failover) கட்டமைப்பது சிக்கலை மேலும் அதிகரிக்கிறது.

ஆதாரம்(கள்) மற்றும் மேலதிக வாசிப்பு

பயன்பாட்டு அடுக்கு


ஆதாரம்: அளவிற்கான கட்டிடக்கலை அமைப்புகளுக்கான அறிமுகம்

அப்ளிகேஷன் லேயரில் இருந்து வலை அடுக்கைப் பிரிப்பது (பிளாட்ஃபார்ம் லேயர் என்றும் அழைக்கப்படுகிறது) இரண்டு அடுக்குகளையும் தனித்தனியாக அளவிட மற்றும் கட்டமைக்க உங்களை அனுமதிக்கிறது. புதிய APIஐச் சேர்ப்பதால், கூடுதல் இணையச் சேவையகங்களைச் சேர்க்காமல் பயன்பாட்டுச் சேவையகங்களைச் சேர்க்கும். ஒற்றை பொறுப்புக் கொள்கை சிறிய மற்றும் தன்னாட்சிச் சேவைகள் இணைந்து செயல்படுவதை ஆதரிக்கிறது. சிறிய சேவைகளைக் கொண்ட சிறிய குழுக்கள் விரைவான வளர்ச்சிக்கு மிகவும் தீவிரமாகத் திட்டமிடலாம்.

பயன்பாட்டு அடுக்கில் உள்ள வேலையாட்களும் அசின்க்ரோனிசம் இயக்க உதவுகிறார்கள்.

மைக்ரோ சர்வீசஸ்

இந்த விவாதத்துடன் தொடர்புடையது மைக்ரோ சர்வீசஸ், அவை சுயாதீனமாக பயன்படுத்தக்கூடிய, சிறிய, மட்டு சேவைகளின் தொகுப்பாக விவரிக்கப்படலாம். ஒவ்வொரு சேவையும் ஒரு தனித்துவமான செயல்முறையை இயக்குகிறது மற்றும் வணிக இலக்கை அடைய நன்கு வரையறுக்கப்பட்ட, இலகுரக பொறிமுறையின் மூலம் தொடர்பு கொள்கிறது. 1

எடுத்துக்காட்டாக, Pinterest பின்வரும் மைக்ரோ சர்வீஸ்களைக் கொண்டிருக்கலாம்: பயனர் சுயவிவரம், பின்தொடர்பவர், ஊட்டம், தேடல், புகைப்படப் பதிவேற்றம் போன்றவை.

சேவை கண்டுபிடிப்பு

கான்சல், [Etcd](https://coreos.com/etcd/docs/lat போன்ற அமைப்புகள் est), மற்றும் Zookeeper பதிவுசெய்யப்பட்ட பெயர்கள், முகவரிகள் மற்றும் போர்ட்களைக் கண்காணிப்பதன் மூலம் சேவைகள் ஒன்றையொன்று கண்டறிய உதவும். உடல்நலச் சரிபார்ப்புகள் சேவை ஒருமைப்பாட்டைச் சரிபார்க்க உதவுகின்றன, மேலும் அவை பெரும்பாலும் HTTP இறுதிப் புள்ளியைப் பயன்படுத்திச் செய்யப்படுகின்றன. Consul மற்றும் Etcd ஆகிய இரண்டும் உள்ளமைக்கப்பட்ட key-value store கட்டமைப்பு மதிப்புகள் மற்றும் பிற பகிரப்பட்ட தரவுகளை சேமிக்க பயனுள்ளதாக இருக்கும்.

குறைபாடு(கள்): பயன்பாட்டு அடுக்கு

  • தளர்வான இணைக்கப்பட்ட சேவைகளுடன் பயன்பாட்டு அடுக்கைச் சேர்ப்பதற்கு, கட்டடக்கலை, செயல்பாடுகள் மற்றும் செயல்முறைக் கண்ணோட்டத்தில் (ஒற்றை அமைப்புக்கு எதிராக) வேறுபட்ட அணுகுமுறை தேவைப்படுகிறது.
  • மைக்ரோ சர்வீஸ்கள் வரிசைப்படுத்தல்கள் மற்றும் செயல்பாடுகளின் அடிப்படையில் சிக்கலைச் சேர்க்கலாம்.

ஆதாரம்(கள்) மற்றும் மேலதிக வாசிப்பு

தரவுத்தளம்


ஆதாரம்: உங்கள் முதல் 10 மில்லியன் பயனர்களை அளவிடுதல்

தொடர்புடைய தரவுத்தள மேலாண்மை அமைப்பு (RDBMS)

SQL போன்ற தொடர்புடைய தரவுத்தளமானது அட்டவணையில் ஒழுங்கமைக்கப்பட்ட தரவு உருப்படிகளின் தொகுப்பாகும்.

ACID என்பது தொடர்புடைய தரவுத்தளத்தின் பரிவர்த்தனைகள் பண்புகளின் தொகுப்பாகும்.

  • அணுவாய் - ஒவ்வொரு பரிவர்த்தனையும் அனைத்தும் அல்லது ஒன்றுமில்லை
  • நிலைத்தன்மை - எந்தவொரு பரிவர்த்தனையும் தரவுத்தளத்தை ஒரு செல்லுபடியாகும் நிலையில் இருந்து மற்றொரு நிலைக்கு கொண்டு வரும்
  • தனிமைப்படுத்தல் - பரிவர்த்தனைகளை ஒரே நேரத்தில் செயல்படுத்துவது, பரிவர்த்தனைகள் தொடர்ச்சியாக செயல்படுத்தப்பட்டால் அதே முடிவுகளைக் கொண்டிருக்கும்.
  • நீடிப்பு - ஒருமுறை பரிவர்த்தனை செய்யப்பட்டால், அது அப்படியே இருக்கும்

தொடர்புடைய தரவுத்தளத்தை அளவிடுவதற்கு பல நுட்பங்கள் உள்ளன: மாஸ்டர்-ஸ்லேவ் ரெப்ளிகேஷன், மாஸ்டர்-மாஸ்டர் ரெப்ளிகேஷன், ஃபெடரேஷன், ஷார்டிங், டிநார்மலைசேஷன் மற்றும் SQL டியூனிங்.

மாஸ்டர்-ஸ்லேவ் பிரதி

எஜமானர் படிக்கவும் எழுதவும் பணியாற்றுகிறார், ஒன்று அல்லது அதற்கு மேற்பட்ட அடிமைகளுக்கு எழுதுவதைப் பிரதிபலிக்கிறார், இது படிக்க மட்டுமே உதவுகிறது. அடிமைகள் ஒரு மரம் போன்ற பாணியில் கூடுதல் அடிமைகளுக்கு நகலெடுக்கலாம். மாஸ்டர் ஆஃப்லைனில் சென்றால், ஒரு அடிமை மாஸ்டராக பதவி உயர்வு பெறும் வரை அல்லது ஒரு புதிய மாஸ்டர் வழங்கப்படும் வரை கணினி படிக்க மட்டும் பயன்முறையில் தொடர்ந்து செயல்படும்.


ஆதாரம்: அளவிடுதல், கிடைக்கும் தன்மை, நிலைத்தன்மை, வடிவங்கள்

குறைபாடு(கள்): எஜமான-அடிமை பிரதியீடு
  • அடிமையை எஜமானராக உயர்த்த கூடுதல் தர்க்கம் தேவை. ** மாஸ்டர்-ஸ்லேவ் மற்றும் மாஸ்டர்-மாஸ்டர் தொடர்பான புள்ளிகளுக்கு பாதகம்(கள்): பிரதி பார்க்கவும்.

மாஸ்டர்-மாஸ்டர் பிரதி

இரண்டு மாஸ்டர்களும் படிக்கவும் எழுதவும் பணியாற்றுகிறார்கள் மற்றும் எழுதுவதில் ஒருவருக்கொருவர் ஒருங்கிணைக்கிறார்கள். மாஸ்டர் செயலிழந்தால், கணினி வாசிப்பு மற்றும் எழுதுதல் ஆகிய இரண்டிலும் தொடர்ந்து செயல்பட முடியும்.


ஆதாரம்: அளவிடுதல், கிடைக்கும் தன்மை, நிலைத்தன்மை, வடிவங்கள்

குறைபாடு(கள்): மாஸ்டர்-மாஸ்டர் பிரதி
  • உங்களுக்கு ஒரு லோட் பேலன்சர் தேவைப்படும் அல்லது எங்கு எழுதுவது என்பதைத் தீர்மானிக்க உங்கள் பயன்பாட்டு தர்க்கத்தில் மாற்றங்களைச் செய்ய வேண்டும்.
  • பெரும்பாலான மாஸ்டர்-மாஸ்டர் அமைப்புகள் தளர்வாக சீரானவை (ACIDயை மீறுதல்) அல்லது ஒத்திசைவு காரணமாக எழுதும் தாமதத்தை அதிகரித்துள்ளன.
  • அதிக எழுத்து முனைகள் சேர்க்கப்படும்போதும், தாமதம் அதிகரிக்கும்போதும் மோதல் தீர்மானம் அதிக அளவில் செயல்படுகிறது. ** மாஸ்டர்-ஸ்லேவ் மற்றும் மாஸ்டர்-மாஸ்டர் தொடர்பான புள்ளிகளுக்கு பாதகம்(கள்): பிரதி பார்க்கவும்.
குறைபாடு(கள்): பிரதி
  • புதிதாக எழுதப்பட்ட எந்தத் தரவையும் மற்ற முனைகளுக்குப் பிரதிபலிக்கும் முன் மாஸ்டர் தோல்வியுற்றால் தரவை இழக்கும் சாத்தியம் உள்ளது.
  • எழுதப்பட்டவை வாசிக்கப்பட்ட பிரதிகளுக்கு மீண்டும் இயக்கப்படும். நிறைய எழுதுபவைகள் இருந்தால், வாசிப்புப் பிரதிகள் மறுபதிப்பு எழுதுவதில் சிக்கித் தவிக்கும், மேலும் பல வாசிப்புகளைச் செய்ய முடியாது.
  • அடிமைகளை எவ்வளவு அதிகமாகப் படிக்கிறீர்களோ, அவ்வளவு அதிகமாக நீங்கள் நகலெடுக்க வேண்டும், இது அதிக நகலெடுப்பு பின்னடைவுக்கு வழிவகுக்கிறது.
  • சில கணினிகளில், மாஸ்டருக்கு எழுதுவது இணையாக எழுதுவதற்கு பல நூல்களை உருவாக்குகிறது, அதேசமயத்தில் படிக்கும் பிரதிகள் ஒரு நூலில் தொடர்ச்சியாக எழுதுவதை மட்டுமே ஆதரிக்கின்றன.
  • பிரதி அதிக வன்பொருள் மற்றும் கூடுதல் சிக்கலைச் சேர்க்கிறது.
மூல(கள்) மற்றும் மேலதிக வாசிப்பு: பிரதி

கூட்டமைப்பு


ஆதாரம்: உங்கள் முதல் 10 மில்லியன் பயனர்களை அளவிடுதல்

கூட்டமைப்பு (அல்லது செயல்பாட்டு பகிர்வு) செயல்பாட்டின் மூலம் தரவுத்தளங்களை பிரிக்கிறது. எடுத்துக்காட்டாக, ஒற்றை, ஒற்றைத் தரவுத்தளத்திற்குப் பதிலாக, நீங்கள் மூன்று தரவுத்தளங்களைக் கொண்டிருக்கலாம்: மன்றங்கள், பயனர்கள், மற்றும் தயாரிப்புகள், இதன் விளைவாக ஒவ்வொரு தரவுத்தளத்திற்கும் குறைவான வாசிப்பு மற்றும் எழுதும் போக்குவரத்தை ஏற்படுத்துகிறது. பின்னடைவு. சிறிய தரவுத்தளங்கள் நினைவகத்தில் பொருந்தக்கூடிய கூடுதல் தரவை உருவாக்குகின்றன, இது மேம்பட்ட கேச் இருப்பிடத்தின் காரணமாக அதிக கேச் ஹிட்களை விளைவிக்கிறது. எந்த ஒரு மைய மாஸ்டர் வரிசையாக்கமும் இல்லாமல் நீங்கள் இணையாக எழுதலாம், செயல்திறனை அதிகரிக்கும்.

குறைபாடு(கள்): கூட்டமைப்பு
  • உங்கள் திட்டத்திற்கு மிகப்பெரிய செயல்பாடுகள் அல்லது அட்டவணைகள் தேவைப்பட்டால் கூட்டமைப்பு செயல்படாது.
  • எந்த தரவுத்தளத்தைப் படிக்க வேண்டும் மற்றும் எழுத வேண்டும் என்பதைத் தீர்மானிக்க, உங்கள் பயன்பாட்டு தர்க்கத்தைப் புதுப்பிக்க வேண்டும்.
  • இரண்டு தரவுத்தளங்களிலிருந்து தரவைச் சேர்ப்பது [சேவையக இணைப்பு] மூலம் மிகவும் சிக்கலானது(http://stackoverflow.com/questions/5145637/querying-data-by-joining-two-tables-in-two-database-on-different- சேவையகங்கள்).
  • கூட்டமைப்பு அதிக வன்பொருள் மற்றும் கூடுதல் சிக்கலைச் சேர்க்கிறது.
ஆதாரம்(கள்) மற்றும் மேலதிக வாசிப்பு: கூட்டமைப்பு

ஷேர்டிங்


ஆதாரம்: அளவிடுதல், கிடைக்கும் தன்மை, நிலைத்தன்மை, வடிவங்கள்

ஷார்டிங் வெவ்வேறு தரவுத்தளங்களில் தரவை விநியோகிக்கிறது, அதாவது ஒவ்வொரு தரவுத்தளமும் தரவின் துணைக்குழுவை மட்டுமே நிர்வகிக்க முடியும். பயனர்களின் தரவுத்தளத்தை உதாரணமாக எடுத்துக் கொண்டால், பயனர்களின் எண்ணிக்கை அதிகரிக்கும் போது, ​​அதிக துகள்கள் கிளஸ்டரில் சேர்க்கப்படுகின்றன.

federation இன் நன்மைகளைப் போலவே, பகிர்தல் குறைவான வாசிப்பு மற்றும் எழுதும் டிராஃபிக்கை, குறைவான பிரதியெடுப்பு மற்றும் அதிக கேச் ஹிட்களில் விளைகிறது. குறியீட்டு அளவும் குறைக்கப்பட்டது, இது பொதுவாக வேகமான வினவல்களுடன் செயல்திறனை மேம்படுத்துகிறது. தரவு இழப்பைத் தவிர்க்க சில வகையான நகலைச் சேர்க்க விரும்பினாலும், ஒரு துண்டு கீழே சென்றால், மற்ற துண்டுகள் இன்னும் செயல்படும். கூட்டமைப்பைப் போலவே, ஒற்றை மைய மாஸ்டர் சீரியல் எழுதுவது இல்லை, இது அதிகரித்த செயல்திறனுடன் இணையாக எழுத உங்களை அனுமதிக்கிறது.

பயனர்களின் அட்டவணையைப் பிரிப்பதற்கான பொதுவான வழிகள் பயனரின் கடைசிப் பெயரின் முதலெழுத்து அல்லது பயனரின் புவியியல் இருப்பிடம்.

குறைபாடு(கள்): ஷார்டிங்
  • சிக்கலான SQL வினவல்களை விளைவிக்கக்கூடிய துகள்களுடன் பணிபுரிய உங்கள் பயன்பாட்டு லாஜிக்கை நீங்கள் புதுப்பிக்க வேண்டும்.
  • தரவு விநியோகம் ஒரு துண்டாக மாறலாம். எடுத்துக்காட்டாக, ஒரு ஷார்டில் உள்ள சக்தியைப் பயன்படுத்துபவர்களின் தொகுப்பு மற்றவர்களுடன் ஒப்பிடும்போது அந்தத் துண்டில் அதிக சுமைகளை ஏற்படுத்தும்.
    • மறுசீரமைப்பு கூடுதல் சிக்கலைச் சேர்க்கிறது. consistent hashing அடிப்படையிலான பகிர்தல் செயல்பாடு பரிமாற்றப்பட்ட தரவின் அளவைக் குறைக்கும்.
  • பல துண்டுகளிலிருந்து தரவை இணைப்பது மிகவும் சிக்கலானது.
  • ஷார்டிங் அதிக வன்பொருள் மற்றும் கூடுதல் சிக்கலைச் சேர்க்கிறது.
மூல(கள்) மற்றும் மேலதிக வாசிப்பு: பகிர்தல்

இயல்புநிலைப்படுத்தல்

இயல்பற்றமயமாக்கல் சில எழுதும் செயல்திறனின் இழப்பில் வாசிப்பு செயல்திறனை மேம்படுத்த முயற்சிக்கிறது. விலையுயர்ந்த இணைப்புகளைத் தவிர்க்க, தரவுகளின் தேவையற்ற நகல்கள் பல அட்டவணைகளில் எழுதப்பட்டுள்ளன. PostgreSQL மற்றும் Oracle ஆதரவு materialized views போன்ற சில RDBMS சேமிக்கும் வேலையைக் கையாளுகிறது தேவையற்ற தகவல் மற்றும் தேவையற்ற நகல்களை சீராக வைத்திருத்தல்.

ஃபெடரேஷன் மற்றும் ஷார்டிங் போன்ற நுட்பங்களுடன் தரவு விநியோகிக்கப்பட்டதும், தரவு மையங்கள் முழுவதும் சேர்வதை நிர்வகிப்பது சிக்கலை மேலும் அதிகரிக்கிறது. இயல்பற்றமயமாக்கல் இத்தகைய சிக்கலான இணைப்புகளின் தேவையைத் தவிர்க்கலாம்.

பெரும்பாலான அமைப்புகளில், வாசிப்புகள் 100:1 அல்லது 1000:1 ஐ விட அதிகமாக இருக்கும். ஒரு சிக்கலான தரவுத்தள இணைப்பின் விளைவாக வாசிப்பு மிகவும் விலை உயர்ந்ததாக இருக்கும், இது வட்டு செயல்பாடுகளில் கணிசமான நேரத்தை செலவிடுகிறது.

குறைபாடு(கள்): இயல்பற்ற தன்மை
  • தரவு நகலெடுக்கப்பட்டது.
  • தகவல்களின் தேவையற்ற நகல்களை ஒத்திசைவில் இருக்க கட்டுப்பாடுகள் உதவும், இது தரவுத்தள வடிவமைப்பின் சிக்கலை அதிகரிக்கிறது.
  • அதிக எழுத்துச் சுமையின் கீழ் உள்ள இயல்புநிலை மாற்றப்பட்ட தரவுத்தளமானது அதன் இயல்பாக்கப்பட்ட எண்ணை விட மோசமாகச் செயல்படக்கூடும்.
ஆதாரம்(கள்) மற்றும் மேலதிக வாசிப்பு: இயல்புநிலைப்படுத்தல்

SQL டியூனிங்

SQL ட்யூனிங் என்பது ஒரு பரந்த தலைப்பு மற்றும் பல புத்தகங்கள் குறிப்புகளாக எழுதப்பட்டுள்ளன.

** பென் செய்வது முக்கியம் chmark** மற்றும் profile உருவகப்படுத்த மற்றும் தடைகளை கண்டறிய.

  • பெஞ்ச்மார்க் - ab போன்ற கருவிகள் மூலம் அதிக சுமை சூழ்நிலைகளை உருவகப்படுத்தவும்.
  • சுயவிவரம் - செயல்திறன் சிக்கல்களைக் கண்காணிக்க உதவும் மெதுவான வினவல் பதிவு போன்ற கருவிகளை இயக்கவும்.

தரப்படுத்தல் மற்றும் விவரக்குறிப்பு பின்வரும் மேம்படுத்தல்களுக்கு உங்களைச் சுட்டிக்காட்டலாம்.

திட்டத்தை இறுக்குங்கள்
  • வேகமான அணுகலுக்காக MySQL டம்ப்கள் டிஸ்கில் அடுத்தடுத்த தொகுதிகள்.
  • நிலையான நீள புலங்களுக்கு VARCHAR என்பதற்குப் பதிலாக CHAR ஐப் பயன்படுத்தவும்.
    • CHAR வேகமான, சீரற்ற அணுகலைத் திறம்பட அனுமதிக்கிறது, அதேசமயம் VARCHAR உடன், அடுத்ததை நோக்கிச் செல்வதற்கு முன் ஒரு சரத்தின் முடிவைக் கண்டறிய வேண்டும்.
  • வலைப்பதிவு இடுகைகள் போன்ற பெரிய அளவிலான உரைகளுக்கு TEXT ஐப் பயன்படுத்தவும். TEXT பூலியன் தேடல்களையும் அனுமதிக்கிறது. TEXT புலத்தைப் பயன்படுத்துவதால், உரைத் தொகுதியைக் கண்டறியப் பயன்படும் ஒரு சுட்டி வட்டில் சேமிக்கப்படும்.
  • 2^32 அல்லது 4 பில்லியன் வரை பெரிய எண்களுக்கு INT ஐப் பயன்படுத்தவும்.
  • மிதக்கும் புள்ளி பிரதிநிதித்துவப் பிழைகளைத் தவிர்க்க நாணயத்திற்கு DECIMAL ஐப் பயன்படுத்தவும்.
  • பெரிய BLOBS சேமிப்பதைத் தவிர்க்கவும், அதற்குப் பதிலாகப் பொருளைப் பெறும் இடத்தைச் சேமிக்கவும்.
  • VARCHAR(255) என்பது 8 பிட் எண்ணில் கணக்கிடப்படும் எழுத்துகளின் மிகப்பெரிய எண்ணிக்கையாகும், இது சில RDBMS இல் பைட்டின் பயன்பாட்டை அதிகப்படுத்துகிறது.
  • [தேடல் செயல்திறனை மேம்படுத்த] (http://stackoverflow.com/questions/1017239/how-do-null-values-affect-performance-in-a-database-search) பொருந்தக்கூடிய இடத்தில் பூஜ்யம் இல்லை என்ற தடையை அமைக்கவும்.
நல்ல குறியீடுகளைப் பயன்படுத்தவும்
  • நீங்கள் வினவுகின்ற நெடுவரிசைகள் (தேர்வு, குழு மூலம்``, வரிசைப்படுத்துதல், சேர்தல்`) குறியீடுகளுடன் வேகமாக இருக்கலாம்.
  • குறியீடுகள் பொதுவாக சுய-சமநிலை B-tree என குறிப்பிடப்படுகின்றன, இது தரவை வரிசைப்படுத்துகிறது மற்றும் மடக்கை நேரத்தில் தேடல்கள், வரிசை அணுகல், செருகல்கள் மற்றும் நீக்குதல்களை அனுமதிக்கிறது.
  • ஒரு குறியீட்டை வைப்பதன் மூலம் தரவை நினைவகத்தில் வைத்திருக்க முடியும், அதிக இடம் தேவைப்படுகிறது.
  • குறியீட்டையும் புதுப்பிக்க வேண்டியிருப்பதால் எழுதுவதும் மெதுவாக இருக்கலாம்.
  • அதிக அளவிலான தரவை ஏற்றும்போது, ​​குறியீடுகளை முடக்குவது, தரவை ஏற்றுவது, பின்னர் குறியீடுகளை மீண்டும் உருவாக்குவது ஆகியவை வேகமாக இருக்கும்.
விலையுயர்ந்த இணைப்புகளைத் தவிர்க்கவும்
பகிர்வு அட்டவணைகள்
  • தனி டேபிளில் ஹாட் ஸ்பாட்களை வைத்து டேபிளை உடைத்து அதை நினைவகத்தில் வைத்திருக்க உதவும்.
வினவல் தற்காலிக சேமிப்பை டியூன் செய்யவும்
மூல(கள்) மற்றும் மேலதிக வாசிப்பு: SQL ட்யூனிங்

NoSQL

NoSQL என்பது முக்கிய மதிப்பு அங்காடி, ஆவண ஸ்டோர், பரந்த நெடுவரிசைக் கடை அல்லது **வரைபட தரவுத்தளத்தில் குறிப்பிடப்படும் தரவு உருப்படிகளின் தொகுப்பாகும். தரவு இயல்பற்றது, மேலும் இணைப்பது பொதுவாக பயன்பாட்டுக் குறியீட்டில் செய்யப்படுகிறது. பெரும்பாலான NoSQL கடைகளில் உண்மையான ACID பரிவர்த்தனைகள் இல்லை மற்றும் இறுதி நிலைத்தன்மை.

BASE பெரும்பாலும் NoSQL தரவுத்தளங்களின் பண்புகளை விவரிக்கப் பயன்படுகிறது. CAP தேற்றம் உடன் ஒப்பிடுகையில், BASE ஆனது நிலைத்தன்மைக்கு மேல் கிடைப்பதைத் தேர்ந்தெடுக்கிறது.

  • அடிப்படையில் கிடைக்கும் - கணினி கிடைப்பதற்கு உத்தரவாதம் அளிக்கிறது.
  • மென்மையான நிலை - கணினியின் நிலை உள்ளீடு இல்லாமல் கூட காலப்போக்கில் மாறலாம்.
  • இறுதி நிலைத்தன்மை - அந்த காலகட்டத்தில் கணினி உள்ளீட்டைப் பெறாததால், ஒரு குறிப்பிட்ட காலத்திற்கு கணினி சீராக மாறும்.

SQL அல்லது NoSQL ஆகியவற்றிற்கு இடையே தேர்ந்தெடுப்பதைத் தவிர, எந்த வகையான NoSQL தரவுத்தளமானது உங்கள் பயன்பாட்டு வழக்கு(களுக்கு) மிகவும் பொருத்தமானது என்பதைப் புரிந்துகொள்வது உதவியாக இருக்கும். அடுத்த பகுதியில் முக்கிய மதிப்புக் கடைகள், ஆவணக் கடைகள், ** பரந்த நெடுவரிசைக் கடைகள்** மற்றும் வரைபட தரவுத்தளங்கள் ஆகியவற்றை மதிப்பாய்வு செய்வோம்.

முக்கிய மதிப்பு கடை

சுருக்கம்: ஹாஷ் அட்டவணை

ஒரு முக்கிய மதிப்பு அங்காடி பொதுவாக O(1) படிக்கவும் எழுதவும் அனுமதிக்கிறது மற்றும் பெரும்பாலும் நினைவகம் அல்லது SSD மூலம் ஆதரிக்கப்படுகிறது. தரவு அங்காடிகள் விசைகளை லெக்சிகோகிராஃபிக் வரிசையில் பராமரிக்க முடியும், இது முக்கிய வரம்புகளை திறமையாக மீட்டெடுக்க அனுமதிக்கிறது. முக்கிய மதிப்பு அங்காடிகள் மெட்டாடேட்டாவை மதிப்புடன் சேமிக்க அனுமதிக்கும்.

முக்கிய மதிப்பு அங்காடிகள் உயர் செயல்திறனை வழங்குகின்றன, மேலும் அவை எளிய தரவு மாதிரிகள் அல்லது இன்-மெமரி கேச் லேயர் போன்ற வேகமாக மாறும் தரவுகளுக்குப் பயன்படுத்தப்படுகின்றன. அவை வரையறுக்கப்பட்ட செயல்பாடுகளை மட்டுமே வழங்குவதால், கூடுதல் செயல்பாடுகள் தேவைப்பட்டால், சிக்கலானது பயன்பாட்டு அடுக்குக்கு மாற்றப்படும்.

ஒரு முக்கிய மதிப்பு அங்காடி என்பது ஆவணக் கடை மற்றும் சில சந்தர்ப்பங்களில் வரைபட தரவுத்தளம் போன்ற மிகவும் சிக்கலான அமைப்புகளுக்கு அடிப்படையாகும்.

மூல(கள்) மற்றும் மேலதிக வாசிப்பு: முக்கிய மதிப்பு அங்காடி

ஆவணக் கடை

சுருக்கம்: மதிப்புகளாக சேமிக்கப்பட்ட ஆவணங்களுடன் முக்கிய மதிப்பு ஸ்டோர்

ஒரு ஆவணக் கடையானது ஆவணங்களை மையமாகக் கொண்டது (XML, JSON, பைனரி, முதலியன), ஒரு ஆவணம் கொடுக்கப்பட்ட பொருளுக்கான அனைத்து தகவல்களையும் சேமிக்கிறது. ஆவணக் கடைகள் ஆவணத்தின் உள் கட்டமைப்பின் அடிப்படையில் வினவுவதற்கு APIகள் அல்லது வினவல் மொழியை வழங்குகின்றன. குறிப்பு, இந்த இரண்டு சேமிப்பக வகைகளுக்கு இடையே உள்ள கோடுகளை மங்கலாக்கி, மதிப்பின் மெட்டாடேட்டாவுடன் பணிபுரிவதற்கான அம்சங்களை பல முக்கிய-மதிப்பு ஸ்டோர்கள் உள்ளடக்கியுள்ளன.

அடிப்படை செயலாக்கத்தின் அடிப்படையில், ஆவணங்கள் சேகரிப்புகள், குறிச்சொற்கள், மெட்டாடேட்டா அல்லது கோப்பகங்கள் மூலம் ஒழுங்கமைக்கப்படுகின்றன. ஆவணங்களை ஒழுங்கமைக்கலாம் அல்லது ஒன்றாக தொகுக்கலாம் என்றாலும், ஆவணங்களில் ஒன்றுக்கொன்று முற்றிலும் வேறுபட்ட புலங்கள் இருக்கலாம்.

MongoDB மற்றும் [CouchDB](https://blog.couchdb.org/2016/08/01/couchdb-2-0-architecture போன்ற சில ஆவணக் கடைகள் /) சிக்கலான வினவல்களைச் செய்ய SQL போன்ற மொழியையும் வழங்குகிறது. DynamoDB முக்கிய மதிப்புகள் மற்றும் ஆவணங்கள் இரண்டையும் ஆதரிக்கிறது.

ஆவணக் கடைகள் அதிக நெகிழ்வுத்தன்மையை வழங்குகின்றன மற்றும் எப்போதாவது மாறும் தரவுகளுடன் பணிபுரிய அடிக்கடி பயன்படுத்தப்படுகின்றன.

மூல(கள்) மற்றும் மேலதிக வாசிப்பு: ஆவணக் கடை

பரந்த நெடுவரிசைக் கடை


ஆதாரம்: SQL & NoSQL, ஒரு சுருக்கமான வரலாறு

சுருக்கம்: உள்ளமைக்கப்பட்ட வரைபடம் நெடுவரிசைக் குடும்பம்<RowKey, நெடுவரிசைகள்<ColKey, மதிப்பு, நேர முத்திரை>>

பரந்த நெடுவரிசைக் கடையின் தரவுகளின் அடிப்படை அலகு ஒரு நெடுவரிசை (பெயர்/மதிப்பு ஜோடி). ஒரு நெடுவரிசையை நெடுவரிசை குடும்பங்களில் தொகுக்கலாம் (ஒரு SQL அட்டவணைக்கு ஒப்பானது). சூப்பர் நெடுவரிசை குடும்பங்கள் மேலும் குழு நெடுவரிசை குடும்பங்கள். நீங்கள் ஒவ்வொரு நெடுவரிசையையும் ஒரு வரிசை விசையுடன் சுயாதீனமாக அணுகலாம், அதே வரிசை விசையுடன் கூடிய நெடுவரிசைகள் ஒரு வரிசையை உருவாக்குகின்றன. ஒவ்வொரு மதிப்பிலும் பதிப்பு மற்றும் முரண்பாடுகளைத் தீர்ப்பதற்கான நேர முத்திரை உள்ளது.

கூகுள் Bigtable முதல் பரந்த நெடுவரிசைக் கடையாக அறிமுகப்படுத்தியது, இது திறந்த மூல [HBase]( ஹடூப் சுற்றுச்சூழல் அமைப்பில் அடிக்கடி பயன்படுத்தப்படும் https://www.edureka.co/blog/hbase-architecture/ மற்றும் [Cassandra](http://docs.datastax.com/en/cassandra/3.0/cassandra/architecture/ archIntro.html) Facebook இல் இருந்து. BigTable, HBase மற்றும் Cassandra போன்ற கடைகள் லெக்சிகோகிராஃபிக் வரிசையில் விசைகளை பராமரிக்கின்றன, இது தேர்ந்தெடுக்கப்பட்ட முக்கிய வரம்புகளை திறமையாக மீட்டெடுக்க அனுமதிக்கிறது.

பரந்த நெடுவரிசை கடைகள் அதிக கிடைக்கும் தன்மை மற்றும் உயர் அளவிடுதல் ஆகியவற்றை வழங்குகின்றன. அவை பெரும்பாலும் மிகப் பெரிய தரவுத் தொகுப்புகளுக்குப் பயன்படுத்தப்படுகின்றன.

மூல(கள்) மற்றும் மேலதிக வாசிப்பு: பரந்த நெடுவரிசைக் கடை

வரைபட தரவுத்தளம்


ஆதாரம்: வரைபட தரவுத்தளம்

சுருக்கம்: வரைபடம்

வரைபட தரவுத்தளத்தில், ஒவ்வொரு முனையும் ஒரு பதிவாகும், மேலும் ஒவ்வொரு வளைவும் இரண்டு முனைகளுக்கு இடையிலான உறவாகும். பல வெளிநாட்டு விசைகள் அல்லது பல-பல உறவுகளுடன் சிக்கலான உறவுகளை பிரதிநிதித்துவப்படுத்த வரைபட தரவுத்தளங்கள் உகந்ததாக இருக்கும்.

சமூக வலைப்பின்னல் போன்ற சிக்கலான உறவுகளைக் கொண்ட தரவு மாதிரிகளுக்கு வரைபட தரவுத்தளங்கள் உயர் செயல்திறனை வழங்குகின்றன. அவை ஒப்பீட்டளவில் புதியவை மற்றும் இன்னும் பரவலாகப் பயன்படுத்தப்படவில்லை; மேம்பாட்டு கருவிகள் மற்றும் வளங்களை கண்டுபிடிப்பது மிகவும் கடினமாக இருக்கலாம். பல வரைபடங்களை [REST APIகள்] (#representational-state-transfer-rest) மூலம் மட்டுமே அணுக முடியும்.

ஆதாரம்(கள்) மற்றும் மேலதிக வாசிப்பு: வரைபடம்

மூல(கள்) மற்றும் மேலதிக வாசிப்பு: NoSQL

SQL அல்லது NoSQL


ஆதாரம்: RDBMS இலிருந்து NoSQLக்கு மாறுதல்

SQLக்கான காரணங்கள்:

  • கட்டமைக்கப்பட்ட தரவு
  • கடுமையான திட்டம்
  • தொடர்புடைய தரவு
  • சிக்கலான இணைப்புகளின் தேவை
  • பரிவர்த்தனைகள்
  • அளவிடுதலுக்கான தெளிவான வடிவங்கள்
  • மேலும் நிறுவப்பட்டது: டெவலப்பர்கள், சமூகம், குறியீடு, கருவிகள் போன்றவை
  • குறியீட்டின் அடிப்படையில் தேடுதல் மிக வேகமாக இருக்கும்

NoSQLக்கான காரணங்கள்:

  • அரை கட்டமைக்கப்பட்ட தரவு
  • மாறும் அல்லது நெகிழ்வான திட்டம்
  • தொடர்பில்லாத தரவு
  • சிக்கலான இணைப்புகள் தேவையில்லை
  • பல TB (அல்லது PB) தரவைச் சேமிக்கவும்
  • மிகவும் டேட்டா செறிவான பணிச்சுமை
  • IOPSக்கான மிக அதிக செயல்திறன்

NoSQL க்கு மிகவும் பொருத்தமான மாதிரி தரவு:

  • கிளிக்ஸ்ட்ரீம் மற்றும் லாக் டேட்டாவின் விரைவான உட்கொள்ளல்
  • லீடர்போர்டு அல்லது ஸ்கோரிங் தரவு
  • ஷாப்பிங் கார்ட் போன்ற தற்காலிக தரவு
  • அடிக்கடி அணுகப்படும் ('ஹாட்') அட்டவணைகள்
  • மெட்டாடேட்டா/தேடல் அட்டவணைகள்
மூல(கள்) மற்றும் மேலதிக வாசிப்பு: SQL அல்லது NoSQL

தற்காலிக சேமிப்பு


ஆதாரம்: அளவிடக்கூடிய கணினி வடிவமைப்பு வடிவங்கள்

கேச்சிங் பக்கம் ஏற்றும் நேரத்தை மேம்படுத்துகிறது மற்றும் உங்கள் சர்வர்கள் மற்றும் தரவுத்தளங்களில் சுமையை குறைக்கலாம். இந்த மாதிரியில், அனுப்பியவர் முதலில் கோரிக்கை முன்வைக்கப்பட்டிருந்தால், உண்மையான செயல்படுத்தலைச் சேமிப்பதற்காக, முந்தைய முடிவைத் திரும்பப் பெற முயற்சிப்பார்.

தரவுத்தளங்கள் அதன் பகிர்வுகள் முழுவதும் வாசிப்பு மற்றும் எழுதுதல்களின் ஒரே மாதிரியான விநியோகத்தால் பெரும்பாலும் பயனடைகின்றன. பிரபலமான பொருட்கள் விநியோகத்தை வளைத்து, தடைகளை ஏற்படுத்தலாம். தரவுத்தளத்தின் முன் ஒரு தற்காலிக சேமிப்பை வைப்பது, போக்குவரத்தில் சீரற்ற சுமைகள் மற்றும் ஸ்பைக்குகளை உறிஞ்சுவதற்கு உதவும்.

கிளையண்ட் கேச்சிங்

தற்காலிக சேமிப்புகள் கிளையன்ட் பக்கத்தில் (OS அல்லது உலாவி), சர்வர் பக்கத்தில் அல்லது ஒரு தனித்துவமான கேச் லேயரில் அமைந்திருக்கும்.

CDN கேச்சிங்

சிடிஎன்கள் ஒரு வகை கேச் எனக் கருதப்படுகிறது.

வெப் சர்வர் கேச்சிங்

Reverse proxies மற்றும் Varnish போன்ற தற்காலிக சேமிப்புகள் நிலையான மற்றும் மாறும் உள்ளடக்கத்தை நேரடியாக வழங்க முடியும். வலை சேவையகங்கள் விண்ணப்ப சேவையகங்களைத் தொடர்பு கொள்ளாமல் கோரிக்கைகளை கேச் செய்யலாம், பதில்களைத் திருப்பி அனுப்பலாம்.

டேட்டாபேஸ் கேச்சிங்

உங்கள் தரவுத்தளமானது இயல்புநிலை உள்ளமைவில் சில நிலை தேக்ககத்தை உள்ளடக்கியது, இது பொதுவான பயன்பாட்டிற்கு உகந்ததாக இருக்கும். குறிப்பிட்ட பயன்பாட்டு முறைகளுக்கு இந்த அமைப்புகளை மாற்றுவது செயல்திறனை மேலும் அதிகரிக்கும்.

பயன்பாட்டு கேச்சிங்

Memcached மற்றும் Redis போன்ற இன்-மெமரி கேச்கள் உங்கள் பயன்பாட்டிற்கும் உங்கள் தரவு சேமிப்பகத்திற்கும் இடையே உள்ள முக்கிய மதிப்பு ஸ்டோர்களாகும். தரவு ரேமில் இருப்பதால், தரவு வட்டில் சேமிக்கப்படும் வழக்கமான தரவுத்தளங்களை விட இது மிக வேகமாக இருக்கும். வட்டை விட ரேம் குறைவாக உள்ளது, எனவே கேச் செல்லாததாக்குதல் அல்காரிதம்களான [குறைந்தது சமீபத்தில் பயன்படுத்தப்பட்ட (LRU)](https://en.wikipedia.org/wiki /Cache_replacement_policies#Last_sently_used_(LRU)) 'குளிர்' உள்ளீடுகளை செல்லாததாக்க மற்றும் RAM இல் 'ஹாட்' தரவை வைத்திருக்க உதவும்.

Redis பின்வரும் கூடுதல் அம்சங்களைக் கொண்டுள்ளது:

  • நிலைத்தன்மை விருப்பம்
  • வரிசைப்படுத்தப்பட்ட தொகுப்புகள் மற்றும் பட்டியல்கள் போன்ற உள்ளமைக்கப்பட்ட தரவு கட்டமைப்புகள்

இரண்டு பொதுவான வகைகளாகப் பிரிக்கக்கூடிய பல நிலைகள் உள்ளன: ** தரவுத்தள வினவல்கள்** மற்றும் ** பொருள்கள்**:

  • வரிசை நிலை
  • வினவல் நிலை
  • முழுமையாக வடிவமைக்கப்பட்ட வரிசைப்படுத்தக்கூடிய பொருள்கள்
  • முழுமையாக வழங்கப்பட்ட HTML

பொதுவாக, கோப்பு அடிப்படையிலான தேக்ககத்தைத் தவிர்க்க முயற்சி செய்ய வேண்டும், ஏனெனில் இது குளோனிங் மற்றும் தானாக அளவிடுதல் மிகவும் கடினமாகிறது.

தரவுத்தள வினவல் மட்டத்தில் கேச்சிங்

நீங்கள் தரவுத்தளத்தை வினவும்போது, ​​வினவலை ஒரு விசையாக ஹாஷ் செய்து, அதன் முடிவை தற்காலிக சேமிப்பில் சேமிக்கவும். இந்த அணுகுமுறை காலாவதி சிக்கல்களால் பாதிக்கப்படுகிறது:

  • சிக்கலான வினவல்களுடன் தேக்ககப்படுத்தப்பட்ட முடிவை நீக்குவது கடினம்
  • டேபிள் செல் போன்ற தரவுகளில் ஒரு பகுதி மாறினால், மாற்றப்பட்ட கலத்தை உள்ளடக்கிய அனைத்து தற்காலிகச் சேமிப்பு வினவல்களையும் நீக்க வேண்டும்

பொருள் மட்டத்தில் கேச்சிங்

உங்கள் பயன்பாட்டுக் குறியீட்டில் நீங்கள் செய்வதைப் போலவே, உங்கள் தரவையும் ஒரு பொருளாகப் பார்க்கவும். உங்கள் பயன்பாடு தரவுத்தளத்திலிருந்து தரவுத்தொகுப்பை ஒரு வகுப்பு நிகழ்வாக அல்லது தரவுக் கட்டமைப்பில் (கள்) இணைக்கச் செய்யுங்கள்:

  • பொருளின் அடிப்படை தரவு மாறியிருந்தால், தற்காலிக சேமிப்பிலிருந்து அதை அகற்றவும்
  • ஒத்திசைவற்ற செயலாக்கத்தை அனுமதிக்கிறது: தொழிலாளர்கள் சமீபத்திய தற்காலிக சேமிப்பில் உள்ள பொருளை உட்கொள்வதன் மூலம் பொருட்களை சேகரிக்கின்றனர்

எதை தேக்ககப்படுத்த வேண்டும் என்பதற்கான பரிந்துரைகள்:

  • பயனர் அமர்வுகள்
  • முழுமையாக ரெண்டர் செய்யப்பட்ட இணையப் பக்கங்கள்
  • செயல்பாட்டு ஸ்ட்ரீம்கள்
  • பயனர் வரைபடத் தரவு

தற்காலிக சேமிப்பை எப்போது புதுப்பிக்க வேண்டும்

தற்காலிக சேமிப்பில் நீங்கள் குறிப்பிட்ட அளவிலான தரவை மட்டுமே சேமிக்க முடியும் என்பதால், உங்கள் பயன்பாட்டுக்கு எந்த கேச் புதுப்பிப்பு உத்தி சிறப்பாகச் செயல்படும் என்பதை நீங்கள் தீர்மானிக்க வேண்டும்.

கேச்-ஒருபுறம்


ஆதாரம்: கேச் முதல் i வரை n-மெமரி தரவு கட்டம்

சேமிப்பகத்திலிருந்து படிக்கவும் எழுதவும் பயன்பாடு பொறுப்பாகும். கேச் சேமிப்பகத்துடன் நேரடியாக தொடர்பு கொள்ளாது. பயன்பாடு பின்வருவனவற்றைச் செய்கிறது:

  • தற்காலிக சேமிப்பில் உள்ளீட்டைத் தேடுங்கள், இதன் விளைவாக கேச் மிஸ் ஆகும்
  • தரவுத்தளத்திலிருந்து உள்ளீட்டை ஏற்றவும்
  • தற்காலிக சேமிப்பில் உள்ளீட்டைச் சேர்க்கவும்
  • திரும்ப நுழைவு
def get_user(self, user_id):
    பயனர் = cache.get("user.{0}", user_id)
    பயனர் யாரும் இல்லை என்றால்:
        பயனர் = db.query ("பயனர்களிடமிருந்து * தேர்ந்தெடுங்கள் எங்கே user_id = {0}", user_id)
        பயனர் யாரும் இல்லை என்றால்:
            விசை = "பயனர்.{0}".format(user_id)
            cache.set(விசை, json.dumps(பயனர்))
    திரும்பிய பயனர்

Memcached பொதுவாக இந்த முறையில் பயன்படுத்தப்படுகிறது.

தற்காலிக சேமிப்பில் சேர்க்கப்பட்ட தரவுகளின் அடுத்தடுத்த வாசிப்புகள் வேகமாக இருக்கும். கேச்-அசைட் என்பது சோம்பேறி ஏற்றுதல் என்றும் குறிப்பிடப்படுகிறது. கோரப்பட்ட தரவு மட்டுமே தற்காலிகமாக சேமிக்கப்படுகிறது, இது கோரப்படாத தரவுகளுடன் தற்காலிக சேமிப்பை நிரப்புவதைத் தவிர்க்கிறது.

குறைபாடு(கள்): கேச்-அசைட்
  • ஒவ்வொரு கேச் மிஸ் மூன்று பயணங்கள், இது குறிப்பிடத்தக்க தாமதத்தை ஏற்படுத்தும்.
  • தரவுத்தளத்தில் புதுப்பிக்கப்பட்டால் தரவு பழையதாகிவிடும். இந்தச் சிக்கலைத் தணிக்க நேர-டு-நேரத்தை (TTL) அமைப்பதன் மூலம் தற்காலிகச் சேமிப்பு உள்ளீட்டைப் புதுப்பித்தல் அல்லது எழுதுதல்-மூலம் பயன்படுத்துதல்.
  • ஒரு முனை தோல்வியுற்றால், அது புதிய, காலியான முனையால் மாற்றப்பட்டு, தாமதத்தை அதிகரிக்கும்.

எழுதுங்கள்


ஆதாரம்: அளவிடுதல், கிடைக்கும் தன்மை, நிலைத்தன்மை, வடிவங்கள்

பயன்பாடு தற்காலிக சேமிப்பை முக்கிய தரவு சேமிப்பகமாகப் பயன்படுத்துகிறது, அதில் தரவைப் படித்து எழுதுகிறது, அதே நேரத்தில் தரவுத்தளத்தைப் படிக்கவும் எழுதவும் கேச் பொறுப்பாகும்:

  • பயன்பாடு தற்காலிக சேமிப்பில் உள்ளீட்டைச் சேர்க்கிறது/புதுப்பிக்கிறது
  • டேட்டா ஸ்டோருக்கு கேச் ஒத்திசைவாக உள்ளீட்டை எழுதுகிறது
  • திரும்பு

விண்ணப்பக் குறியீடு:

set_user(12345, {"foo":"bar"})

கேச் குறியீடு:

def set_user(user_id, மதிப்புகள்):
    பயனர் = db.query("பயனர்களை எங்கிருந்து புதுப்பிக்கவும் ஐடி = {0}", user_id, மதிப்புகள்)
    cache.set(user_id, பயனர்)

எழுதுதல் செயல்பாட்டின் காரணமாக எழுதுதல்-மூலம் ஒரு மெதுவான ஒட்டுமொத்த செயல்பாடாகும், ஆனால் எழுதப்பட்ட தரவுகளின் அடுத்தடுத்த வாசிப்புகள் வேகமாக இருக்கும். பயனர்கள் பொதுவாக தரவுகளைப் படிப்பதை விட தரவைப் புதுப்பிக்கும் போது தாமதத்தை பொறுத்துக்கொள்கிறார்கள். தற்காலிக சேமிப்பில் உள்ள தரவு பழையதாக இல்லை.

குறைபாடு(கள்): மூலம் எழுதவும்
  • தோல்வி அல்லது அளவிடுதல் காரணமாக ஒரு புதிய முனை உருவாக்கப்படும் போது, ​​தரவுத்தளத்தில் உள்ளீடு புதுப்பிக்கப்படும் வரை புதிய முனை உள்ளீடுகளை கேச் செய்யாது. Cache-side with write through இந்த சிக்கலைத் தணிக்க முடியும்.
  • எழுதப்பட்ட பெரும்பாலான தரவுகள் ஒருபோதும் படிக்கப்படாமல் இருக்கலாம், அதை TTL மூலம் குறைக்கலாம்.

எழுது-பின்னால் (எழுது-திரும்ப)


ஆதாரம்: அளவிடுதல், கிடைக்கும் தன்மை, நிலைத்தன்மை, வடிவங்கள்

எழுதுவதற்குப் பின்னால், பயன்பாடு பின்வருவனவற்றைச் செய்கிறது:

  • தற்காலிக சேமிப்பில் உள்ளீட்டைச் சேர்க்கவும்/புதுப்பிக்கவும்
  • டேட்டா ஸ்டோருக்கு ஒத்திசைவற்ற முறையில் எழுதுதல், எழுதும் செயல்திறனை மேம்படுத்துதல்
குறைபாடு(கள்): எழுத-பின்னால்
  • டேட்டா ஸ்டோரில் உள்ள உள்ளடக்கங்கள் தாக்கும் முன் கேச் செயலிழந்தால் தரவு இழப்பு ஏற்படலாம்.
  • கேச்-அசைட் அல்லது ரைட்-த்ரூ செயல்படுத்துவதை விட, ரைட்-பின் செயல்படுத்துவது மிகவும் சிக்கலானது.

புதுப்பித்தல்


ஆதாரம்: கேச் முதல் இன்-மெமரி டேட்டா கிரிட் வரை< /a>

சமீபத்தில் அணுகப்பட்ட கேச் உள்ளீட்டை அதன் காலாவதிக்கு முன் தானாகவே புதுப்பிக்க, தற்காலிக சேமிப்பை உள்ளமைக்கலாம்.

எதிர்காலத்தில் எந்தெந்த பொருட்கள் தேவைப்படலாம் என்பதை தற்காலிக சேமிப்பால் துல்லியமாக கணிக்க முடிந்தால், புதுப்பித்தல்-முன்னால் தாமதம் மற்றும் வாசிப்பு-மூலம் குறையும்.

குறைபாடு(கள்): புதுப்பித்தல்
  • எதிர்காலத்தில் எந்தெந்த பொருட்கள் தேவைப்படலாம் என்பதை துல்லியமாக கணிக்காமல், புதுப்பித்தல் இல்லாமல் செயல்திறன் குறையும்.

குறைபாடு(கள்): தற்காலிக சேமிப்பு

  • கேச்கள் மற்றும் கேச் செல்லாததாக்குதல் மூலம் தரவுத்தளம் போன்ற உண்மையின் ஆதாரங்களுக்கு இடையே நிலைத்தன்மையை பராமரிக்க வேண்டும்.
  • கேச் செல்லாதது ஒரு கடினமான பிரச்சனை, தற்காலிக சேமிப்பை எப்போது புதுப்பிக்க வேண்டும் என்பதில் கூடுதல் சிக்கல் உள்ளது.
  • Redis அல்லது memcached ஐச் சேர்ப்பது போன்ற பயன்பாட்டு மாற்றங்களைச் செய்ய வேண்டும்.

ஆதாரம்(கள்) மற்றும் மேலதிக வாசிப்பு

ஒத்திசைவு


ஆதாரம்: அளவிற்கான கட்டிடக்கலை அமைப்புகளுக்கான அறிமுகம்

ஒத்திசைவற்ற பணிப்பாய்வுகள் விலையுயர்ந்த செயல்பாடுகளுக்கான கோரிக்கை நேரங்களைக் குறைக்க உதவுகின்றன, இல்லையெனில் அவை இன்-லைனில் செய்யப்படும். அவர்கள் நேரத்தைச் செலவழிக்கும் வேலையை, குறிப்பிட்ட கால இடைவெளியில் தரவு திரட்டுதல் போன்றவற்றைச் செய்வதன் மூலமும் உதவலாம்.

செய்தி வரிசைகள்

செய்தி வரிசைகள் செய்திகளைப் பெறுகின்றன, வைத்திருக்கின்றன மற்றும் வழங்குகின்றன. ஒரு செயல்பாடு இன்லைனில் செய்ய மிகவும் மெதுவாக இருந்தால், பின்வரும் பணிப்பாய்வுகளுடன் செய்தி வரிசையைப் பயன்படுத்தலாம்:

  • ஒரு பயன்பாடு ஒரு வேலையை வரிசையில் வெளியிடுகிறது, பின்னர் வேலை நிலையைப் பயனருக்குத் தெரிவிக்கிறது
  • ஒரு தொழிலாளி வரிசையிலிருந்து வேலையை எடுத்துக்கொள்கிறார், அதைச் செயல்படுத்துகிறார், பிறகு வேலை முடிந்தது என்று சமிக்ஞை செய்கிறார்

பயனர் தடுக்கப்படவில்லை மற்றும் வேலை பின்னணியில் செயல்படுத்தப்படுகிறது. இந்த நேரத்தில், கிளையன்ட் விருப்பமாக ஒரு சிறிய அளவிலான செயலாக்கத்தைச் செய்து, பணி முடிந்துவிட்டது போல் தோன்றும். எடுத்துக்காட்டாக, ஒரு ட்வீட்டை இடுகையிட்டால், ட்வீட் உடனடியாக உங்கள் டைம்லைனில் இடுகையிடப்படலாம், ஆனால் உங்கள் ட்வீட் உண்மையில் உங்களைப் பின்தொடர்பவர்கள் அனைவருக்கும் வழங்குவதற்கு சிறிது நேரம் ஆகலாம்.

Redis ஒரு எளிய செய்தி தரகராக பயனுள்ளதாக இருக்கும், ஆனால் செய்திகளை இழக்கலாம்.

RabbitMQ பிரபலமானது, ஆனால் நீங்கள் 'AMQP' நெறிமுறைக்கு ஏற்ப மற்றும் உங்கள் சொந்த முனைகளை நிர்வகிக்க வேண்டும்.

Amazon SQS ஹோஸ்ட் செய்யப்பட்டுள்ளது, ஆனால் அதிக தாமதம் மற்றும் செய்திகள் இருமுறை வழங்கப்படுவதற்கான சாத்தியக்கூறுகள் உள்ளன.

பணி வரிசைகள்

பணிகளின் வரிசைகள் பணிகள் மற்றும் அவற்றின் தொடர்புடைய தரவைப் பெறுகின்றன, அவற்றை இயக்குகின்றன, பின்னர் அவற்றின் முடிவுகளை வழங்குகின்றன. அவர்கள் திட்டமிடலை ஆதரிக்கலாம் மற்றும் பின்னணியில் கணக்கீட்டு-தீவிர வேலைகளை இயக்க பயன்படுத்தலாம்.

Celery திட்டமிடலுக்கான ஆதரவைக் கொண்டுள்ளது மற்றும் முதன்மையாக பைதான் ஆதரவைக் கொண்டுள்ளது.

பின் அழுத்தம்

வரிசைகள் கணிசமாக வளரத் தொடங்கினால், வரிசை அளவு நினைவகத்தை விட பெரியதாகிவிடும், இதன் விளைவாக கேச் மிஸ், டிஸ்க் ரீட் மற்றும் மெதுவான செயல்திறன் போன்றவை ஏற்படும். முதுகு அழுத்தம் வரிசையின் அளவைக் கட்டுப்படுத்தி, அதிக செயல்திறன் வீதத்தையும் நல்ல பதிலையும் பராமரிக்க உதவுகிறது ஏற்கனவே வரிசையில் உள்ள வேலைகளுக்கான நேரங்கள். வரிசை நிரம்பியதும், வாடிக்கையாளர்கள் பிஸியாக உள்ள சர்வர் அல்லது HTTP 503 நிலைக் குறியீட்டைப் பெறுவார்கள். வாடிக்கையாளர்கள் பின்னர் கோரிக்கையை மீண்டும் முயற்சிக்கலாம், ஒருவேளை அதிவேக பேக்ஆஃப்.

குறைபாடு(கள்): ஒத்திசைவு

  • விலையில்லா கணக்கீடுகள் மற்றும் நிகழ்நேர வேலைப்பாய்வுகள் போன்றவற்றைப் பயன்படுத்துவது ஒத்திசைவான செயல்பாடுகளுக்கு மிகவும் பொருத்தமானதாக இருக்கும், ஏனெனில் வரிசைகளை அறிமுகப்படுத்துவது தாமதங்களையும் சிக்கலையும் சேர்க்கலாம்.

ஆதாரம்(கள்) மற்றும் மேலதிக வாசிப்பு

தொடர்பு


ஆதாரம்: OSI 7 அடுக்கு மாதிரி

ஹைபர்டெக்ஸ்ட் பரிமாற்ற நெறிமுறை (HTTP)

HTTP என்பது ஒரு கிளையன்ட் மற்றும் சர்வர் இடையே தரவை குறியாக்கம் செய்து கொண்டு செல்வதற்கான ஒரு முறையாகும். இது ஒரு கோரிக்கை/பதில் நெறிமுறை: வாடிக்கையாளர்கள் கோரிக்கைகளை வழங்குகிறார்கள் மற்றும் சேவையகங்கள் கோரிக்கை பற்றிய தொடர்புடைய உள்ளடக்கம் மற்றும் நிறைவு நிலை தகவலுடன் பதில்களை வழங்குகின்றன. HTTP ஆனது சுயமாக உள்ளது, இது பல இடைநிலை திசைவிகள் மற்றும் சேவையகங்கள் வழியாக கோரிக்கைகள் மற்றும் பதில்களை அனுமதிக்கிறது, அவை சுமை சமநிலை, கேச்சிங், குறியாக்கம் மற்றும் சுருக்கம் ஆகியவற்றைச் செய்கின்றன.

ஒரு அடிப்படை HTTP கோரிக்கை ஒரு வினைச்சொல் (முறை) மற்றும் ஒரு ஆதாரம் (இறுதிப்புள்ளி) ஆகியவற்றைக் கொண்டுள்ளது. கீழே பொதுவான HTTP வினைச்சொற்கள் உள்ளன:

வினை விளக்கம் ஐடெம்போடென்ட்* பாதுகாப்பான Cacheable
பெற ஒரு ஆதாரத்தைப் படிக்கிறது ஆம் ஆம் ஆம்
பதவி ஒரு ஆதாரத்தை உருவாக்குகிறது அல்லது தரவைக் கையாளும் செயல்முறையைத் தூண்டுகிறது இல்லை இல்லை ஆம், பதிலில் புத்துணர்ச்சி தகவல் இருந்தால்
போடு ஒரு வளத்தை உருவாக்குகிறது அல்லது மாற்றுகிறது ஆம் இல்லை இல்லை
இணைப்பு ஒரு வளத்தை ஓரளவு புதுப்பிக்கிறது இல்லை இல்லை ஆம், பதிலில் புத்துணர்ச்சி தகவல் இருந்தால்
நீக்கு ஒரு ஆதாரத்தை நீக்குகிறது ஆம் இல்லை இல்லை
  • வேறுபட்ட முடிவுகள் இல்லாமல் பல முறை அழைக்கப்படலாம்.

HTTP என்பது TCP மற்றும் UDP போன்ற கீழ்-நிலை நெறிமுறைகளை நம்பியிருக்கும் ஒரு பயன்பாட்டு அடுக்கு நெறிமுறையாகும்.

மூல(கள்) மற்றும் மேலதிக வாசிப்பு: HTTP

டிரான்ஸ்மிஷன் கண்ட்ரோல் புரோட்டோகால் (TCP)


ஆதாரம்: எப்படி மல்டிபிளேயர் கேம்ஐ உருவாக்கவும்

TCP என்பது ஒரு IP நெட்வொர்க் மூலம் இணைப்பு சார்ந்த நெறிமுறையாகும். ஹேண்ட்ஷேக் ஐப் பயன்படுத்தி இணைப்பு நிறுவப்பட்டது மற்றும் நிறுத்தப்பட்டது. அனுப்பப்பட்ட அனைத்து பாக்கெட்டுகளும் அசல் வரிசையில் இலக்கை அடைவதற்கான உத்தரவாதம் மற்றும் ஊழல் இல்லாமல்:

அனுப்புநர் சரியான பதிலைப் பெறவில்லை என்றால், அது பாக்கெட்டுகளை மீண்டும் அனுப்பும். பல காலக்கெடு இருந்தால், இணைப்பு துண்டிக்கப்படும். TCP ஓட்டம் கட்டுப்பாடு மற்றும் நெரிசல் கட்டுப்பாடு ஆகியவற்றையும் செயல்படுத்துகிறது. இந்த உத்தரவாதங்கள் தாமதங்களை ஏற்படுத்துகின்றன மற்றும் பொதுவாக UDP ஐ விட குறைவான செயல்திறன் கொண்ட பரிமாற்றத்தை விளைவிக்கும்.

அதிக செயல்திறனை உறுதி செய்ய, இணைய சேவையகங்கள் அதிக எண்ணிக்கையிலான TCP இணைப்புகளைத் திறந்து வைத்திருக்க முடியும், இதன் விளைவாக அதிக நினைவகப் பயன்பாடு ஏற்படுகிறது. வெப் சர்வர் த்ரெட்களுக்கு இடையே அதிக எண்ணிக்கையிலான திறந்த இணைப்புகளை வைத்திருப்பது விலை உயர்ந்ததாக இருக்கலாம் மற்றும் ஒரு memcached சேவையகம். இணைப்பு பூலிங் பொருந்தக்கூடிய UDP க்கு மாறுவதற்கு கூடுதலாக உதவும்.

அதிக நம்பகத்தன்மை தேவைப்படும் ஆனால் குறைவான நேரம் தேவைப்படும் பயன்பாடுகளுக்கு TCP பயனுள்ளதாக இருக்கும். சில எடுத்துக்காட்டுகளில் இணைய சேவையகங்கள், தரவுத்தளத் தகவல், SMTP, FTP மற்றும் SSH ஆகியவை அடங்கும்.

UDP இல் TCP ஐப் பயன்படுத்தும்போது:

  • எல்லாத் தரவுகளும் அப்படியே வர வேண்டும்
  • நெட்வொர்க் செயல்பாட்டின் சிறந்த மதிப்பீட்டைப் பயன்படுத்த நீங்கள் தானாகவே விரும்புகிறீர்கள்

பயனர் டேட்டாகிராம் நெறிமுறை (யுடிபி)


ஆதாரம்: எப்படி மல்டிபிளேயர் கேம்ஐ உருவாக்கவும்

UDP இணைப்பற்றது. டேட்டாகிராம்கள் (பாக்கெட்டுகளுக்கு ஒப்பானது) டேட்டாகிராம் மட்டத்தில் மட்டுமே உத்தரவாதம் அளிக்கப்படுகிறது. டேட்டாகிராம்கள் தங்கள் இலக்கை ஒழுங்கில்லாமல் அடையலாம் அல்லது இல்லாமலும் போகலாம். UDP நெரிசல் கட்டுப்பாட்டை ஆதரிக்காது. TCP ஆதரவு உத்தரவாதம் இல்லாமல், UDP பொதுவாக மிகவும் திறமையானது.

UDP சப்நெட்டில் உள்ள அனைத்து சாதனங்களுக்கும் டேட்டாகிராம்களை அனுப்பும், ஒளிபரப்ப முடியும். இது [DHCP] (https://en.wikipedia.org/wiki/Dynamic_Host_Configuration_Protocol) உடன் பயனுள்ளதாக இருக்கும், ஏனெனில் கிளையன்ட் இன்னும் IP முகவரியைப் பெறவில்லை, இதனால் IP முகவரி இல்லாமல் TCP ஸ்ட்ரீம் செய்வதற்கான வழியைத் தடுக்கிறது.

UDP குறைந்த நம்பகத்தன்மை கொண்டது, ஆனால் VoIP, வீடியோ அரட்டை, ஸ்ட்ரீமிங் மற்றும் நிகழ்நேர மல்டிபிளேயர் கேம்கள் போன்ற நிகழ்நேர பயன்பாட்டு நிகழ்வுகளில் நன்றாக வேலை செய்கிறது.

TCP இல் UDP ஐப் பயன்படுத்தும்போது:

  • உங்களுக்கு மிகக் குறைந்த தாமதம் தேவை
  • தரவு இழப்பை விட தாமதமான தரவு மோசமானது
  • உங்கள் சொந்த பிழை திருத்தத்தை நீங்கள் செயல்படுத்த விரும்புகிறீர்கள்

மூல(கள்) மற்றும் மேலதிக வாசிப்பு: TCP மற்றும் UDP

தொலை நடைமுறை அழைப்பு (RPC)


ஆதாரம்: சிஸ்டம் டிசைன் நேர்காணலை சிதைக்கவும்

ஒரு RPC இல், ஒரு கிளையன்ட் வேறு முகவரி இடத்தில், பொதுவாக தொலை சேவையகத்தில் ஒரு செயல்முறையை செயல்படுத்துகிறது. க்ளையன்ட் புரோகிராமில் இருந்து சர்வருடன் எப்படித் தொடர்புகொள்வது என்பது பற்றிய விவரங்களைச் சுருக்கி, உள்ளூர் செயல்முறை அழைப்பைப் போல் இந்த செயல்முறை குறியிடப்படுகிறது. தொலைநிலை அழைப்புகள் பொதுவாக உள்ளூர் அழைப்புகளை விட மெதுவாகவும் நம்பகத்தன்மை குறைவாகவும் இருக்கும், எனவே உள்ளூர் அழைப்புகளிலிருந்து RPC அழைப்புகளை வேறுபடுத்துவது உதவியாக இருக்கும். பிரபலமான RPC கட்டமைப்புகளில் Protobuf, Thrift, மற்றும் [Avro](https://avro .apache.org/docs/current/).

RPC என்பது கோரிக்கை-பதில் நெறிமுறை:

  • கிளையண்ட் புரோகிராம் - கிளையன்ட் ஸ்டப் செயல்முறையை அழைக்கிறது. அளவுருக்கள் ஒரு உள்ளூர் செயல்முறை அழைப்பு போன்ற அடுக்கில் தள்ளப்படும்.
  • கிளையண்ட் ஸ்டப் செயல்முறை - மார்ஷல்கள் (பேக்குகள்) செயல்முறை ஐடி மற்றும் கோரிக்கை செய்தியில் வாதங்கள்.
  • கிளையண்ட் கம்யூனிகேஷன் மாட்யூல் - OS ஆனது கிளையண்டிலிருந்து சர்வருக்கு செய்தியை அனுப்புகிறது.
  • சர்வர் கம்யூனிகேஷன் மாட்யூல் - OS pasசேவையக ஸ்டப் செயல்முறைக்கு உள்வரும் பாக்கெட்டுகளை ses.
  • சர்வர் ஸ்டப் செயல்முறை - முடிவுகளை அன்மார்ஷல் செய்கிறது, செயல்முறை ஐடியுடன் பொருந்தக்கூடிய சேவையக செயல்முறையை அழைக்கிறது மற்றும் கொடுக்கப்பட்ட வாதங்களை அனுப்புகிறது.
  • சர்வர் பதில் மேலே உள்ள படிகளை தலைகீழ் வரிசையில் மீண்டும் செய்கிறது.

மாதிரி RPC அழைப்புகள்:

GET /someoperation?data=anId

POST /மற்றொரு செயல்பாடு
{
  "தரவு":"anId";
  "மற்றொரு தரவு": "மற்றொரு மதிப்பு"
}

RPC நடத்தைகளை வெளிப்படுத்துவதில் கவனம் செலுத்துகிறது. RPCகள் பெரும்பாலும் உள் தகவல்தொடர்புகளுடன் செயல்திறன் காரணங்களுக்காகப் பயன்படுத்தப்படுகின்றன, ஏனெனில் உங்கள் பயன்பாட்டு நிகழ்வுகளை சிறப்பாகப் பொருத்துவதற்கு சொந்த அழைப்புகளை நீங்கள் கையால் செய்யலாம்.

நேட்டிவ் லைப்ரரியை (எஸ்.டி.கே) தேர்வு செய்யும்போது:

  • உங்கள் இலக்கு தளத்தை நீங்கள் அறிவீர்கள்.
  • உங்கள் "தர்க்கம்" எவ்வாறு அணுகப்படுகிறது என்பதை நீங்கள் கட்டுப்படுத்த வேண்டும்.
  • உங்கள் நூலகத்தில் பிழைக் கட்டுப்பாடு எவ்வாறு நிகழ்கிறது என்பதை நீங்கள் கட்டுப்படுத்த வேண்டும்.
  • செயல்திறன் மற்றும் இறுதி பயனர் அனுபவம் உங்கள் முதன்மையான அக்கறை.

REST ஐப் பின்பற்றும் HTTP APIகள் பொது APIகளுக்கு அடிக்கடி பயன்படுத்தப்படுகின்றன.

குறைபாடு(கள்): RPC

  • RPC வாடிக்கையாளர்கள் சேவையை செயல்படுத்துவதில் இறுக்கமாக இணைந்துள்ளனர்.
  • ஒவ்வொரு புதிய செயல்பாடு அல்லது பயன்பாட்டு நிகழ்வுக்கும் ஒரு புதிய API வரையறுக்கப்பட வேண்டும்.
  • RPC பிழைத்திருத்தம் கடினமாக இருக்கலாம்.
  • ஏற்கனவே உள்ள தொழில்நுட்பங்களை உங்களால் பயன்படுத்த முடியாமல் போகலாம். எடுத்துக்காட்டாக, [Squid போன்ற கேச்சிங் சர்வர்களில் RPC அழைப்புகள் சரியாக தேக்ககப்படுத்தப்படுவதை உறுதிப்படுத்த கூடுதல் முயற்சி தேவைப்படலாம். ](http://www.squid-cache.org/).

பிரதிநிதித்துவ மாநில பரிமாற்றம் (REST)

REST என்பது கிளையன்ட்/சர்வர் மாதிரியை செயல்படுத்தும் ஒரு கட்டடக்கலை பாணியாகும், அங்கு கிளையன்ட் சர்வரால் நிர்வகிக்கப்படும் வளங்களின் தொகுப்பில் செயல்படுகிறது. சேவையகம் வளங்கள் மற்றும் செயல்களின் பிரதிநிதித்துவத்தை வழங்குகிறது, அவை வளங்களின் புதிய பிரதிநிதித்துவத்தை கையாளலாம் அல்லது பெறலாம். அனைத்து தகவல்தொடர்புகளும் நிலையற்றதாகவும் தற்காலிகமாக சேமிக்கக்கூடியதாகவும் இருக்க வேண்டும்.

ஒரு RESTful இடைமுகத்தில் நான்கு குணங்கள் உள்ளன:

  • ஆதாரங்களை அடையாளம் காணவும் (HTTP இல் URI) - எந்த செயலையும் பொருட்படுத்தாமல் அதே URI ஐப் பயன்படுத்தவும்.
  • பிரதிநிதித்துவங்களுடன் மாற்றவும் (HTTP இல் உள்ள வினைச்சொற்கள்) - வினைச்சொற்கள், தலைப்புகள் மற்றும் உடலைப் பயன்படுத்தவும்.
  • சுய விளக்க பிழை செய்தி (HTTP இல் நிலை பதில்) - நிலைக் குறியீடுகளைப் பயன்படுத்தவும், சக்கரத்தை மீண்டும் கண்டுபிடிக்க வேண்டாம்.
  • HATEOAS (HTTPக்கான HTML இடைமுகம்) - உங்கள் இணைய சேவையானது உலாவியில் முழுமையாக அணுகக்கூடியதாக இருக்க வேண்டும்.

மாதிரி REST அழைப்புகள்:

பெறவும் / சில ஆதாரங்கள் / ஐடி

PUT /someresources/anId
{"மற்றொரு தரவு": "மற்றொரு மதிப்பு"}

REST ஆனது தரவை வெளிப்படுத்துவதில் கவனம் செலுத்துகிறது. இது கிளையன்ட்/சர்வர் இடையே இணைப்பதைக் குறைக்கிறது மற்றும் பொது HTTP API களுக்கு அடிக்கடி பயன்படுத்தப்படுகிறது. REST ஆனது URIகள் மூலம் வளங்களை வெளிப்படுத்தும் பொதுவான மற்றும் சீரான முறையைப் பயன்படுத்துகிறது, தலைப்புகள் மூலம் பிரதிநிதித்துவம், மற்றும் GET, POST, PUT, DELETE மற்றும் PATCH போன்ற வினைச்சொற்கள் மூலம் செயல்கள். நிலையற்றதாக இருப்பதால், கிடைமட்ட அளவிடுதல் மற்றும் பகிர்வுக்கு REST சிறந்தது.

குறைபாடு(கள்): REST

  • REST ஆனது தரவை வெளிப்படுத்துவதில் கவனம் செலுத்துவதால், வளங்கள் இயற்கையாக ஒழுங்கமைக்கப்படாவிட்டாலோ அல்லது எளிய படிநிலையில் அணுகப்படாமலோ இருந்தால் அது சரியான பொருத்தமாக இருக்காது. எடுத்துக்காட்டாக, குறிப்பிட்ட நிகழ்வுகளின் தொகுப்புடன் பொருந்திய கடந்த மணிநேரத்திலிருந்து புதுப்பிக்கப்பட்ட அனைத்து பதிவுகளையும் திருப்பி அனுப்புவது ஒரு பாதையாக எளிதில் வெளிப்படுத்தப்படாது. REST உடன், இது URI பாதை, வினவல் அளவுருக்கள் மற்றும் ஒருவேளை கோரிக்கை அமைப்பு ஆகியவற்றின் கலவையுடன் செயல்படுத்தப்படும்.
  • ஓய்வு என்பது பொதுவாக சில வினைச்சொற்களை (GET, POST, PUT, DELETE மற்றும் PATCH) சார்ந்துள்ளது, இது சில நேரங்களில் உங்கள் பயன்பாட்டுக்கு பொருந்தாது. எடுத்துக்காட்டாக, காலாவதியான ஆவணங்களை காப்பக கோப்புறைக்கு நகர்த்துவது இந்த வினைச்சொற்களுக்குள் சரியாக பொருந்தாமல் போகலாம்.
  • உள்ளமைக்கப்பட்ட படிநிலைகளுடன் சிக்கலான ஆதாரங்களைப் பெறுவதற்கு கிளையன்ட் மற்றும் சர்வர் இடையே ஒற்றைப் பார்வைகளை வழங்குவதற்கு பல சுற்றுப் பயணங்கள் தேவை, எ.கா. வலைப்பதிவு உள்ளீட்டின் உள்ளடக்கம் மற்றும் அந்த பதிவின் கருத்துகளைப் பெறுதல். மாறி நெட்வொர்க் நிலைகளில் இயங்கும் மொபைல் பயன்பாடுகளுக்கு, இந்த பல சுற்றுப்பயணங்கள் மிகவும் விரும்பத்தகாதவை.
  • காலப்போக்கில், ஏபிஐ பதிலில் அதிக புலங்கள் சேர்க்கப்படலாம் மற்றும் பழைய கிளையன்ட்கள் அனைத்து புதிய தரவு புலங்களையும் பெறுவார்கள், அவர்களுக்குத் தேவையில்லாதவை கூட, இதன் விளைவாக, இது பேலோட் அளவைக் குறைக்கிறது மற்றும் பெரிய தாமதங்களுக்கு வழிவகுக்கிறது.

RPC மற்றும் REST அழைப்புகள் ஒப்பீடு

ஆபரேஷன் RPC ஓய்வு
பதிவு போஸ்ட் /பதிவு போஸ்ட் /நபர்கள்
ராஜினாமா POST / resign
{
"personid": "1234"
}
நீக்கு /நபர்கள்/1234
ஒரு நபரைப் படியுங்கள் GET /readPerson?personid=1234 GET /persons/1234
ஒரு நபரின் பொருட்களின் பட்டியலைப் படியுங்கள் GET /readUsersItemsList?personid=1234 GET /persons/1234/items
ஒரு நபரின் பொருட்களில் ஒரு பொருளைச் சேர்க்கவும் POST /addItemToUsersItemsList
{
"personid": "1234";
"itemid": "456"
}
POST /persons/1234/items
{
"itemid": "456"
}
ஒரு உருப்படியைப் புதுப்பிக்கவும் POST /modifyItem
{
"itemid": "456";
"விசை": "மதிப்பு"
}
PUT /items/456
{
"விசை": "மதிப்பு"
}
ஒரு பொருளை நீக்கு POST /removeItem
{
"itemid": "456"
}
நீக்கு /items/456

ஆதாரம்: நீங்கள் ஏன் RPC ஐ விட ஓய்வை விரும்புகிறீர்கள் என்று உங்களுக்குத் தெரியுமா /i>

மூல(கள்) மற்றும் மேலதிக வாசிப்பு: REST மற்றும் RPC

பாதுகாப்பு

இந்தப் பிரிவு சில புதுப்பிப்புகளைப் பயன்படுத்தலாம். கருத்தில் பங்களிப்பை!

பாதுகாப்பு என்பது ஒரு பரந்த தலைப்பு. உங்களுக்கு கணிசமான அனுபவம், பாதுகாப்பு பின்னணி அல்லது பாதுகாப்பு பற்றிய அறிவு தேவைப்படும் பதவிக்கு விண்ணப்பிக்கும் வரை, நீங்கள் அடிப்படைகளை விட அதிகமாக தெரிந்து கொள்ள வேண்டிய அவசியமில்லை:

  • போக்குவரத்திலும் ஓய்விலும் குறியாக்கம் செய்யுங்கள்.
  • XSS மற்றும் SQL ஊசி ஆகியவற்றைத் தடுக்க அனைத்து பயனர் உள்ளீடுகள் அல்லது பயனருக்கு வெளிப்படும் எந்த உள்ளீட்டு அளவுருக்களையும் சுத்தப்படுத்தவும் விக்கி/SQL_injection).
  • SQL உட்செலுத்தலைத் தடுக்க அளவுருக் கொண்ட வினவல்களைப் பயன்படுத்தவும்.
  • குறைந்த சலுகை கொள்கையைப் பயன்படுத்தவும்.

ஆதாரம்(கள்) மற்றும் மேலதிக வாசிப்பு

இணைப்பு

நீங்கள் சில சமயங்களில் 'கவர்-ஆஃப்-தி-என்வலப்' மதிப்பீடுகளைச் செய்யும்படி கேட்கப்படுவீர்கள். எடுத்துக்காட்டாக, வட்டில் இருந்து 100 பட சிறுபடங்களை உருவாக்க எவ்வளவு நேரம் ஆகும் அல்லது தரவு அமைப்பு எவ்வளவு நினைவகத்தை எடுக்கும் என்பதை நீங்கள் தீர்மானிக்க வேண்டும். இரண்டு அட்டவணையின் சக்திகள் மற்றும் ஒவ்வொரு ப்ரோக்ராமரும் தெரிந்து கொள்ள வேண்டிய லேட்டன்சி எண்கள் எளிமையான குறிப்புகள்.

இரண்டு அட்டவணையின் அதிகாரங்கள்

சக்தி சரியான மதிப்பு தோராயமான மதிப்பு பைட்டுகள்
------------------------------------------------- -------------
7 128
8 256
10 1024 1 ஆயிரம் 1 கே.பி
16 65,536 64 KB
20 1,048,576 1 மில்லியன் 1 எம்பி
30 1,073,741,824 1 பில்லியன் 1 ஜிபி
32 4,294,967,296 4 ஜிபி
40 1,099,511,627,776 1 டிரில்லியன் 1 TB

ஆதாரம்(கள்) மற்றும் மேலதிக வாசிப்பு

ஒவ்வொரு புரோகிராமரும் தெரிந்து கொள்ள வேண்டிய லேட்டன்சி எண்கள்

தாமத ஒப்பீட்டு எண்கள்
----------------------------
L1 கேச் குறிப்பு 0.5 ns
கிளை 5 ns ஐ தவறாகக் கணித்துள்ளது
L2 கேச் குறிப்பு 7 ns 14x L1 கேச்
மியூடெக்ஸ் பூட்டு/திறத்தல் 25 ns
முதன்மை நினைவக குறிப்பு 100 ns 20x L2 கேச், 200x L1 கேச்
Zippy 10,000 ns 10 us மூலம் 1K பைட்டுகளை சுருக்கவும்
1 KB பைட்டுகளை 1 Gbps நெட்வொர்க்கில் 10,000 ns 10 எங்களுக்கு அனுப்பு
SSD இலிருந்து தோராயமாக 4 KB படிக்கவும்* 150,000 ns 150 us ~1GB/sec SSD
நினைவகம் 250,000 ns 250 இல் இருந்து 1 MB ஐ தொடர்ச்சியாக படிக்கவும்
அதே டேட்டாசென்டருக்குள் சுற்றுப் பயணம் 500,000 ns 500 us
SSD இலிருந்து 1 MB வரிசையாகப் படிக்கவும்* 1,000,000 ns 1,000 us 1 ms ~1GB/sec SSD, 4X நினைவகம்
HDD சீக் 10,000,000 ns 10,000 us 10 ms 20x டேட்டாசென்டர் ரவுண்ட் ட்ரிப்
1 ஜிபிபிஎஸ் 10,000,000 என்எஸ் 10,000 யூஸ் 10 எம்எஸ் 40 எக்ஸ் மெமரி, 10 எக்ஸ் எஸ்எஸ்டி இலிருந்து 1 எம்பியை தொடர்ச்சியாகப் படிக்கவும்
HDD 30,000,000 ns 30,000 us 30 ms 120x நினைவகம், 30X SSD இலிருந்து 1 MB வரிசையாகப் படிக்கவும்
பாக்கெட் அனுப்பு CA->நெதர்லாந்து->CA 150,000,000 ns 150,000 us 150 ms

குறிப்புகள்
-----
1 ns = 10^-9 வினாடிகள்
1 us = 10^-6 வினாடிகள் = 1,000 ns
1 ms = 10^-3 வினாடிகள் = 1,000 us = 1,000,000 ns

மேலே உள்ள எண்களின் அடிப்படையில் எளிமையான அளவீடுகள்:

  • HDD இலிருந்து 30 MB/s இல் வரிசையாகப் படிக்கவும்
  • 1 ஜிபிபிஎஸ் ஈதர்நெட்டிலிருந்து 100 எம்பி/வி வேகத்தில் தொடர்ச்சியாகப் படிக்கவும்
  • SSD இலிருந்து 1 GB/s இல் தொடர்ச்சியாகப் படிக்கவும்
  • பிரதான நினைவகத்திலிருந்து 4 GB/s இல் வரிசையாகப் படிக்கவும்
  • வினாடிக்கு 6-7 உலக சுற்றுப் பயணங்கள்
  • ஒரு தரவு மையத்திற்குள் ஒரு வினாடிக்கு 2,000 சுற்றுப் பயணங்கள்

தாமத எண்கள் காட்சிப்படுத்தப்பட்டன

![](https://camo.githubusercontent.com/77f72259e1eb58596b564d1ad823af1853bc60a3/687474703a2f2f692e696d6775722e636f6022e631b3276636f60606

ஆதாரம்(கள்) மற்றும் மேலதிக வாசிப்பு

கூடுதல் கணினி வடிவமைப்பு நேர்காணல் கேள்விகள்

பொதுவான கணினி வடிவமைப்பு நேர்காணல் கேள்விகள், ஒவ்வொன்றையும் எவ்வாறு தீர்ப்பது என்பதற்கான ஆதாரங்களுக்கான இணைப்புகள்.

கேள்வி குறிப்பு(கள்)
டிராப்பாக்ஸ் போன்ற கோப்பு ஒத்திசைவு சேவையை வடிவமைக்கவும் youtube.com
கூகுள் போன்ற தேடுபொறியை வடிவமைக்கவும் queue.acm.org
[stackexchange.com](http://programmers.stackexchange.com/questions/38324/ interview-question-how-would-you-implement-google-search)
ardendertat.com< br/>stanford.edu
கூகுள் போன்ற அளவிடக்கூடிய வலை கிராலரை வடிவமைக்கவும் quora.com
வடிவமைப்பு கூகுள் டாக்ஸ் code.google.com
[neil.fraser.name](https://neil.fraser.name/writing/sync /)
ரெடிஸ் போன்ற முக்கிய மதிப்புள்ள கடையை வடிவமைக்கவும் slideshare.net
Memcached போன்ற கேச் சிஸ்டத்தை வடிவமைக்கவும் slideshare.net
Amazon's போன்ற பரிந்துரை அமைப்பை வடிவமைக்கவும் hulu.com
ijcai13 .org
பிட்லி போன்ற ஒரு tinyurl அமைப்பை வடிவமைக்கவும் n00tc0d3r.blogspot.com
WhatsApp போன்ற அரட்டை செயலியை வடிவமைக்கவும் highscalability.com
Instagram போன்ற படப் பகிர்வு அமைப்பை வடிவமைத்தல்
பேஸ்புக் செய்தி ஊட்ட செயல்பாட்டை வடிவமைக்கவும் quora.com
[quora.com](http: //www.quora.com/Activity-Streams/What-are-the-scaling-issues-to-keep-in-mind-while-developing-a-social-network-feed)
slideshare.net
பேஸ்புக் டைம்லைன் செயல்பாட்டை வடிவமைக்கவும் facebook.com
[highscalability.com](http://highscalability.com/blog/2012/1/23/ ஃபேஸ்புக்-டைம்லைன்-உங்களிடம்-வழங்கியது denormaliza.html)
பேஸ்புக் அரட்டை செயல்பாட்டை வடிவமைக்கவும் erlang-factory.com
[facebook.com](https://www.facebook. com/note.php?note_id=14218138919&id=9445547199&index=0)
Facebook இன் போன்ற வரைபட தேடல் செயல்பாட்டை வடிவமைக்கவும் facebook.com
facebook .com
facebook.com
CloudFlare போன்ற உள்ளடக்க விநியோக நெட்வொர்க்கை வடிவமைக்கவும் figshare.com
ட்விட்டர் போன்ற பிரபலமான தலைப்பு அமைப்பை வடிவமைக்கவும் michael-noll.com
snikolov . wordpress.com
சீரற்ற ஐடி உருவாக்க அமைப்பை வடிவமைத்தல் blog.twitter.com
github.com
ஒரு நேர இடைவெளியில் மேல் k கோரிக்கைகளை திருப்பி அனுப்பவும் cs.ucsb.edu
wpi.edu
பல தரவு மையங்களில் இருந்து தரவை வழங்கும் அமைப்பை வடிவமைக்கவும் highscalability.com
ஆன்லைன் மல்டிபிளேயர் கார்டு கேமை வடிவமைக்கவும் indieflashblog.com
buildnewgames.com
குப்பை சேகரிப்பு அமைப்பை வடிவமைத்தல் stuffwithstuff.com
washington.edu
ஒரு API வீத வரம்பு https://stripe.com/blog/
ஒரு பங்குச் சந்தையை வடிவமைத்தல் (NASDAQ அல்லது Binance போன்றவை) ஜேன் ஸ்ட்ரீட்
Golang Implementation
கோ நடைமுறைப்படுத்தல்
கணினி வடிவமைப்பு கேள்வியைச் சேர் பங்களிக்கவும்

நிஜ உலக கட்டிடக்கலை

நிஜ உலக அமைப்புகள் எவ்வாறு வடிவமைக்கப்பட்டுள்ளன என்பது பற்றிய கட்டுரைகள்.


ஆதாரம்: Twitter காலவரிசைகள் அளவில்

அதற்குப் பதிலாக, பின்வரும் கட்டுரைகளுக்கு மோசமான விவரங்களில் கவனம் செலுத்த வேண்டாம்:

  • இந்தக் கட்டுரைகளில் பகிரப்பட்ட கொள்கைகள், பொதுவான தொழில்நுட்பங்கள் மற்றும் வடிவங்களைக் கண்டறியவும்
  • ஒவ்வொரு கூறுகளாலும் என்னென்ன பிரச்சனைகள் தீர்க்கப்படுகின்றன, எங்கு வேலை செய்கிறது, எங்கு இல்லை என்பதை ஆய்வு செய்யுங்கள்
  • கற்றுக்கொண்ட பாடங்களை மதிப்பாய்வு செய்யவும்
வகை அமைப்பு குறிப்பு(கள்)
தரவு செயலாக்கம் MapReduce - Google இலிருந்து விநியோகிக்கப்பட்ட தரவு செயலாக்கம் research.google.com
தரவு செயலாக்கம் Spark - Databricks இலிருந்து விநியோகிக்கப்பட்ட தரவு செயலாக்கம் slideshare.net
தரவு செயலாக்கம் புயல் - Twitter இலிருந்து விநியோகிக்கப்பட்ட தரவு செயலாக்கம் slideshare.net
டேட்டா ஸ்டோர் Bigtable - Google இலிருந்து விநியோகிக்கப்பட்ட நெடுவரிசை சார்ந்த தரவுத்தளம் harvard.edu
டேட்டா ஸ்டோர் HBase - பிக்டேபிளின் ஓப்பன் சோர்ஸ் செயல்படுத்தல் slideshare.net
டேட்டா ஸ்டோர் கசாண்ட்ரா - ஃபேஸ்புக்கில் இருந்து விநியோகிக்கப்படும் நெடுவரிசை சார்ந்த தரவுத்தளம் slideshare.net
டேட்டா ஸ்டோர் DynamoDB - அமேசானில் இருந்து ஆவணம் சார்ந்த தரவுத்தளம் harvard.edu
டேட்டா ஸ்டோர் MongoDB - ஆவணம் சார்ந்த தரவுத்தளம் slideshare.net
டேட்டா ஸ்டோர் ஸ்பேனர் - Google இலிருந்து உலகளவில் விநியோகிக்கப்படும் தரவுத்தளம் research.google.com
டேட்டா ஸ்டோர் Memcached - Distributed memory caching system slideshare.net
டேட்டா ஸ்டோர் ரெடிஸ் - நிலைத்தன்மை மற்றும் மதிப்பு வகைகளுடன் விநியோகிக்கப்பட்ட நினைவக கேச்சிங் அமைப்பு slideshare.net
கோப்பு முறைமை Google கோப்பு முறைமை (GFS) - விநியோகிக்கப்பட்ட கோப்பு முறைமை research.google.com
கோப்பு முறைமை ஹடூப் கோப்பு முறைமை (HDFS) - GFSன் ஓப்பன் சோர்ஸ் செயல்படுத்தல் apache.org
மற்றவை சப்பி - Google இலிருந்து தளர்வாக இணைக்கப்பட்ட விநியோகிக்கப்பட்ட அமைப்புகளுக்கான பூட்டு சேவை research.google.com
மற்றவை டாப்பர் - விநியோகிக்கப்பட்ட அமைப்புகள் டிரேசிங் உள்கட்டமைப்பு research.google.com
மற்றவை காஃப்கா - லிங்க்ட்இனில் இருந்து பப்/சப் மெசேஜ் வரிசை slideshare.net
மற்றவை Zookeeper - மையப்படுத்தப்பட்ட உள்கட்டமைப்பு மற்றும் ஒத்திசைவை செயல்படுத்தும் சேவைகள் slideshare.net
ஒரு கட்டிடக்கலை சேர் பங்களிக்கவும்

நிறுவன கட்டமைப்புகள்

நிறுவனம் குறிப்பு(கள்)
அமேசான் அமேசான் கட்டிடக்கலை
Cinchcast ஒவ்வொரு நாளும் 1,500 மணிநேர ஆடியோவைத் தயாரிக்கிறது
டேட்டாசிஃப்ட் நிகழ்நேர டேட்டாமைனிங் வினாடிக்கு 120,000 ட்வீட்கள்
டிராப்பாக்ஸ் நாங்கள் டிராப்பாக்ஸை எப்படி அளவிடினோம்
ESPN வினாடிக்கு 100,000 duh nuh nuhs இல் இயங்குகிறது
கூகுள் Google கட்டமைப்பு
Instagram 14 மில்லியன் பயனர்கள், டெராபைட் புகைப்படங்கள்
[இன்ஸ்டாகிராமிற்கு என்ன சக்தி](http://instagram-engineering.tumblr. com/post/13649370142/what-powers-instagram-நூற்றுக்கணக்கான நிகழ்வுகள்)
Justin.tv Justin.Tv இன் நேரடி வீடியோ ஒளிபரப்பு கட்டமைப்பு
Facebook Facebook இல் அளவிடுதல் memcached
[TAO : சமூக வரைபடத்திற்கான Facebook இன் விநியோகிக்கப்பட்ட தரவு ஸ்டோர்](https://cs.uwaterloo.ca/~brecht/courses/854-Emerging-2014/readings/data-store/tao-facebook-distributed-datastore-atc-2013. pdf)
ஃபேஸ்புக்கின் புகைப்பட சேமிப்பு
[எப்படி பேஸ்புக் லைவ் ஸ்ட்ரீம் 800,000 ஒரே நேரத்தில் பார்வையாளர்களுக்கு] (http://highscalability.com/blog/2016/6/27/how-facebook-live-streams-to-800000-simultaneous-viewers.html)
Flickr Flickr architecture
அஞ்சல் பெட்டி [6 வாரங்களில் 0 முதல் ஒரு மில்லியன் பயனர்கள் வரை](http://highscalability.com/blog/2013/6/18/scaling-mailbox-from-0-to-one-million-users-in-6-weeks- மற்றும்-1.html)
நெட்ஃபிக்ஸ் முழு நெட்ஃபிக்ஸ் ஸ்டேக்கின் 360 டிகிரி பார்வை
Netflix: Play ஐ அழுத்தினால் என்ன நடக்கும்?
Pinterest [ஒரு மாதத்திற்கு 0 முதல் 10 பில்லியன் பக்க பார்வைகள்](http://highscalability.com/blog/2013/4/15/scaling-pinterest-from-0-to-10s-of-billions-of-page- views-a.html)
[18 மில்லியன் பார்வையாளர்கள், 10x வளர்ச்சி, 12 ஊழியர்கள்](http://highscalability.com/blog/2012/5/21/pinterest-architecture-update-18-million-visitors- 10x-growth.html)
விளையாட்டு மீன் 50 மில்லியன் மாதாந்திர பயனர்கள் மற்றும் வளர்ந்து வருகின்றனர்
PlentyOfFish PlentyOfFish architecture
சேல்ஸ்ஃபோர்ஸ் ஒரு நாளைக்கு 1.3 பில்லியன் பரிவர்த்தனைகளை அவர்கள் எவ்வாறு கையாளுகிறார்கள்
ஸ்டாக் ஓவர்ஃப்ளோ ஸ்டாக் ஓவர்ஃப்ளோ ஆர்கிடெக்சர்
பயண ஆலோசகர் 40M பார்வையாளர்கள், 200M டைனமிக் பக்க பார்வைகள், 30TB தரவு
Tumblr 15 பில்லியன் பக்க பார்வைகள் ஒரு மாதம்
ட்விட்டர் ட்விட்டரை 10000 சதவீதம் வேகமாக உருவாக்குகிறது
[MySQL ஐப் பயன்படுத்தி ஒரு நாளைக்கு 250 மில்லியன் ட்வீட்களைச் சேமிக்கிறது](http://highscalability. .com/blog/2011/12/19/how-twitter-stores-250-million-tweets-a-day-using-mysql.html)
150M செயலில் உள்ள பயனர்கள், 300K QPS, 22 MB/S firehose
[காலவரிசைகள் அளவில்] (https://www.infoq.com/presentations/Twitter-Timeline-Scalability)
Twitter இல் உள்ள பெரிய மற்றும் சிறிய தரவு
Twitter இல் செயல்பாடுகள்: 100 மில்லியன் பயனர்களுக்கு அப்பால் அளவிடுதல்
[ட்விட்டர் எப்படி வினாடிக்கு 3,000 படங்களைக் கையாள்கிறது](http://highscalability. com/blog/2016/4/20/how-twitter-handles-3000-images-per-second.html)
உபெர் உபெர் அவர்களின் நிகழ்நேர சந்தை தளத்தை எவ்வாறு அளவிடுகிறது
[2000 பொறியாளர்கள், 1000 சேவைகள் மற்றும் 8000 Git களஞ்சியங்கள் வரை அளவிடுதல் Uber இலிருந்து கற்றுக்கொண்ட பாடங்கள்](http://highscalability.com/blog/2016/10/12/lessons-learned-from-scaling-uber-to-2000-engineers -1000-ser.html)
WhatsApp ஃபேஸ்புக் நிறுவனம் $19 பில்லியனுக்கு வாங்கியது
YouTube YouTube அளவிடுதல்
YouTube கட்டமைப்பு

நிறுவன பொறியியல் வலைப்பதிவுகள்

நீங்கள் நேர்காணல் செய்யும் நிறுவனங்களுக்கான கட்டிடக்கலை.

நீங்கள் சந்திக்கும் கேள்விகள் அதே டொமைனில் இருந்து இருக்கலாம்.

ஆதாரம்(கள்) மற்றும் மேலதிக வாசிப்பு

வலைப்பதிவைச் சேர்க்க விரும்புகிறீர்களா? வேலையை நகலெடுப்பதைத் தவிர்க்க, பின்வரும் ரெப்போவில் உங்கள் நிறுவனத்தின் வலைப்பதிவைச் சேர்ப்பதைக் கவனியுங்கள்:

வளர்ச்சியில் உள்ளது

ஒரு பிரிவைச் சேர்ப்பதில் ஆர்வமாக உள்ளீர்களா அல்லது செயலில் உள்ள ஒன்றை முடிக்க உதவுகிறீர்களா? பங்களிக்கவும்!

  • MapReduce உடன் விநியோகிக்கப்பட்ட கணினி
  • சீரான ஹேஷிங்
  • சிதறல் கூடும்
  • பங்களிக்கவும்

வரவுகள்

இந்த ரெப்போ முழுவதும் கடன்களும் ஆதாரங்களும் வழங்கப்படுகின்றன.

சிறப்பு நன்றிகள்:

தொடர்பு தகவல்

ஏதேனும் சிக்கல்கள், கேள்விகள் அல்லது கருத்துகளைப் பற்றி விவாதிக்க என்னைத் தொடர்புகொள்ள தயங்க வேண்டாம்.

எனது தொடர்புத் தகவலை எனது GitHub பக்கத்தில் காணலாம்.

உரிமம்

திறந்த மூல உரிமத்தின் கீழ் இந்தக் களஞ்சியத்தில் குறியீடு மற்றும் ஆதாரங்களை உங்களுக்கு வழங்குகிறேன். இது எனது தனிப்பட்ட களஞ்சியமாக இருப்பதால், எனது குறியீடு மற்றும் ஆதாரங்களுக்கு நீங்கள் பெறும் உரிமம் என்னிடமிருந்ததே தவிர எனது முதலாளி (பேஸ்புக்) அல்ல.

பதிப்புரிமை 2017 Donne Martin

கிரியேட்டிவ் காமன்ஸ் பண்புக்கூறு 4.0 சர்வதேச உரிமம் (CC BY 4.0)

http://creativecommons.org/licenses/by/4.0/