252 KiB
English ∙ 日本語 ∙ [简体中文](C ∙ 繁體中文 | العَرَبِيَّة ∙ বাংলা ∙ Português do Brasil ∙ Deutsch ∙ ελληνικά ∙ עברית ∙ Italiano ∙ 한국어 ∙ فارسی ∙ Polski ∙ русский язык ∙ Español ∙ ภาษาไทย ∙ Türkçe ∙ tiếng Việt ∙ Français . Tamil | Add Translation
Help translate this guide!
The System Design Primer | சிஸ்டம் டிசைன் ப்ரைமர்
முயற்சி
பெரிய அளவிலான அமைப்புகளை எப்படி வடிவமைப்பது என்பதை அறிக.
கணினி வடிவமைப்பு நேர்காணலுக்கான தயாரிப்பு.
பெரிய அளவிலான அமைப்புகளை எப்படி வடிவமைப்பது என்பதை அறிக
அளவிடக்கூடிய அமைப்புகளை எவ்வாறு வடிவமைப்பது என்பதைக் கற்றுக்கொள்வது, சிறந்த பொறியாளராக மாற உதவும்.
கணினி வடிவமைப்பு ஒரு பரந்த தலைப்பு. கணினி வடிவமைப்பு கொள்கைகளில் இணையம் முழுவதும் பரந்த அளவிலான வளங்கள் உள்ளன.
இந்த ரெப்போ என்பது ஒரு ஒழுங்கமைக்கப்பட்ட சேகரிப்பு ஆகும்
திறந்த மூல சமூகத்திலிருந்து கற்றுக்கொள்ளுங்கள்
இது தொடர்ந்து புதுப்பிக்கப்பட்ட, திறந்த மூல திட்டமாகும்.
பங்களிப்புகள் வரவேற்கிறோம்!
கணினி வடிவமைப்பு நேர்காணலுக்கான தயாரிப்பு
குறியீட்டு நேர்காணல்களுடன் கூடுதலாக, கணினி வடிவமைப்பு என்பது பல தொழில்நுட்ப நிறுவனங்களில் தொழில்நுட்ப நேர்காணல் செயல்முறையின் தேவையான கூறு ஆகும்.
பொதுவான சிஸ்டம் வடிவமைப்பு நேர்காணல் கேள்விகளைப் பயிற்சி செய்யவும் மற்றும் **உங்கள் முடிவுகளை மாதிரி தீர்வுகளுடன் ஒப்பிடவும்: விவாதங்கள், குறியீடு மற்றும் வரைபடங்கள்.
நேர்முகத் தயாரிப்புக்கான கூடுதல் தலைப்புகள்:
- கல்வி வழிகாட்டி
- கணினி வடிவமைப்பு நேர்காணல் கேள்வியை எவ்வாறு அணுகுவது
- System design interview questions, with solutions
- பொருள் சார்ந்த வடிவமைப்பு நேர்காணல் கேள்விகள், தீர்வுகளுடன்
- கூடுதல் கணினி வடிவமைப்பு நேர்காணல் கேள்விகள்
அங்கி ஃபிளாஷ் கார்டுகள்
பயணத்தின் போது பயன்படுத்த சிறந்தது.
குறியீட்டு ஆதாரம்: ஊடாடும் குறியீட்டு சவால்கள்
குறியீட்டு நேர்காணலுக்கு தயாராவதற்கு உங்களுக்கு உதவ ஆதாரங்களைத் தேடுகிறீர்களா?
உதவிக்கு இழுக்கும் கோரிக்கைகளைச் சமர்ப்பிக்க தயங்க வேண்டாம்:
- பிழைகளை சரிசெய்யவும்
- பிரிவுகளை மேம்படுத்தவும்
- புதிய பிரிவுகளைச் சேர்க்கவும்
- Translate சில மெருகூட்டல் தேவைப்படும் உள்ளடக்கம் [வளர்ச்சியில்] (#குறை வளர்ச்சி) வைக்கப்படுகிறது.
[பங்களிப்பு வழிகாட்டுதல்கள்] மதிப்பாய்வு செய்யவும்(CONTRIBUTING.md).
கணினி வடிவமைப்பு தலைப்புகளின் அட்டவணை
நன்மை தீமைகள் உட்பட பல்வேறு அமைப்பு வடிவமைப்பு தலைப்புகளின் சுருக்கங்கள். எல்லாமே வியாபாரம்தான்.
ஒவ்வொரு பிரிவிலும் இன்னும் ஆழமான ஆதாரங்களுக்கான இணைப்புகள் உள்ளன.
- கணினி வடிவமைப்பு தலைப்புகள்: இங்கே தொடங்கவும்
- செயல்திறன் மற்றும் அளவிடுதல்
- [லேட்டன்சி vs த்ரோபுட்](#லேட்டன்சி-வுக்கு எதிராக-த்ரூபுட்)
- [கிடைக்கும் தன்மை மற்றும் நிலைத்தன்மை]
- CAP தேற்றம்
- [CP - நிலைத்தன்மை மற்றும் பகிர்வு சகிப்புத்தன்மை](#cp---நிலைத்தன்மை மற்றும் பகிர்வு-சகிப்புத்தன்மை)
- [AP - கிடைக்கும் தன்மை மற்றும் பகிர்வு சகிப்புத்தன்மை](#ap--- கிடைக்கும் மற்றும் பகிர்வு-சகிப்புத்தன்மை)
- CAP தேற்றம்
- நிலையான வடிவங்கள்
- [கிடைக்கக்கூடிய வடிவங்கள்](#கிடைக்கக்கூடிய வடிவங்கள்)
- ஃபெயில்-ஓவர்
- பிரதி
- [எண்களில் கிடைக்கும்](#எண்களில் கிடைக்கும்)
- டொமைன் பெயர் அமைப்பு
- உள்ளடக்க விநியோக நெட்வொர்க்
- [லோட் பேலன்சர்](#லோட் பேலன்சர்)
- செயலில்-செயலற்ற
- செயலில்-செயலில்
- அடுக்கு 4 சுமை சமநிலை
- லேயர் 7 சுமை சமநிலை
- [கிடைமட்ட அளவிடுதல்](#கிடைமட்ட அளவிடுதல்)
- தலைகீழ் ப்ராக்ஸி (வலை சேவையகம்)
- பயன்பாட்டு அடுக்கு
- [மைக்ரோ சர்வீசஸ்](#மைக்ரோ சர்வீசஸ்)
- சேவை கண்டுபிடிப்பு
- தரவுத்தளம்
- தொடர்பு தரவுத்தள மேலாண்மை அமைப்பு (RDBMS)
- NoSQL
- [முக்கிய மதிப்பு கடை](#முக்கிய மதிப்பு கடை)
- [ஆவணக் கடை](#ஆவணக் கடை)
- பரந்த நெடுவரிசைக் கடை
- [வரைபட தரவுத்தளம்](#வரைபட தரவுத்தளம்)
- SQL அல்லது NoSQL
- கேச்
- கிளையண்ட் கேச்சிங்
- சிடிஎன் கேச்சிங்
- [இணைய சேவையக கேச்சிங்](#வலை சேவையகம்-கேச்சிங்)
- டேட்டாபேஸ் கேச்சிங்
- பயன்பாடு கேச்சிங்
- தரவுத்தள வினவல் மட்டத்தில் கேச்சிங்
- [பொருள் மட்டத்தில் கேச்சிங்](#பொருள்-நிலையில் கேச்சிங்)
- [தேக்ககத்தை எப்போது புதுப்பிக்க வேண்டும்](#கேச்-ஐ எப்போது புதுப்பிக்க வேண்டும்)
- அசின்க்ரோனிசம்
- செய்தி வரிசைகள்
- பணி வரிசைகள்
- [முதுகு அழுத்தம்](#முதுகு அழுத்தம்)
- தொடர்பு
- பாதுகாப்பு
- [இணைப்பு](#பின் இணைப்பு)
- [இரண்டு அட்டவணையின் அதிகாரங்கள்](#பவர்ஸ் ஆஃப் டூ டேபிள்)
- [ஒவ்வொரு புரோகிராமரும் தெரிந்து கொள்ள வேண்டிய லேட்டன்சி எண்கள்](#லேட்டன்சி-எண்கள்-ஒவ்வொரு புரோகிராமரும்-தெரிந்து கொள்ள வேண்டும்)
- கூடுதல் கணினி வடிவமைப்பு நேர்காணல் கேள்விகள்
- [உண்மையான உலக கட்டிடக்கலை](#நிஜ உலக கட்டிடக்கலை)
- நிறுவன கட்டமைப்புகள்
- நிறுவனத்தின் பொறியியல் வலைப்பதிவுகள்
- [வளர்ச்சியில் உள்ளது](#அபிவிருத்தியின் கீழ்)
- வரவுகள்
- [தொடர்புத் தகவல்](#தொடர்புத் தகவல்)
- உரிமம்
கல்வி வழிகாட்டி
உங்கள் நேர்காணல் காலவரிசையின் (குறுகிய, நடுத்தர, நீண்ட) அடிப்படையில் மதிப்பாய்வு செய்ய பரிந்துரைக்கப்பட்ட தலைப்புகள். கே: நேர்காணல்களுக்கு, நான் இங்கே அனைத்தையும் தெரிந்து கொள்ள வேண்டுமா?
ப: இல்லை, நேர்காணலுக்குத் தயாராவதற்கு நீங்கள் இங்கே அனைத்தையும் தெரிந்து கொள்ள வேண்டியதில்லை. ஒரு நேர்காணலில் உங்களிடம் கேட்கப்படுவது போன்ற மாறிகளைப் பொறுத்தது:
- உங்களுக்கு எவ்வளவு அனுபவம் இருக்கிறது
- உங்கள் தொழில்நுட்ப பின்னணி என்ன
- எந்தெந்த பதவிகளுக்கு நேர்காணல் செய்கிறீர்கள்
- எந்தெந்த நிறுவனங்களுடன் நேர்காணல் செய்கிறீர்கள்
- அதிர்ஷ்டம்
அதிக அனுபவம் வாய்ந்த விண்ணப்பதாரர்கள் பொதுவாக கணினி வடிவமைப்பைப் பற்றி மேலும் அறிந்து கொள்வார்கள் என்று எதிர்பார்க்கப்படுகிறது. தனிப்பட்ட பங்களிப்பாளர்களை விட கட்டிடக் கலைஞர்கள் அல்லது குழுத் தலைவர்கள் அதிகம் அறிந்திருப்பார்கள் என்று எதிர்பார்க்கலாம். சிறந்த தொழில்நுட்ப நிறுவனங்கள் ஒன்று அல்லது அதற்கு மேற்பட்ட வடிவமைப்பு நேர்காணல் சுற்றுகளைக் கொண்டிருக்கும்.
அகலமாகத் தொடங்கி ஒரு சில பகுதிகளில் ஆழமாகச் செல்லவும். பல்வேறு முக்கிய கணினி வடிவமைப்பு தலைப்புகளைப் பற்றி கொஞ்சம் தெரிந்துகொள்ள இது உதவுகிறது. உங்கள் காலக்கெடு, அனுபவம், எந்தெந்த பதவிகளுக்கு நேர்காணல் செய்கிறீர்கள், எந்தெந்த நிறுவனங்களுடன் நேர்காணல் செய்கிறீர்கள் என்பதன் அடிப்படையில் பின்வரும் வழிகாட்டியைச் சரிசெய்யவும்.
- குறுகிய காலவரிசை - கணினி வடிவமைப்பு தலைப்புகளுடன் அகலம்க்கான நோக்கம். சில நேர்காணல் கேள்விகளைத் தீர்ப்பதன் மூலம் பயிற்சி செய்யுங்கள்.
- நடுத்தர காலவரிசை - கணினி வடிவமைப்பு தலைப்புகளுடன் அகலம் மற்றும் சிறிது ஆழம் ஆகியவற்றை நோக்கமாகக் கொண்டது. பல நேர்காணல் கேள்விகளைத் தீர்ப்பதன் மூலம் பயிற்சி செய்யுங்கள்.
- நீண்ட காலவரிசை - கணினி வடிவமைப்பு தலைப்புகளுடன் அகலம் மற்றும் அதிக ஆழம். பெரும்பாலான நேர்காணல் கேள்விகளைத் தீர்ப்பதன் மூலம் பயிற்சி செய்யுங்கள்.
குறுகிய | நடுத்தர | நீண்ட | |
---|---|---|---|
கணினிகள் எவ்வாறு செயல்படுகின்றன என்பதைப் பற்றிய விரிவான புரிதலைப் பெற கணினி வடிவமைப்பு தலைப்புகள் மூலம் படிக்கவும் | 👍 | 👍 | 👍 |
நீங்கள் நேர்காணல் செய்யும் நிறுவனங்களுக்கான கம்பெனி இன்ஜினியரிங் வலைப்பதிவுகளில் சில கட்டுரைகளைப் படிக்கவும் | 👍 | 👍 | 👍 |
சில உண்மையான உலக கட்டிடக்கலை மூலம் படிக்கவும் | 👍 | 👍 | 👍 |
மதிப்பாய்வு கணினி வடிவமைப்பு நேர்காணல் கேள்வியை எப்படி அணுகுவது | 👍 | 👍 | 👍 |
[கணினி வடிவமைப்பு நேர்காணல் கேள்விகள் தீர்வுகளுடன்] (#system-design-interview-quesions-with-solutions) மூலம் வேலை செய்யுங்கள் | சில | பல | பெரும்பாலான |
[பொருள் சார்ந்த வடிவமைப்பு நேர்காணல் கேள்விகள் தீர்வுகளுடன்] (#பொருள் சார்ந்த வடிவமைப்பு-நேர்காணல்-கேள்விகள்-தீர்வுகளுடன்) | சில | பல | பெரும்பாலான |
மதிப்பாய்வு கூடுதல் கணினி வடிவமைப்பு நேர்காணல் கேள்விகள் | சில | பல | பெரும்பாலான |
கணினி வடிவமைப்பு நேர்காணல் கேள்வியை எவ்வாறு அணுகுவது
கணினி வடிவமைப்பு நேர்காணல் கேள்வியை எவ்வாறு சமாளிப்பது.
கணினி வடிவமைப்பு நேர்காணல் ஒரு திறந்த உரையாடலாகும். நீங்கள் அதை வழிநடத்துவீர்கள் என்று எதிர்பார்க்கப்படுகிறது.
விவாதத்தை வழிநடத்த பின்வரும் படிகளைப் பயன்படுத்தலாம். இந்த செயல்முறையை உறுதிப்படுத்த உதவ, பின்வரும் படிகளைப் பயன்படுத்தி கணினி வடிவமைப்பு நேர்காணல் கேள்விகள் தீர்வுகளுடன் பிரிவின் மூலம் வேலை செய்யுங்கள்.
படி 1: பயன்பாட்டு வழக்குகள், கட்டுப்பாடுகள் மற்றும் அனுமானங்களை கோடிட்டுக் காட்டுங்கள்
தேவைகளைச் சேகரித்து சிக்கலைக் கண்டறியவும். பயன்பாட்டு வழக்குகள் மற்றும் தடைகளைத் தெளிவுபடுத்த கேள்விகளைக் கேளுங்கள். அனுமானங்களைப் பற்றி விவாதிக்கவும்.
- அதைப் பயன்படுத்தப் போவது யார்?
- அதை எப்படிப் பயன்படுத்தப் போகிறார்கள்?
- எத்தனை பயனர்கள் உள்ளனர்?
- அமைப்பு என்ன செய்கிறது?
- கணினியின் உள்ளீடுகள் மற்றும் வெளியீடுகள் என்ன?
- எவ்வளவு டேட்டாவை கையாள வேண்டும் என்று எதிர்பார்க்கிறோம்?
- ஒரு வினாடிக்கு எத்தனை கோரிக்கைகளை எதிர்பார்க்கிறோம்? *எதிர்பார்க்கும் படிக்கும் எழுத்து விகிதம் என்ன?
படி 2: உயர்நிலை வடிவமைப்பை உருவாக்கவும்
அனைத்து முக்கிய கூறுகளுடன் உயர் மட்ட வடிவமைப்பை கோடிட்டுக் காட்டுங்கள்.
- முக்கிய கூறுகள் மற்றும் இணைப்புகளை வரையவும்
- உங்கள் எண்ணங்களை நியாயப்படுத்துங்கள்
படி 3: முக்கிய கூறுகளை வடிவமைக்கவும்
ஒவ்வொரு முக்கிய கூறுகளின் விவரங்களுக்கு முழுக்கு. எடுத்துக்காட்டாக, நீங்கள் URL சுருக்குதல் சேவையை வடிவமைக்க கேட்கப்பட்டால், விவாதிக்கவும்:
- முழு url இன் ஹாஷை உருவாக்குதல் மற்றும் சேமித்தல்
- ஹாஷ் செய்யப்பட்ட urlஐ முழு urlக்கு மொழிபெயர்த்தல்
- தரவுத்தள தேடல்
- API மற்றும் பொருள் சார்ந்த வடிவமைப்பு
படி 4: வடிவமைப்பை அளவிடவும்
தடைகளைக் கண்டறிந்து, தடைகளுக்கு தீர்வு காணவும். எடுத்துக்காட்டாக, அளவிடுதல் சிக்கல்களைத் தீர்க்க உங்களுக்கு பின்வருபவை தேவையா?
- லோட் பேலன்சர்
- கிடைமட்ட அளவிடுதல்
- கேச்சிங்
- தரவுத்தள பகிர்வு
சாத்தியமான தீர்வுகள் மற்றும் வர்த்தக பரிமாற்றங்களைப் பற்றி விவாதிக்கவும். எல்லாமே வியாபாரம்தான். [அளவிடக்கூடிய கணினி வடிவமைப்பின் கோட்பாடுகள்] (#அமைப்பு-வடிவமைப்பு-தலைப்புகளின் குறியீட்டு) பயன்படுத்தி இடையூறுகளைச் சரிசெய்யவும்.
உறையின் பின் கணக்கீடுகள்
கையால் சில மதிப்பீடுகளைச் செய்யும்படி நீங்கள் கேட்கப்படலாம். பின்வரும் ஆதாரங்களுக்கு [இணைப்பு](#பின் இணைப்பு) பார்க்கவும்:
- உறை கணக்கீடுகளின் பின்புறத்தைப் பயன்படுத்தவும்
- [இரண்டு அட்டவணையின் அதிகாரங்கள்](#பவர்ஸ் ஆஃப் டூ டேபிள்)
- [ஒவ்வொரு புரோகிராமரும் தெரிந்து கொள்ள வேண்டிய லேட்டன்சி எண்கள்](#லேட்டன்சி-எண்கள்-ஒவ்வொரு புரோகிராமரும்-தெரிந்து கொள்ள வேண்டும்)
ஆதாரம்(கள்) மற்றும் மேலதிக வாசிப்பு
என்ன எதிர்பார்க்கலாம் என்பது பற்றிய சிறந்த யோசனையைப் பெற பின்வரும் இணைப்புகளைப் பார்க்கவும்:
- கணினி வடிவமைப்பு நேர்காணலை எவ்வாறு உருவாக்குவது
- கணினி வடிவமைப்பு நேர்காணல்
- கட்டிடக்கலை மற்றும் சிஸ்டம்ஸ் வடிவமைப்பு நேர்காணலுக்கான அறிமுகம்
- கணினி வடிவமைப்பு டெம்ப்ளேட்
தீர்வுகளுடன் கூடிய சிஸ்டம் டிசைன் நேர்காணல் கேள்விகள்
மாதிரி விவாதங்கள், குறியீடு மற்றும் வரைபடங்களுடன் பொதுவான கணினி வடிவமைப்பு நேர்காணல் கேள்விகள்.
solutions/
கோப்புறையில் உள்ள உள்ளடக்கத்துடன் தீர்வுகள் இணைக்கப்பட்டுள்ளன.
கேள்வி | |
---|---|
வடிவமைப்பு Pastebin.com (அல்லது Bit.ly) | தீர்வு |
Twitter டைம்லைனை வடிவமைத்து தேடவும் (அல்லது Facebook ஊட்டம் மற்றும் தேடல்) | தீர்வு |
ஒரு வலை கிராலர் வடிவமைப்பு | தீர்வு |
வடிவமைப்பு Mint.com | தீர்வு |
ஒரு சமூக வலைப்பின்னலுக்கான தரவு கட்டமைப்புகளை வடிவமைக்கவும் | தீர்வு |
ஒரு தேடுபொறிக்கான முக்கிய மதிப்பு கடையை வடிவமைத்தல் | தீர்வு |
வகை அம்சத்தின் அடிப்படையில் Amazon இன் விற்பனை தரவரிசையை வடிவமைக்கவும் | தீர்வு |
AWS இல் மில்லியன் கணக்கான பயனர்களை அளவிடும் ஒரு அமைப்பை வடிவமைக்கவும் | தீர்வு |
சிஸ்டம் டெஸைச் சேர்க்கவும்ign கேள்வி | பங்களிக்கவும் |
வடிவமைப்பு Pastebin.com (அல்லது Bit.ly)
உடற்பயிற்சி மற்றும் தீர்வைக் காண்க
ட்விட்டர் காலவரிசையை வடிவமைத்து தேடுங்கள் (அல்லது Facebook ஊட்டம் மற்றும் தேடல்)
உடற்பயிற்சி மற்றும் தீர்வைக் காண்க
வலை கிராலரை வடிவமைக்கவும்
உடற்பயிற்சி மற்றும் தீர்வைக் காண்க
Design Mint.com
உடற்பயிற்சி மற்றும் தீர்வைக் காண்க
ஒரு சமூக வலைப்பின்னலுக்கான தரவு கட்டமைப்புகளை வடிவமைக்கவும்
உடற்பயிற்சி மற்றும் தீர்வைக் காண்க
ஒரு தேடுபொறிக்கான முக்கிய மதிப்பு கடையை வடிவமைக்கவும்
உடற்பயிற்சி மற்றும் தீர்வைக் காண்க
அமேசானின் விற்பனை தரவரிசையை வகை அம்சத்தின்படி வடிவமைக்கவும்
உடற்பயிற்சி மற்றும் தீர்வைக் காண்க
AWS இல் மில்லியன் கணக்கான பயனர்களை அளவிடும் ஒரு அமைப்பை வடிவமைக்கவும்
உடற்பயிற்சி மற்றும் தீர்வைக் காண்க
பொருள் சார்ந்த வடிவமைப்பு நேர்காணல் கேள்விகள் தீர்வுகளுடன்
மாதிரி விவாதங்கள், குறியீடு மற்றும் வரைபடங்களுடன் பொதுவான பொருள் சார்ந்த வடிவமைப்பு நேர்காணல் கேள்விகள்.
solutions/
கோப்புறையில் உள்ள உள்ளடக்கத்துடன் தீர்வுகள் இணைக்கப்பட்டுள்ளன.
குறிப்பு: இந்தப் பிரிவு வளர்ச்சியில் உள்ளது
கேள்வி | |
---|---|
ஹாஷ் வரைபடத்தை வடிவமைக்கவும் | தீர்வு |
குறைந்தது சமீபத்தில் பயன்படுத்தப்பட்ட தற்காலிக சேமிப்பை வடிவமைக்கவும் | தீர்வு |
ஒரு கால் சென்டரை வடிவமைக்கவும் | தீர்வு |
அட்டைகளின் தளத்தை வடிவமைக்கவும் | தீர்வு |
வாகன நிறுத்துமிடத்தை வடிவமைத்தல் | தீர்வு |
அரட்டை சேவையகத்தை வடிவமைக்கவும் | தீர்வு |
ஒரு வட்ட வரிசையை வடிவமைக்கவும் | பங்களிக்கவும் |
பொருள் சார்ந்த வடிவமைப்பு கேள்வியைச் சேர்க்கவும் | பங்களிக்கவும் |
கணினி வடிவமைப்பு தலைப்புகள்: இங்கே தொடங்கவும்
கணினி வடிவமைப்பில் புதியதா?
முதலில், பொதுவான கொள்கைகள், அவை என்ன, அவை எவ்வாறு பயன்படுத்தப்படுகின்றன, அவற்றின் நன்மை தீமைகள் ஆகியவற்றைப் பற்றிய அடிப்படை புரிதல் உங்களுக்குத் தேவைப்படும்.
படி 1: அளவிடுதல் வீடியோ விரிவுரையை மதிப்பாய்வு செய்யவும்
ஹார்வர்டில் அளவிடுதல் விரிவுரை
- உள்ளடக்கப்பட்ட தலைப்புகள்:
- செங்குத்து அளவிடுதல்
- கிடைமட்ட அளவிடுதல்
- கேச்சிங்
- சுமை சமநிலை
- தரவுத்தள நகல்
- தரவுத்தள பகிர்வு
படி 2: அளவிடுதல் கட்டுரையை மதிப்பாய்வு செய்யவும்
- உள்ளடக்கப்பட்ட தலைப்புகள்:
அடுத்த படிகள்
அடுத்து, உயர்நிலை வர்த்தக பரிமாற்றங்களைப் பார்ப்போம்:
- செயல்திறன் எதிராக ** அளவிடுதல்**
- தாமதம் எதிராக த்ரூபுட்
- கிடைக்கும் எதிராக நிலைத்தன்மை
எல்லாம் ஒரு பரிவர்த்தனை என்பதை நினைவில் கொள்ளுங்கள்.
பிறகு, DNS, CDNகள் மற்றும் லோட் பேலன்சர்கள் போன்ற இன்னும் குறிப்பிட்ட தலைப்புகளில் முழுக்கு போடுவோம்.
செயல்திறன் மற்றும் அளவிடுதல்
ஒரு சேவையானது அளவிடக்கூடியது அது அதிகரித்த செயல்திறன் ஆதாரங்களுக்கு விகிதாசாரமாக இருந்தால். பொதுவாக, செயல்திறனை அதிகரிப்பது என்பது அதிக வேலை அலகுகளுக்கு சேவை செய்வதாகும், ஆனால் தரவுத்தொகுப்புகள் வளரும்போது, பெரிய அளவிலான வேலைகளைக் கையாளவும் முடியும்.1
செயல்திறன் மற்றும் அளவிடுதல் ஆகியவற்றைப் பார்க்க மற்றொரு வழி:
- உங்களுக்கு செயல்திறன் சிக்கல் இருந்தால், உங்கள் கணினி ஒரு பயனருக்கு மெதுவாக இருக்கும். அளவிடுதல் சிக்கல் இருந்தால், உங்கள் கணினி ஒரு பயனருக்கு வேகமாக இருக்கும், ஆனால் அதிக சுமையின் கீழ் மெதுவாக இருக்கும்.
ஆதாரம்(கள்) மற்றும் மேலதிக வாசிப்பு
தாமதம் மற்றும் செயல்திறன்
தாமதம் என்பது சில செயல்களைச் செய்ய அல்லது சில முடிவுகளைத் தரும் நேரம்.
மூலம் என்பது ஒரு யூனிட் நேரத்திற்கு இதுபோன்ற செயல்கள் அல்லது முடிவுகளின் எண்ணிக்கை.
பொதுவாக, நீங்கள் அதிகபட்ச செயல்திறனை ஏற்றுக்கொள்ளக்கூடிய தாமதத்துடன் நோக்க வேண்டும்.
ஆதாரம்(கள்) மற்றும் மேலதிக வாசிப்பு
கிடைக்கும் தன்மை vs நிலைத்தன்மை
CAP தேற்றம்
ஆதாரம்: CAP தேற்றம் மறுபரிசீலனை செய்யப்பட்டது
விநியோகிக்கப்பட்ட கணினி அமைப்பில், பின்வரும் இரண்டு உத்தரவாதங்களை மட்டுமே நீங்கள் ஆதரிக்க முடியும்:
- நிலைத்தன்மை - ஒவ்வொரு வாசிப்பும் மிக சமீபத்திய எழுத்து அல்லது பிழையைப் பெறுகிறது
- கிடைக்கும் - ஒவ்வொரு கோரிக்கையும் பதிலைப் பெறுகிறது, அது தகவலின் சமீபத்திய பதிப்பைக் கொண்டுள்ளது என்பதற்கான உத்தரவாதம் இல்லாமல்
- பகிர்வு சகிப்புத்தன்மை - நெட்வொர்க் தோல்விகள் காரணமாக தன்னிச்சையான பகிர்வு இருந்தாலும் கணினி தொடர்ந்து இயங்குகிறது
நெட்வொர்க்குகள் நம்பகமானவை அல்ல, எனவே நீங்கள் பகிர்வு சகிப்புத்தன்மையை ஆதரிக்க வேண்டும். நிலைத்தன்மைக்கும் கிடைக்கும் தன்மைக்கும் இடையே நீங்கள் மென்பொருள் பரிமாற்றத்தை மேற்கொள்ள வேண்டும்.
CP - நிலைத்தன்மை மற்றும் பகிர்வு சகிப்புத்தன்மை
பகிர்ந்த முனையிலிருந்து பதிலுக்காகக் காத்திருப்பது காலாவதி பிழையை ஏற்படுத்தக்கூடும். உங்கள் வணிகத் தேவைகளுக்கு அணு வாசிப்பு மற்றும் எழுதுதல் தேவைப்பட்டால் CP ஒரு நல்ல தேர்வாகும்.
AP - கிடைக்கும் தன்மை மற்றும் பகிர்வு சகிப்புத்தன்மை
பதில்கள் எந்த முனையிலும் கிடைக்கும் தரவின் மிக எளிதாகக் கிடைக்கும் பதிப்பை வழங்கும், இது சமீபத்தியதாக இருக்காது. பகிர்வு தீர்க்கப்படும் போது எழுதுதல்கள் பிரச்சாரம் செய்ய சிறிது நேரம் ஆகலாம்.
வணிகத் தேவைகள் [இறுதி நிலைத்தன்மை] (#இறுதி-நிலைத்தன்மை) அல்லது வெளிப்புறப் பிழைகள் இருந்தபோதிலும் கணினி தொடர்ந்து செயல்பட வேண்டும் எனில், AP ஒரு நல்ல தேர்வாகும்.
ஆதாரம்(கள்) மற்றும் மேலதிக வாசிப்பு
- CAP தேற்றம் மறுபரிசீலனை செய்யப்பட்டது
- CAP தேற்றத்திற்கு ஒரு எளிய ஆங்கில அறிமுகம்
- CAP FAQ
- CAP தேற்றம்
நிலைத்தன்மை வடிவங்கள்
ஒரே தரவின் பல நகல்களுடன், அவற்றை எவ்வாறு ஒத்திசைக்க வேண்டும் என்பதற்கான விருப்பங்களை நாங்கள் எதிர்கொள்கிறோம், அதனால் வாடிக்கையாளர்கள் தரவைப் பற்றிய நிலையான பார்வையைப் பெறுவார்கள். 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 முடித்தல் - உள்வரும் கோரிக்கைகளை டிக்ரிப்ட் செய்து சர்வர் பதில்களை என்க்ரிப்ட் செய்யவும், எனவே பின்தள சேவையகங்கள் இந்த விலையுயர்ந்த செயல்பாடுகளைச் செய்ய வேண்டியதில்லை
- ஒவ்வொரு சர்வரிலும் X.509 சான்றிதழ்கள் நிறுவ வேண்டிய தேவையை நீக்குகிறது
- அமர்வு நிலைத்தன்மை - குக்கீகளை வழங்கவும் மற்றும் வலை பயன்பாடுகள் அமர்வுகளைக் கண்காணிக்கவில்லை என்றால், குறிப்பிட்ட கிளையண்டின் கோரிக்கைகளை அதே நிகழ்விற்கு அனுப்பவும்
தோல்விகளிலிருந்து பாதுகாக்க, பல சுமை பேலன்சர்களை செயலில்-செயலற்ற அல்லது ஆக்டிவ்-ஆக்டிவ் முறையில் அமைப்பது பொதுவானது.
சுமை பேலன்சர்கள் பல்வேறு அளவீடுகளின் அடிப்படையில் போக்குவரத்தை வழிநடத்தலாம், அவற்றுள்:
- சீரற்ற
- குறைவாக ஏற்றப்பட்டது
- அமர்வு/குக்கீகள்
- ரவுண்ட் ராபின் அல்லது எடையுள்ள ரவுண்ட் ராபின்
- அடுக்கு 4
- அடுக்கு 7
அடுக்கு 4 சுமை சமநிலை
லேயர் 4 லோட் பேலன்சர்கள் கோரிக்கைகளை எவ்வாறு விநியோகிப்பது என்பதைத் தீர்மானிக்க போக்குவரத்து அடுக்கு இல் உள்ள தகவலைப் பார்க்கிறார்கள். பொதுவாக, இது மூல, இலக்கு ஐபி முகவரிகள் மற்றும் தலைப்பில் உள்ள போர்ட்களை உள்ளடக்கியது, ஆனால் பாக்கெட்டின் உள்ளடக்கங்கள் அல்ல. லேயர் 4 லோட் பேலன்சர்கள் நெட்வொர்க் பாக்கெட்டுகளை அப்ஸ்ட்ரீம் சேவையகத்திற்கு அனுப்புகிறது.
அடுக்கு 7 சுமை சமநிலை
லேயர் 7 லோட் பேலன்சர்கள் கோரிக்கைகளை எவ்வாறு விநியோகிப்பது என்பதைத் தீர்மானிக்க பயன்பாட்டு அடுக்கு பார்க்கவும். இது தலைப்பு, செய்தி மற்றும் குக்கீகளின் உள்ளடக்கங்களை உள்ளடக்கியிருக்கலாம். லேயர் 7 லோட் பேலன்சர்கள் நெட்வொர்க் ட்ராஃபிக்கை நிறுத்துகின்றன, செய்தியைப் படிக்கின்றன, சுமை சமநிலை முடிவை எடுக்கின்றன, பின்னர் தேர்ந்தெடுக்கப்பட்ட சேவையகத்திற்கான இணைப்பைத் திறக்கின்றன. எடுத்துக்காட்டாக, லேயர் 7 லோட் பேலன்சர் வீடியோ டிராஃபிக்கை வீடியோக்களை ஹோஸ்ட் செய்யும் சேவையகங்களுக்கு வழிநடத்தும் அதே வேளையில் அதிக உணர்திறன் வாய்ந்த பயனர் பில்லிங் போக்குவரத்தை பாதுகாப்பு-கடினப்படுத்தப்பட்ட சேவையகங்களுக்கு இயக்குகிறது.
நெகிழ்வுத்தன்மையின் விலையில், அடுக்கு 4 சுமை சமநிலைக்கு லேயர் 7 ஐ விட குறைவான நேரமும் கணினி வளங்களும் தேவைப்படுகின்றன, இருப்பினும் செயல்திறன் தாக்கம் நவீன கமாடிட்டி வன்பொருளில் குறைவாகவே இருக்கும்.
கிடைமட்ட அளவிடுதல்
லோட் பேலன்சர்கள் கிடைமட்ட அளவீடு, செயல்திறன் மற்றும் கிடைக்கும் தன்மையை மேம்படுத்தவும் உதவும். வெர்டிகல் ஸ்கேலிங் எனப்படும் அதிக விலையுயர்ந்த வன்பொருளில் ஒற்றை சர்வரை அளவிடுவதை விட, கமாடிட்டி மெஷின்களைப் பயன்படுத்தி அளவிடுதல் அதிக செலவுத் திறன் கொண்டது மற்றும் அதிக கிடைக்கும் தன்மையை விளைவிக்கிறது. சிறப்பு நிறுவன அமைப்புகளை விட கமாடிட்டி ஹார்டுவேரில் பணிபுரியும் திறமைசாலிகளை பணியமர்த்துவதும் எளிதானது.
குறைபாடு(கள்): கிடைமட்ட அளவிடுதல்
- கிடைமட்டமாக அளவிடுதல் சிக்கலான தன்மையை அறிமுகப்படுத்துகிறது மற்றும் குளோனிங் சர்வர்களை உள்ளடக்கியது
- சேவையகங்கள் நிலையற்றதாக இருக்க வேண்டும்: அவை அமர்வுகள் அல்லது சுயவிவரப் படங்கள் போன்ற பயனர் தொடர்பான எந்தத் தரவையும் கொண்டிருக்கக்கூடாது
- அமர்வுகள் டேட்டாபேஸ் (SQL, NoSQL) அல்லது ஒரு நிலையான கேச் (ரெடிஸ், மெம்கேச்) போன்ற மையப்படுத்தப்பட்ட தரவு சேமிப்பகத்தில் சேமிக்கப்படும்.
-
- கீழ்நிலை சேவையகங்களான கேச்கள் மற்றும் தரவுத்தளங்கள், அப்ஸ்ட்ரீம் சர்வர்கள் அளவிடப்படுவதால் ஒரே நேரத்தில் அதிக இணைப்புகளைக் கையாள வேண்டும்
குறைபாடு(கள்): சுமை சமநிலை
- லோட் பேலன்சர் போதுமான ஆதாரங்களைக் கொண்டிருக்கவில்லை என்றாலோ அல்லது சரியாக உள்ளமைக்கப்படாமல் இருந்தாலோ செயல்திறன் தடையாக மாறும்.
- ஒரு தோல்வியின் ஒரு புள்ளியை அகற்ற உதவும் ஒரு சுமை சமநிலையை அறிமுகப்படுத்துவது சிக்கலான தன்மையை அதிகரிக்கிறது.
- ஒரு ஒற்றை சுமை சமநிலையானது தோல்வியின் ஒரு புள்ளியாகும், பல சுமை சமநிலையாளர்களை கட்டமைப்பது சிக்கலை மேலும் அதிகரிக்கிறது.
ஆதாரம்(கள்) மற்றும் மேலதிக வாசிப்பு
- NGINX கட்டிடக்கலை
- HAProxy கட்டிடக்கலை வழிகாட்டி
- அளவிடுதல்
- விக்கிபீடியா
- அடுக்கு 4 சுமை சமநிலை
- லேயர் 7 சுமை சமநிலை
- ELB கேட்பவர் கட்டமைப்பு
ரிவர்ஸ் ப்ராக்ஸி (வலை சேவையகம்)
தலைகீழ் ப்ராக்ஸி என்பது ஒரு இணைய சேவையகமாகும், இது உள் சேவைகளை மையப்படுத்துகிறது மற்றும் பொதுமக்களுக்கு ஒருங்கிணைந்த இடைமுகங்களை வழங்குகிறது. கிளையண்டுகளிடமிருந்து வரும் கோரிக்கைகள், சேவையகத்திற்கு ரிவர்ஸ் ப்ராக்ஸி சேவையகத்தின் பதிலை வழங்கும் முன், அதை நிறைவேற்றக்கூடிய சர்வருக்கு அனுப்பப்படும்.
கூடுதல் நன்மைகள் அடங்கும்:
- அதிகரித்த பாதுகாப்பு - பின்தள சேவையகங்கள், பிளாக்லிஸ்ட் ஐபிகள், ஒரு கிளையண்டிற்கான இணைப்புகளின் வரம்பு பற்றிய தகவல்களை மறை
- அதிகரிப்பு மற்றும் நெகிழ்வுத்தன்மை - வாடிக்கையாளர்கள் ரிவர்ஸ் ப்ராக்ஸியின் ஐபியை மட்டுமே பார்க்கிறார்கள், இது உங்களை சர்வர்களை அளவிட அல்லது அவற்றின் உள்ளமைவை மாற்ற அனுமதிக்கிறது.
- SSL முடித்தல் - உள்வரும் கோரிக்கைகளை டிக்ரிப்ட் செய்து சர்வர் பதில்களை என்க்ரிப்ட் செய்யவும், எனவே பின்தள சேவையகங்கள் இந்த விலையுயர்ந்த செயல்பாடுகளைச் செய்ய வேண்டியதில்லை
- ஒவ்வொரு சர்வரிலும் X.509 சான்றிதழ்கள் நிறுவ வேண்டிய தேவையை நீக்குகிறது
- அமுக்கம் - சர்வர் பதில்களை சுருக்கவும்
- கேச்சிங் - கேச் செய்யப்பட்ட கோரிக்கைகளுக்கான பதிலைத் திருப்பி அனுப்பவும்
- நிலையான உள்ளடக்கம் - நிலையான உள்ளடக்கத்தை நேரடியாக வழங்கவும்
- 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 என குறிப்பிடப்படுகின்றன, இது தரவை வரிசைப்படுத்துகிறது மற்றும் மடக்கை நேரத்தில் தேடல்கள், வரிசை அணுகல், செருகல்கள் மற்றும் நீக்குதல்களை அனுமதிக்கிறது.
- ஒரு குறியீட்டை வைப்பதன் மூலம் தரவை நினைவகத்தில் வைத்திருக்க முடியும், அதிக இடம் தேவைப்படுகிறது.
- குறியீட்டையும் புதுப்பிக்க வேண்டியிருப்பதால் எழுதுவதும் மெதுவாக இருக்கலாம்.
- அதிக அளவிலான தரவை ஏற்றும்போது, குறியீடுகளை முடக்குவது, தரவை ஏற்றுவது, பின்னர் குறியீடுகளை மீண்டும் உருவாக்குவது ஆகியவை வேகமாக இருக்கும்.
விலையுயர்ந்த இணைப்புகளைத் தவிர்க்கவும்
- டிநார்மலைஸ் செயல்திறன் கோரும் இடத்தில்.
பகிர்வு அட்டவணைகள்
- தனி டேபிளில் ஹாட் ஸ்பாட்களை வைத்து டேபிளை உடைத்து அதை நினைவகத்தில் வைத்திருக்க உதவும்.
வினவல் தற்காலிக சேமிப்பை டியூன் செய்யவும்
- சில சமயங்களில், வினவல் கேச் செயல்திறன் சிக்கல்களுக்கு வழிவகுக்கும் .com/blog/2016/10/12/mysql-5-7-performance-tuning-immediately-after-installation/).
மூல(கள்) மற்றும் மேலதிக வாசிப்பு: SQL ட்யூனிங்
- MySQL வினவல்களை மேம்படுத்துவதற்கான உதவிக்குறிப்புகள்
- [VARCHAR(255) அடிக்கடி பயன்படுத்தப்படுவதை நான் பார்க்க நல்ல காரணம் உள்ளதா?](http://stackoverflow.com/questions/1217466/is-there-a-good-reason-i-see-varchar255-used-so -அடிக்கடி-எதிராக-மற்றொரு-எல்)
- பூஜ்ய மதிப்புகள் செயல்திறனை எவ்வாறு பாதிக்கின்றன?
- மெதுவான வினவல் பதிவு
NoSQL
NoSQL என்பது முக்கிய மதிப்பு அங்காடி, ஆவண ஸ்டோர், பரந்த நெடுவரிசைக் கடை அல்லது **வரைபட தரவுத்தளத்தில் குறிப்பிடப்படும் தரவு உருப்படிகளின் தொகுப்பாகும். தரவு இயல்பற்றது, மேலும் இணைப்பது பொதுவாக பயன்பாட்டுக் குறியீட்டில் செய்யப்படுகிறது. பெரும்பாலான NoSQL கடைகளில் உண்மையான ACID பரிவர்த்தனைகள் இல்லை மற்றும் இறுதி நிலைத்தன்மை.
BASE பெரும்பாலும் NoSQL தரவுத்தளங்களின் பண்புகளை விவரிக்கப் பயன்படுகிறது. CAP தேற்றம் உடன் ஒப்பிடுகையில், BASE ஆனது நிலைத்தன்மைக்கு மேல் கிடைப்பதைத் தேர்ந்தெடுக்கிறது.
- அடிப்படையில் கிடைக்கும் - கணினி கிடைப்பதற்கு உத்தரவாதம் அளிக்கிறது.
- மென்மையான நிலை - கணினியின் நிலை உள்ளீடு இல்லாமல் கூட காலப்போக்கில் மாறலாம்.
- இறுதி நிலைத்தன்மை - அந்த காலகட்டத்தில் கணினி உள்ளீட்டைப் பெறாததால், ஒரு குறிப்பிட்ட காலத்திற்கு கணினி சீராக மாறும்.
SQL அல்லது NoSQL ஆகியவற்றிற்கு இடையே தேர்ந்தெடுப்பதைத் தவிர, எந்த வகையான NoSQL தரவுத்தளமானது உங்கள் பயன்பாட்டு வழக்கு(களுக்கு) மிகவும் பொருத்தமானது என்பதைப் புரிந்துகொள்வது உதவியாக இருக்கும். அடுத்த பகுதியில் முக்கிய மதிப்புக் கடைகள், ஆவணக் கடைகள், ** பரந்த நெடுவரிசைக் கடைகள்** மற்றும் வரைபட தரவுத்தளங்கள் ஆகியவற்றை மதிப்பாய்வு செய்வோம்.
முக்கிய மதிப்பு கடை
சுருக்கம்: ஹாஷ் அட்டவணை
ஒரு முக்கிய மதிப்பு அங்காடி பொதுவாக O(1) படிக்கவும் எழுதவும் அனுமதிக்கிறது மற்றும் பெரும்பாலும் நினைவகம் அல்லது SSD மூலம் ஆதரிக்கப்படுகிறது. தரவு அங்காடிகள் விசைகளை லெக்சிகோகிராஃபிக் வரிசையில் பராமரிக்க முடியும், இது முக்கிய வரம்புகளை திறமையாக மீட்டெடுக்க அனுமதிக்கிறது. முக்கிய மதிப்பு அங்காடிகள் மெட்டாடேட்டாவை மதிப்புடன் சேமிக்க அனுமதிக்கும்.
முக்கிய மதிப்பு அங்காடிகள் உயர் செயல்திறனை வழங்குகின்றன, மேலும் அவை எளிய தரவு மாதிரிகள் அல்லது இன்-மெமரி கேச் லேயர் போன்ற வேகமாக மாறும் தரவுகளுக்குப் பயன்படுத்தப்படுகின்றன. அவை வரையறுக்கப்பட்ட செயல்பாடுகளை மட்டுமே வழங்குவதால், கூடுதல் செயல்பாடுகள் தேவைப்பட்டால், சிக்கலானது பயன்பாட்டு அடுக்குக்கு மாற்றப்படும்.
ஒரு முக்கிய மதிப்பு அங்காடி என்பது ஆவணக் கடை மற்றும் சில சந்தர்ப்பங்களில் வரைபட தரவுத்தளம் போன்ற மிகவும் சிக்கலான அமைப்புகளுக்கு அடிப்படையாகும்.
மூல(கள்) மற்றும் மேலதிக வாசிப்பு: முக்கிய மதிப்பு அங்காடி
- [விசை-மதிப்பு
- இ தரவுத்தளம்](https://en.wikipedia.org/wiki/Key-value_database)
- முக்கிய மதிப்பு கடைகளின் தீமைகள்
- ரெடிஸ் கட்டிடக்கலை
- Memcached architecture
ஆவணக் கடை
சுருக்கம்: மதிப்புகளாக சேமிக்கப்பட்ட ஆவணங்களுடன் முக்கிய மதிப்பு ஸ்டோர்
ஒரு ஆவணக் கடையானது ஆவணங்களை மையமாகக் கொண்டது (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
- அடிப்படை சொற்களின் விளக்கம்
- NoSQL தரவுத்தளங்கள் ஒரு கணக்கெடுப்பு மற்றும் முடிவு வழிகாட்டுதல்
- அளவிடுதல்
- NoSQL அறிமுகம்
- 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 ஐச் சேர்ப்பது போன்ற பயன்பாட்டு மாற்றங்களைச் செய்ய வேண்டும்.
ஆதாரம்(கள்) மற்றும் மேலதிக வாசிப்பு
- கேச் முதல் இன்-மெமரி டேட்டா கிரிட் வரை
- அளவிடக்கூடிய கணினி வடிவமைப்பு வடிவங்கள்
- அளவிலான கட்டிடக்கலை அமைப்புகளுக்கான அறிமுகம்
- அளவிடுதல், கிடைக்கும் தன்மை, நிலைப்புத்தன்மை, வடிவங்கள்
- அளவிடுதல்
- AWS ElastiCache உத்திகள்
- விக்கிபீடியா
ஒத்திசைவு
ஆதாரம்: அளவிற்கான கட்டிடக்கலை அமைப்புகளுக்கான அறிமுகம்
ஒத்திசைவற்ற பணிப்பாய்வுகள் விலையுயர்ந்த செயல்பாடுகளுக்கான கோரிக்கை நேரங்களைக் குறைக்க உதவுகின்றன, இல்லையெனில் அவை இன்-லைனில் செய்யப்படும். அவர்கள் நேரத்தைச் செலவழிக்கும் வேலையை, குறிப்பிட்ட கால இடைவெளியில் தரவு திரட்டுதல் போன்றவற்றைச் செய்வதன் மூலமும் உதவலாம்.
செய்தி வரிசைகள்
செய்தி வரிசைகள் செய்திகளைப் பெறுகின்றன, வைத்திருக்கின்றன மற்றும் வழங்குகின்றன. ஒரு செயல்பாடு இன்லைனில் செய்ய மிகவும் மெதுவாக இருந்தால், பின்வரும் பணிப்பாய்வுகளுடன் செய்தி வரிசையைப் பயன்படுத்தலாம்:
- ஒரு பயன்பாடு ஒரு வேலையை வரிசையில் வெளியிடுகிறது, பின்னர் வேலை நிலையைப் பயனருக்குத் தெரிவிக்கிறது
- ஒரு தொழிலாளி வரிசையிலிருந்து வேலையை எடுத்துக்கொள்கிறார், அதைச் செயல்படுத்துகிறார், பிறகு வேலை முடிந்தது என்று சமிக்ஞை செய்கிறார்
பயனர் தடுக்கப்படவில்லை மற்றும் வேலை பின்னணியில் செயல்படுத்தப்படுகிறது. இந்த நேரத்தில், கிளையன்ட் விருப்பமாக ஒரு சிறிய அளவிலான செயலாக்கத்தைச் செய்து, பணி முடிந்துவிட்டது போல் தோன்றும். எடுத்துக்காட்டாக, ஒரு ட்வீட்டை இடுகையிட்டால், ட்வீட் உடனடியாக உங்கள் டைம்லைனில் இடுகையிடப்படலாம், ஆனால் உங்கள் ட்வீட் உண்மையில் உங்களைப் பின்தொடர்பவர்கள் அனைவருக்கும் வழங்குவதற்கு சிறிது நேரம் ஆகலாம்.
Redis ஒரு எளிய செய்தி தரகராக பயனுள்ளதாக இருக்கும், ஆனால் செய்திகளை இழக்கலாம்.
RabbitMQ பிரபலமானது, ஆனால் நீங்கள் 'AMQP' நெறிமுறைக்கு ஏற்ப மற்றும் உங்கள் சொந்த முனைகளை நிர்வகிக்க வேண்டும்.
Amazon SQS ஹோஸ்ட் செய்யப்பட்டுள்ளது, ஆனால் அதிக தாமதம் மற்றும் செய்திகள் இருமுறை வழங்கப்படுவதற்கான சாத்தியக்கூறுகள் உள்ளன.
பணி வரிசைகள்
பணிகளின் வரிசைகள் பணிகள் மற்றும் அவற்றின் தொடர்புடைய தரவைப் பெறுகின்றன, அவற்றை இயக்குகின்றன, பின்னர் அவற்றின் முடிவுகளை வழங்குகின்றன. அவர்கள் திட்டமிடலை ஆதரிக்கலாம் மற்றும் பின்னணியில் கணக்கீட்டு-தீவிர வேலைகளை இயக்க பயன்படுத்தலாம்.
Celery திட்டமிடலுக்கான ஆதரவைக் கொண்டுள்ளது மற்றும் முதன்மையாக பைதான் ஆதரவைக் கொண்டுள்ளது.
பின் அழுத்தம்
வரிசைகள் கணிசமாக வளரத் தொடங்கினால், வரிசை அளவு நினைவகத்தை விட பெரியதாகிவிடும், இதன் விளைவாக கேச் மிஸ், டிஸ்க் ரீட் மற்றும் மெதுவான செயல்திறன் போன்றவை ஏற்படும். முதுகு அழுத்தம் வரிசையின் அளவைக் கட்டுப்படுத்தி, அதிக செயல்திறன் வீதத்தையும் நல்ல பதிலையும் பராமரிக்க உதவுகிறது ஏற்கனவே வரிசையில் உள்ள வேலைகளுக்கான நேரங்கள். வரிசை நிரம்பியதும், வாடிக்கையாளர்கள் பிஸியாக உள்ள சர்வர் அல்லது HTTP 503 நிலைக் குறியீட்டைப் பெறுவார்கள். வாடிக்கையாளர்கள் பின்னர் கோரிக்கையை மீண்டும் முயற்சிக்கலாம், ஒருவேளை அதிவேக பேக்ஆஃப்.
குறைபாடு(கள்): ஒத்திசைவு
- விலையில்லா கணக்கீடுகள் மற்றும் நிகழ்நேர வேலைப்பாய்வுகள் போன்றவற்றைப் பயன்படுத்துவது ஒத்திசைவான செயல்பாடுகளுக்கு மிகவும் பொருத்தமானதாக இருக்கும், ஏனெனில் வரிசைகளை அறிமுகப்படுத்துவது தாமதங்களையும் சிக்கலையும் சேர்க்கலாம்.
ஆதாரம்(கள்) மற்றும் மேலதிக வாசிப்பு
- இது அனைத்தும் எண்கள் விளையாட்டு
- ஓவர்லோட் செய்யும்போது பின் அழுத்தத்தைப் பயன்படுத்துதல்
- லிட்டில்ஸ் சட்டம்
- [செய்தி வரிசைக்கும் பணி வரிசைக்கும் என்ன வித்தியாசம்?](https://www.quora.com/What-is-the-difference-between-a-message-queue-and-a-task-queue -ஏன்-ஒரு-பணி-வரிசை-ஒரு-செய்தி-தரகர்-போன்ற-RabbitMQ-Redis-Celery-அல்லது-IronMQ-க்கு-செயல்பட வேண்டும்)
தொடர்பு
ஹைபர்டெக்ஸ்ட் பரிமாற்ற நெறிமுறை (HTTP)
HTTP என்பது ஒரு கிளையன்ட் மற்றும் சர்வர் இடையே தரவை குறியாக்கம் செய்து கொண்டு செல்வதற்கான ஒரு முறையாகும். இது ஒரு கோரிக்கை/பதில் நெறிமுறை: வாடிக்கையாளர்கள் கோரிக்கைகளை வழங்குகிறார்கள் மற்றும் சேவையகங்கள் கோரிக்கை பற்றிய தொடர்புடைய உள்ளடக்கம் மற்றும் நிறைவு நிலை தகவலுடன் பதில்களை வழங்குகின்றன. HTTP ஆனது சுயமாக உள்ளது, இது பல இடைநிலை திசைவிகள் மற்றும் சேவையகங்கள் வழியாக கோரிக்கைகள் மற்றும் பதில்களை அனுமதிக்கிறது, அவை சுமை சமநிலை, கேச்சிங், குறியாக்கம் மற்றும் சுருக்கம் ஆகியவற்றைச் செய்கின்றன.
ஒரு அடிப்படை HTTP கோரிக்கை ஒரு வினைச்சொல் (முறை) மற்றும் ஒரு ஆதாரம் (இறுதிப்புள்ளி) ஆகியவற்றைக் கொண்டுள்ளது. கீழே பொதுவான HTTP வினைச்சொற்கள் உள்ளன:
வினை | விளக்கம் | ஐடெம்போடென்ட்* | பாதுகாப்பான | Cacheable |
---|---|---|---|---|
பெற | ஒரு ஆதாரத்தைப் படிக்கிறது | ஆம் | ஆம் | ஆம் |
பதவி | ஒரு ஆதாரத்தை உருவாக்குகிறது அல்லது தரவைக் கையாளும் செயல்முறையைத் தூண்டுகிறது | இல்லை | இல்லை | ஆம், பதிலில் புத்துணர்ச்சி தகவல் இருந்தால் |
போடு | ஒரு வளத்தை உருவாக்குகிறது அல்லது மாற்றுகிறது | ஆம் | இல்லை | இல்லை |
இணைப்பு | ஒரு வளத்தை ஓரளவு புதுப்பிக்கிறது | இல்லை | இல்லை | ஆம், பதிலில் புத்துணர்ச்சி தகவல் இருந்தால் |
நீக்கு | ஒரு ஆதாரத்தை நீக்குகிறது | ஆம் | இல்லை | இல்லை |
- வேறுபட்ட முடிவுகள் இல்லாமல் பல முறை அழைக்கப்படலாம்.
HTTP என்பது TCP மற்றும் UDP போன்ற கீழ்-நிலை நெறிமுறைகளை நம்பியிருக்கும் ஒரு பயன்பாட்டு அடுக்கு நெறிமுறையாகும்.
மூல(கள்) மற்றும் மேலதிக வாசிப்பு: HTTP
- HTTP என்றால் என்ன?
- HTTP மற்றும் TCP இடையே உள்ள வேறுபாடு
- [PUT மற்றும் PATCH இடையே உள்ள வேறுபாடு](https://laracasts.com/discuss/channels/பொது-கலந்துரையாடல்/புட்டு-மற்றும்-பேட்ச் இடையே என்ன வேறுபாடுகள்?பக்கம்=1)
டிரான்ஸ்மிஷன் கண்ட்ரோல் புரோட்டோகால் (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
- கேம் நிரலாக்கத்திற்கான நெட்வொர்க்கிங்
- TCP மற்றும் UDP நெறிமுறைகளுக்கு இடையிலான முக்கிய வேறுபாடுகள்
- டிசிபி மற்றும் யுடிபி இடையே உள்ள வேறுபாடு
- பரபரப்பு கட்டுப்பாட்டு நெறிமுறை
- பயனர் டேட்டாகிராம் புரோட்டோகால்
- Facebook இல் memcache அளவிடுதல்
தொலை நடைமுறை அழைப்பு (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
- ஆர்.பி.சியை விட நீங்கள் ஏன் ஓய்வை விரும்புகிறீர்கள் என்று உங்களுக்குத் தெரியுமா
- RESTயை விட RPC-ish அணுகுமுறைகள் எப்போது மிகவும் பொருத்தமானவை?
- REST vs JSON-RPC
- RPC மற்றும் REST பற்றிய கட்டுக்கதைகளை நீக்குதல்
- REST ஐப் பயன்படுத்துவதில் உள்ள குறைபாடுகள் என்ன
- கணினி வடிவமைப்பு நேர்காணலை சிதைக்கவும்
- சிக்கன
- ஆர்.பி.சி அல்ல, உள் பயன்பாட்டிற்கு ஏன் ஓய்வெடுக்க வேண்டும்
பாதுகாப்பு
இந்தப் பிரிவு சில புதுப்பிப்புகளைப் பயன்படுத்தலாம். கருத்தில் பங்களிப்பை!
பாதுகாப்பு என்பது ஒரு பரந்த தலைப்பு. உங்களுக்கு கணிசமான அனுபவம், பாதுகாப்பு பின்னணி அல்லது பாதுகாப்பு பற்றிய அறிவு தேவைப்படும் பதவிக்கு விண்ணப்பிக்கும் வரை, நீங்கள் அடிப்படைகளை விட அதிகமாக தெரிந்து கொள்ள வேண்டிய அவசியமில்லை:
- போக்குவரத்திலும் ஓய்விலும் குறியாக்கம் செய்யுங்கள்.
- 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 சுற்றுப் பயணங்கள்
தாமத எண்கள் காட்சிப்படுத்தப்பட்டன
ஆதாரம்(கள்) மற்றும் மேலதிக வாசிப்பு
- ஒவ்வொரு புரோகிராமரும் தெரிந்து கொள்ள வேண்டிய தாமத எண்கள் - 1
- ஒவ்வொரு புரோகிராமரும் தெரிந்து கொள்ள வேண்டிய தாமத எண்கள் - 2
- [வடிவமைப்புகள், பாடங்கள் மற்றும் bui இலிருந்து ஆலோசனை
- பெரிய விநியோகிக்கப்பட்ட அமைப்புகள்](http://www.cs.cornell.edu/projects/ladis2009/talks/dean-keynote-ladis2009.pdf)
- பெரிய அளவிலான விநியோகிக்கப்பட்ட அமைப்புகளை உருவாக்குவதற்கான மென்பொருள் பொறியியல் ஆலோசனை
கூடுதல் கணினி வடிவமைப்பு நேர்காணல் கேள்விகள்
பொதுவான கணினி வடிவமைப்பு நேர்காணல் கேள்விகள், ஒவ்வொன்றையும் எவ்வாறு தீர்ப்பது என்பதற்கான ஆதாரங்களுக்கான இணைப்புகள்.
கேள்வி | குறிப்பு(கள்) |
---|---|
டிராப்பாக்ஸ் | போன்ற கோப்பு ஒத்திசைவு சேவையை வடிவமைக்கவும் 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 |
போன்ற அரட்டை செயலியை வடிவமைக்கவும் highscalability.com | |
போன்ற படப் பகிர்வு அமைப்பை வடிவமைத்தல் | |
பேஸ்புக் செய்தி ஊட்ட செயல்பாட்டை வடிவமைக்கவும் | 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 |
ஒரு கட்டிடக்கலை சேர் | பங்களிக்கவும் |
நிறுவன கட்டமைப்புகள்
நிறுவன பொறியியல் வலைப்பதிவுகள்
நீங்கள் நேர்காணல் செய்யும் நிறுவனங்களுக்கான கட்டிடக்கலை.
நீங்கள் சந்திக்கும் கேள்விகள் அதே டொமைனில் இருந்து இருக்கலாம்.
- Airbnb பொறியியல்
- அட்லாசியன் டெவலப்பர்கள்
- AWS வலைப்பதிவு
- பிட்லி இன்ஜினியரிங் வலைப்பதிவு
- பெட்டி வலைப்பதிவுகள்
- Cloudera டெவலப்பர் வலைப்பதிவு
- டிராப்பாக்ஸ் தொழில்நுட்ப வலைப்பதிவு
- கோராவில் பொறியியல்
- ஈபே தொழில்நுட்ப வலைப்பதிவு
- ஈவ்rnote Tech Blog
- எட்ஸி கோட் கைவினை
- பேஸ்புக் பொறியியல்
- Flickr குறியீடு
- Foursquare Engineering Blog
- GitHub பொறியியல் வலைப்பதிவு
- Google ஆராய்ச்சி வலைப்பதிவு
- குரூப்பன் இன்ஜினியரிங் வலைப்பதிவு
- Heroku பொறியியல் வலைப்பதிவு
- ஹப்ஸ்பாட் இன்ஜினியரிங் வலைப்பதிவு
- உயர் அளவீடு
- Instagram பொறியியல்
- இன்டெல் மென்பொருள் வலைப்பதிவு
- ஜேன் ஸ்ட்ரீட் டெக் வலைப்பதிவு
- LinkedIn Engineering
- மைக்ரோசாப்ட் இன்ஜினியரிங்
- மைக்ரோசாப்ட் பைதான் இன்ஜினியரிங்
- நெட்ஃபிக்ஸ் தொழில்நுட்ப வலைப்பதிவு
- பேபால் டெவலப்பர் வலைப்பதிவு
- Pinterest பொறியியல் வலைப்பதிவு
- ரெடிட் வலைப்பதிவு
- சேல்ஸ்ஃபோர்ஸ் இன்ஜினியரிங் வலைப்பதிவு
- ஸ்லாக் இன்ஜினியரிங் வலைப்பதிவு
- Spotify Labs
- ட்விலியோ இன்ஜினியரிங் வலைப்பதிவு
- ட்விட்டர் பொறியியல்
- Uber Engineering Blog
- யாகூ பொறியியல் வலைப்பதிவு
- Yelp பொறியியல் வலைப்பதிவு
- ஜிங்கா பொறியியல் வலைப்பதிவு
ஆதாரம்(கள்) மற்றும் மேலதிக வாசிப்பு
வலைப்பதிவைச் சேர்க்க விரும்புகிறீர்களா? வேலையை நகலெடுப்பதைத் தவிர்க்க, பின்வரும் ரெப்போவில் உங்கள் நிறுவனத்தின் வலைப்பதிவைச் சேர்ப்பதைக் கவனியுங்கள்:
வளர்ச்சியில் உள்ளது
ஒரு பிரிவைச் சேர்ப்பதில் ஆர்வமாக உள்ளீர்களா அல்லது செயலில் உள்ள ஒன்றை முடிக்க உதவுகிறீர்களா? பங்களிக்கவும்!
- MapReduce உடன் விநியோகிக்கப்பட்ட கணினி
- சீரான ஹேஷிங்
- சிதறல் கூடும்
- பங்களிக்கவும்
வரவுகள்
இந்த ரெப்போ முழுவதும் கடன்களும் ஆதாரங்களும் வழங்கப்படுகின்றன.
சிறப்பு நன்றிகள்:
- தொழில்நுட்பத்தில் பணியமர்த்தப்பட்டவர்
- குறியீட்டு நேர்காணலை சிதைத்தல்
- உயர் அளவிடுதல்
- checkcheckzz/system-design-interview
- shashank88/system_design
- mmcgrana/services-engineering
- கணினி வடிவமைப்பு ஏமாற்று தாள்
- விநியோகிக்கப்பட்ட அமைப்புகளின் வாசிப்பு பட்டியல்
- கணினி வடிவமைப்பு நேர்காணலை சிதைத்தல்
தொடர்பு தகவல்
ஏதேனும் சிக்கல்கள், கேள்விகள் அல்லது கருத்துகளைப் பற்றி விவாதிக்க என்னைத் தொடர்புகொள்ள தயங்க வேண்டாம்.
எனது தொடர்புத் தகவலை எனது GitHub பக்கத்தில் காணலாம்.
உரிமம்
திறந்த மூல உரிமத்தின் கீழ் இந்தக் களஞ்சியத்தில் குறியீடு மற்றும் ஆதாரங்களை உங்களுக்கு வழங்குகிறேன். இது எனது தனிப்பட்ட களஞ்சியமாக இருப்பதால், எனது குறியீடு மற்றும் ஆதாரங்களுக்கு நீங்கள் பெறும் உரிமம் என்னிடமிருந்ததே தவிர எனது முதலாளி (பேஸ்புக்) அல்ல.
பதிப்புரிமை 2017 Donne Martin
கிரியேட்டிவ் காமன்ஸ் பண்புக்கூறு 4.0 சர்வதேச உரிமம் (CC BY 4.0)
http://creativecommons.org/licenses/by/4.0/