নতুন নতুন ভুল করা আমি এখন প্রায় 15 বছর ধরে একজন সফটওয়্যার ইঞ্জিনিয়ার হয়েছি। আমার কর্মজীবন জুড়ে আমি অনেক কিছু শিখেছি এবং এই শিক্ষাগুলিকে অনেকগুলি বিতরণ করা সিস্টেম ডিজাইন এবং বাস্তবায়নে প্রয়োগ করেছি (এবং মাঝে মাঝে ফেজ আউট বা ত্যাগ করি)। সেই পথে আমি অসংখ্য ভুল করেছি এবং এখনও করে যাচ্ছি। কিন্তু আমার প্রধান ফোকাস ছিল নির্ভরযোগ্যতা হিসাবে আমি ত্রুটি ফ্রিকোয়েন্সি হ্রাস করার উপায় খুঁজে বের করার জন্য আমার অভিজ্ঞতা এবং সম্প্রদায়ের দিকে ফিরে তাকাচ্ছি। আমার নীতিবাক্য হল: আমাদের অবশ্যই নতুন ভুল করার চেষ্টা করতে হবে (কম সুস্পষ্ট, আরও পরিশীলিত)। একটি ভুল করা ভাল - এইভাবে আমরা শিখি, পুনরাবৃত্তি করা - দুঃখজনক এবং নিরুৎসাহিত। এটিই সম্ভবত গণিত সম্পর্কে আমাকে সর্বদা মুগ্ধ করেছে। শুধু তাই নয় যে এটি মার্জিত এবং সংক্ষিপ্ত, কিন্তু কারণ এর যৌক্তিক কঠোরতা ভুল প্রতিরোধ করে। এটি আপনাকে আপনার বর্তমান প্রেক্ষাপট সম্পর্কে চিন্তা করতে বাধ্য করে, আপনি কোন অনুমান এবং উপপাদ্যগুলির উপর নির্ভর করতে পারেন। এই নিয়মগুলি অনুসরণ করা ফলপ্রসূ প্রমাণিত হয়, আপনি সঠিক ফলাফল পাবেন। এটা সত্য যে, কম্পিউটার বিজ্ঞান গণিতের একটি শাখা। কিন্তু আমরা সাধারণত যা অনুশীলন করি তা হল সফ্টওয়্যার ইঞ্জিনিয়ারিং, একটি খুব আলাদা জিনিস। আমরা কম্পিউটার বিজ্ঞানের কৃতিত্ব এবং আবিষ্কারগুলি অনুশীলনের জন্য প্রয়োগ করি, সময়ের সীমাবদ্ধতা এবং ব্যবসায়ের প্রয়োজনগুলির জন্য অ্যাকাউন্টিং করি। এই ব্লগটি কম্পিউটার প্রোগ্রামের ডিজাইন এবং বাস্তবায়নে আধা-গাণিতিক যুক্তি প্রয়োগ করার একটি প্রচেষ্টা। আমরা বিভিন্ন এক্সিকিউশন একটি মডেল সামনে রাখব যা অনেক প্রোগ্রামিং ত্রুটি এড়াতে একটি কাঠামো প্রদান করে। রেজিমের বিনীত শুরু থেকে যখন আমরা প্রোগ্রাম করতে শিখি এবং আমাদের প্রথম অস্থায়ী (বা সাহসী) পদক্ষেপগুলি করি তখন আমরা সাধারণত কিছু সহজ দিয়ে শুরু করি: প্রোগ্রামিং লুপ, মৌলিক পাটিগণিত করা এবং একটি টার্মিনালে ফলাফল মুদ্রণ করা গণিত সমস্যা সমাধান করা, সম্ভবত ম্যাথক্যাড বা ম্যাথমেটিকা হিসাবে কিছু বিশেষ পরিবেশে আমরা পেশী মেমরি অর্জন করি, ভাষা সিনট্যাক্স শিখি এবং সবচেয়ে গুরুত্বপূর্ণভাবে আমরা আমাদের চিন্তাভাবনা এবং যুক্তি পরিবর্তন করি। আমরা কোড পড়তে শিখি, কীভাবে এটি কার্যকর করা হচ্ছে সে সম্পর্কে অনুমান তৈরি করি। আমরা প্রায় কখনই একটি ভাষার মান পড়ে শুরু করি না এবং এর "মেমরি মডেল" বিভাগের মাধ্যমে ঘনিষ্ঠভাবে পড়ি - কারণ আমরা এখনও সেগুলিকে পুরোপুরি উপলব্ধি করতে এবং ব্যবহার করতে সজ্জিত নই। আমরা ট্রায়াল এবং ত্রুটি অনুশীলন করি: আমরা আমাদের প্রথম প্রোগ্রামগুলিতে লজিক্যাল এবং গাণিতিক বাগগুলি প্রবর্তন করি। এই ভুলগুলি আমাদের অনুমানগুলি পরীক্ষা করতে শেখায়: এই লুপ অপরিবর্তনীয় কি সঠিক, আমরা কি এইভাবে অ্যারের উপাদানের সূচক এবং দৈর্ঘ্য তুলনা করতে পারি (আপনি এটি -1 কোথায় রাখবেন)? কিন্তু যদি আমরা কিছু ধরণের ত্রুটি দেখতে না পাই, প্রায়শই আমরা কিছু অভ্যন্তরীণ করে নিই সিস্টেম প্রয়োগ করে এবং আমাদের প্রদান করে। invariants যথা এই এক: কোডের লাইন সবসময় একই ক্রমে মূল্যায়ন করা হয় (ক্রমিক)। এই অনুমানটি আমাদের অনুমান করতে দেয় যে পরবর্তী প্রস্তাবগুলি সত্য (আমরা সেগুলি প্রমাণ করতে যাচ্ছি না): মূল্যায়ন আদেশ মৃত্যুদন্ডের মধ্যে পরিবর্তন হয় না ফাংশন কল সবসময় ফিরে আসে গাণিতিক স্বতঃসিদ্ধ বৃহত্তর স্ট্রাকচারগুলিকে শক্ত ভিত্তিতে তৈরি করতে এবং তৈরি করতে দেয়। গণিতে, আমাদের কাছে 4+1 পোস্টুলেট সহ রয়েছে। শেষটি বলেছেন: ইউক্লিডীয় জ্যামিতি সমান্তরাল রেখাগুলি সমান্তরাল থাকে, তারা ছেদ বা বিচ্ছিন্ন হয় না সহস্রাব্দ ধরে গণিতবিদরা এটি প্রমাণ করার চেষ্টা করেছিলেন এবং প্রথম চারটি থেকে এটি আহরণ করেছিলেন। দেখা যাচ্ছে যে এটি সম্ভব নয়। আমরা এই "সমান্তরাল রেখাগুলি" বিকল্পগুলির সাথে প্রতিস্থাপন করতে পারি এবং বিভিন্ন ধরণের জ্যামিতি (যেমন, হাইপারবোলিক এবং উপবৃত্তাকার) পেতে পারি, যা নতুন সম্ভাবনার সূচনা করে এবং প্রযোজ্য এবং দরকারী হতে দেখা যায়। সর্বোপরি আমাদের নিজস্ব গ্রহের পৃষ্ঠ সমতল নয় এবং এর জন্য আমাদেরকে হিসাব করতে হবে যেমন জিপিএস সফ্টওয়্যার এবং বিমানের রুটে। পরিবর্তনের প্রয়োজনীয়তা কিন্তু তার আগে আসুন থামুন এবং সবচেয়ে ইঞ্জিনিয়ারিং প্রশ্ন জিজ্ঞাসা করুন: কেন বিরক্ত? যদি প্রোগ্রামটি তার কাজ করে, এটি সমর্থন করা, রক্ষণাবেক্ষণ করা এবং বিকশিত করা সহজ, কেন আমরা প্রথমে অনুমানযোগ্য অনুক্রমিক সম্পাদনের এই আরামদায়ক পরিবর্তনটি ছেড়ে দেব? আমি দুটি উত্তর দেখতে. প্রথমটি হল । যদি আমরা আমাদের প্রোগ্রামকে দ্বিগুণ দ্রুত বা একইভাবে চালাতে পারি - হার্ডওয়্যারের অর্ধেক প্রয়োজন - এটি একটি ইঞ্জিনিয়ারিং অর্জন। একই পরিমাণ কম্পিউটেশনাল রিসোর্স ব্যবহার করলে আমরা 2x (বা 3, 4, 5, 10x) ডেটা গ্রাইন্ড করতে পারি - এটি একই প্রোগ্রামের সম্পূর্ণ নতুন অ্যাপ্লিকেশন খুলতে পারে। এটি সার্ভারের পরিবর্তে আপনার পকেটে থাকা মোবাইল ফোনে চলতে পারে। কখনও কখনও আমরা চতুর অ্যালগরিদম প্রয়োগ করে বা আরও কার্যকরী ভাষায় পুনরায় লেখার মাধ্যমে গতি অর্জন করতে পারি। এইগুলি আমাদের এক্সপ্লোর করার প্রথম বিকল্প, হ্যাঁ। কিন্তু তাদের একটা সীমা আছে। স্থাপত্য প্রায় সবসময় বাস্তবায়ন বীট. মুরের আইন ইদানীং তেমন ভালো করছে না, একটি একক CPU-এর কর্মক্ষমতা ধীরে ধীরে বাড়ছে, RAM কর্মক্ষমতা (প্রধানতঃ বিলম্বিতা) পিছিয়ে যাচ্ছে। সুতরাং, স্বাভাবিকভাবেই, প্রকৌশলীরা অন্যান্য বিকল্পগুলি সন্ধান করতে শুরু করেছিলেন। কর্মক্ষমতা দ্বিতীয় বিবেচনা . প্রকৃতি বিশৃঙ্খল, তাপগতিবিদ্যার দ্বিতীয় সূত্র সুনির্দিষ্ট, ক্রমিক এবং পুনরাবৃত্তিযোগ্য যেকোনো কিছুর বিরুদ্ধে ক্রমাগত কাজ করে। বিট ফ্লিপ হয়, উপকরণ ক্ষয় হয়, পাওয়ার ব্রাউন হয়ে যায়, তারগুলি কেটে যায় যা আমাদের প্রোগ্রামগুলি সম্পাদনে বাধা দেয়। ক্রমিক এবং পুনরাবৃত্তিযোগ্য বিমূর্ততা রাখা একটি কঠিন কাজ হয়ে ওঠে। যদি আমাদের প্রোগ্রামগুলি সফ্টওয়্যার এবং হার্ডওয়্যার ব্যর্থতাগুলিকে ছাড়িয়ে যেতে পারে তবে আমরা এমন পরিষেবাগুলি সরবরাহ করতে পারি যেগুলির একটি প্রতিযোগিতামূলক ব্যবসায়িক সুবিধা রয়েছে - এটি আরেকটি প্রকৌশল কাজ যা আমরা সমাধান শুরু করতে পারি। নির্ভরযোগ্যতা লক্ষ্যের সাথে সজ্জিত, আমরা অ-ক্রমিক পদ্ধতির সাথে পরীক্ষা শুরু করতে পারি। মৃত্যুদণ্ডের থ্রেড আসুন ছদ্ম কোডের এই অংশটি দেখি: ``` def fetch_coordinates(poi: str) -> Point: … def find_pois(center: Point, distance: int) -> List[str]: … def get_my_location() -> Point: … def fetch_coordinates(p) - Point: … def main(): me = get_my_location() for point in find_pois(me, 500): loc = fetch_coordinates(point) sys.stdout.write(f“Name: {point} is at x={loc.x} y={loc.y}”) আমরা টপ-টু-বাটম কোড পড়তে পারি এবং যুক্তিসঙ্গতভাবে ধরে নিতে পারি যে `find_pois` ফাংশনকে `get_my_location`- কল করা হবে। এবং আমরা পরেরটি আনার পরে প্রথম POI এর স্থানাঙ্কগুলি আনব এবং ফেরত দেব। এই অনুমানগুলি সঠিক এবং প্রোগ্রাম সম্পর্কে একটি মানসিক মডেল, কারণ তৈরি করার অনুমতি দেয়। এর পরে আসুন কল্পনা করি আমরা আমাদের কোডটি অ-ক্রমিকভাবে চালানোর জন্য তৈরি করতে পারি। আমরা সিনট্যাক্টিকভাবে এটি করতে পারি এমন অনেক উপায় রয়েছে। আমরা স্টেটমেন্ট রি-অর্ডারিং নিয়ে পরীক্ষা-নিরীক্ষা এড়িয়ে যাব (এটিই আধুনিক কম্পাইলার এবং CPU গুলি করে) এবং আমাদের ভাষা প্রসারিত করব যাতে আমরা একটি নতুন শাসন প্রকাশ করতে পারি: অথবা এমনকি অন্যান্য ফাংশন সাপেক্ষে। রিফ্রেসিং, আমাদের এক্সিকিউশনের একাধিক প্রবর্তন করতে হবে। আমাদের প্রোগ্রাম ফাংশনগুলি একটি নির্দিষ্ট পরিবেশে (ওএস দ্বারা তৈরি এবং রক্ষণাবেক্ষণ করা হয়) সঞ্চালিত হয়, এই মুহূর্তে আমরা ঠিকানাযোগ্য ভার্চুয়াল মেমরি এবং একটি থ্রেড - একটি শিডিউলিং ইউনিট, এমন কিছু যা একটি CPU দ্বারা কার্যকর করা যেতে পারে৷ ফাংশন এক্সিকিউশন একইসঙ্গে সমান্তরাল থ্রেড থ্রেডগুলি বিভিন্ন স্বাদে আসে: একটি POSIX থ্রেড, সবুজ থ্রেড, কোরোটিন, গোরুটিন। বিবরণ ব্যাপকভাবে পৃথক, কিন্তু এটি মৃত্যুদন্ড কার্যকর করা যেতে পারে যে কিছু নিচে ফোঁড়া. যদি একাধিক ফাংশন একসাথে চলতে পারে তবে প্রতিটির নিজস্ব শিডিউলিং ইউনিট প্রয়োজন। অর্থাৎ মাল্টি-থ্রেডিং থেকে এসেছে, একের পরিবর্তে, আমাদের এক্সিকিউশনের বেশ কয়েকটি থ্রেড রয়েছে। কিছু এনভায়রনমেন্ট (MPI) এবং ভাষা অস্পষ্টভাবে থ্রেড তৈরি করতে পারে, কিন্তু সাধারণত আমাদের C-তে `pthread_create`, Python-এ `threading` মডিউল ক্লাস বা Go-তে একটি সাধারণ `go` স্টেটমেন্ট ব্যবহার করে এটি করতে হয়। কিছু সতর্কতা অবলম্বন করে আমরা একই কোডকে বেশিরভাগ ক্ষেত্রে সমান্তরালভাবে চালাতে পারি: def fetch_coordinates(poi, results, idx) -> None: … results[idx] = poi def main(): me = get_my_location() points = find_pois(me, 500) results = [None] * len(points) # Reserve space for each result threads = [] for i, point in enumerate(find_pois(me, 500)): # i - index for result thr = threading.Thread(target=fetch_coordinates, args=(poi, results, i)) thr.start() threads.append(thr) for thr in threads: thr.wait() for point, result in zip(points, results): sys.stdout.write(f“Name: {poi} is at x={loc.x} y={loc.y}”) আমাদের প্রোগ্রাম একাধিক CPU এবং স্কেলে চলতে পারে কারণ কোরের সংখ্যা দ্রুত বৃদ্ধি পায় এবং শেষ হয়। পরবর্তী ইঞ্জিনিয়ারিং প্রশ্ন আমাদের অবশ্যই জিজ্ঞাসা করতে হবে: কি খরচে? আমরা আমাদের কর্মক্ষমতা লক্ষ্য অর্জন করেছি: আমরা ইচ্ছাকৃতভাবে সিরিয়ালাইজড এবং অনুমানযোগ্য মৃত্যুদন্ড ছেড়ে দিয়েছি। এখানে একটি ফাংশন + সময় এবং ডেটার মধ্যে পয়েন্ট। প্রতিটি সময়ে একটি চলমান ফাংশন এবং এর ডেটার মধ্যে সর্বদা একটি একক ম্যাপিং থাকে: কোন দ্বিধা নেই পরবর্তী পরিণতি হল যে একটি ফাংশন এই সময়ে অন্যটির আগে শেষ করতে পারে, পরের বার এটি অন্যভাবে হতে পারে। এক্সিকিউশনের এই নতুন ব্যবস্থা ডেটা রেসের দিকে নিয়ে যায়: যখন সমসাময়িক ফাংশনগুলি ডেটার সাথে কাজ করে তার মানে ডেটাতে প্রয়োগ করা ক্রিয়াকলাপের ক্রম অনির্ধারিত। আমরা ডেটা রেসের মুখোমুখি হতে শুরু করি এবং সেগুলি ব্যবহার করে মোকাবেলা করতে শিখি: সমালোচনামূলক বিভাগ: মিউটেক্স (এবং স্পিনলক) লক-মুক্ত অ্যালগরিদম (সরলতম ফর্মটি উপরের স্নিপেটে রয়েছে) জাতি সনাক্তকরণ সরঞ্জাম ইত্যাদি এই মুহুর্তে, আমরা অন্তত দুটি জিনিস আবিষ্কার করি। প্রথমত, ডেটা অ্যাক্সেস করার একাধিক উপায় রয়েছে। কিছু তথ্য আছে (যেমন ফাংশন স্কোপড ভেরিয়েবল) এবং শুধুমাত্র আমরা দেখতে পারি (এবং এটি অ্যাক্সেস করতে পারি) এবং এইভাবে এটি সর্বদা সেই অবস্থায় থাকে যা আমরা এটি ছেড়ে দিয়েছি। তবে কিছু ডাটা শেয়ার করা হয় বা . এটি এখনও আমাদের প্রসেস মেমরিতে থাকে, কিন্তু আমরা এটি অ্যাক্সেস করার জন্য বিশেষ উপায় ব্যবহার করি এবং এটি সিঙ্ক থেকে বেরিয়ে যেতে পারে। কিছু ক্ষেত্রে এটির সাথে কাজ করার জন্য আমরা ডেটা রেস এড়াতে এটিকে আমাদের স্থানীয় মেমরিতে কপি করি - তাই == == মরিচায় জনপ্রিয়। স্থানীয় দূরবর্তী .clone() যখন আমরা যুক্তির এই লাইনটি চালিয়ে যাই, অন্যান্য কৌশল যেমন থ্রেড-লোকাল স্টোরেজ স্বাভাবিকভাবেই আসে। আমরা আমাদের প্রোগ্রামিং টুলবেল্টে একটি নতুন গ্যাজেট অর্জন করেছি, সফ্টওয়্যার তৈরি করে আমরা যা অর্জন করতে পারি তা বিস্তৃত করে। যাইহোক, আমরা এখনও নির্ভর করতে পারি এমন একটি পরিবর্তন আছে। যখন আমরা একটি থ্রেড থেকে ভাগ করা (দূরবর্তী) ডেটার জন্য পৌঁছাই, আমরা সর্বদা এটি পাই। এমন কোন পরিস্থিতি নেই যখন কিছু মেমরি খণ্ড পাওয়া যায় না। ব্যাকিং ফিজিক্যাল মেমরি অঞ্চলে ত্রুটি দেখা দিলে ওএস প্রক্রিয়াটি মেরে (থ্রেড) বন্ধ করে দেবে। একই কথা "আমাদের" থ্রেডের ক্ষেত্রেও প্রযোজ্য যদি আমরা একটি মিউটেক্স লক করে থাকি, তাহলে লকটি হারানোর কোনো উপায় নেই এবং আমরা যা করছি তা অবিলম্বে বন্ধ করতে হবে। আমরা এই পরিবর্তনের উপর নির্ভর করতে পারি (ওএস এবং আধুনিক হার্ডওয়্যার দ্বারা প্রয়োগ করা হয়েছে) যে সমস্ত অংশগ্রহণকারী হয় মৃত বা জীবিত। সকলেই : যদি প্রক্রিয়া (OOM), OS (কার্নেল বাগ) বা হার্ডওয়্যার কোনো সমস্যার সম্মুখীন হয় - আমাদের সমস্ত থ্রেড বাইরের অবশিষ্ট পার্শ্ব-প্রতিক্রিয়া ছাড়াই একসাথে থাকা বন্ধ হয়ে যাবে। সব অংশগ্রহণকারীদের ভাগ্য ভাগ করে নেয় একটি প্রক্রিয়া উদ্ভাবন একটি গুরুত্বপূর্ণ বিষয় লক্ষ্য করুন। কিভাবে আমরা থ্রেড প্রবর্তন করে এই প্রথম ধাপ তৈরি করেছি? আমরা আলাদা, কাঁটাচামচ. একটি শিডিউলিং ইউনিটের পরিবর্তে আমরা একাধিক চালু করেছি। আসুন এই শেয়ার না করার পদ্ধতিটি প্রয়োগ করা চালিয়ে যান এবং দেখুন এটি কীভাবে যায়। এই সময় আমরা ভার্চুয়াল মেমরি প্রক্রিয়া কপি. একে বলা হয় - একটি । আমরা আমাদের প্রোগ্রামের অন্য একটি উদাহরণ চালাতে পারি বা অন্য বিদ্যমান ইউটিলিটি শুরু করতে পারি। এটি একটি দুর্দান্ত পদ্ধতি: প্রক্রিয়ার জন্ম দেওয়া কঠোর সীমানা সহ অন্যান্য কোড পুনরায় ব্যবহার করুন অবিশ্বস্ত কোড চালান, এটি আমাদের নিজস্ব মেমরি থেকে বিচ্ছিন্ন করে প্রায় সব == == এইভাবে কাজ করুন, যাতে তারা ইন্টারনেট থেকে ডাউনলোড করা অবিশ্বস্ত জাভাস্ক্রিপ্ট এক্সিকিউটেবল কোড চালাতে সক্ষম হয় এবং আপনি যখন পুরো অ্যাপ্লিকেশনটি নামিয়ে না এনে একটি ট্যাব বন্ধ করেন তখন এটি নির্ভরযোগ্যভাবে বন্ধ করে দেয়। আধুনিক ব্রাউজার ইনভেরিয়েন্ট ত্যাগ করে এবং ভার্চুয়াল মেমরি এবং একটি কপি তৈরি করে আমরা আবিষ্কৃত মৃত্যুদন্ডের আরেকটি পদ্ধতি। কপি বিনামূল্যে নয়: শেয়ার্ড ফেট শেয়ার না করে OS কে মেমরি সম্পর্কিত ডেটা স্ট্রাকচার পরিচালনা করতে হবে (ভার্চুয়াল -> শারীরিক ম্যাপিং বজায় রাখতে) কিছু বিট ভাগ করা যেতে পারে এবং এইভাবে প্রক্রিয়াগুলি অতিরিক্ত মেমরি গ্রাস করে খাঁচা মুক্ত এখানে থামা কেন? আসুন আমরা আমাদের প্রোগ্রামটি অনুলিপি এবং পারি আর কী তা অন্বেষণ করি। কিন্তু কেন প্রথম স্থানে বিতরণ যেতে? অনেক ক্ষেত্রে হাতের কাজগুলি একটি একক মেশিন ব্যবহার করে সমাধান করা যেতে পারে। বিতরণ করতে আমাদের বিতরণ করতে হবে tenets যাতে আমাদের সফ্টওয়্যারটি অন্তর্নিহিত স্তরগুলির সম্মুখীন হওয়া অনিবার্য সমস্যার উপর নির্ভর করে বন্ধ হয়ে যায়। ভাগ্য ভাগ্য এড়াতে কয়েকটি নাম বলতে: OS আপগ্রেড: সময়ে সময়ে আমাদের মেশিনগুলি পুনরায় বুট করতে হবে হার্ডওয়্যার ব্যর্থতা: এগুলি আমরা যতটা চাই তার চেয়ে বেশি ঘন ঘন ঘটে বাহ্যিক ব্যর্থতা: পাওয়ার এবং নেটওয়ার্ক বিভ্রাট একটি জিনিস। যদি আমরা একটি OS অনুলিপি করি - আমরা এটিকে একটি বলি এবং একটি ভৌতিক একটিতে গ্রাহকদের প্রোগ্রাম চালাতে পারি এবং এটিতে একটি বিশাল ক্লাউড ব্যবসা তৈরি করতে পারি। যদি আমরা দুই বা ততোধিক কম্পিউটার নিয়ে যাই এবং প্রতিটিতে আমাদের প্রোগ্রাম চালাই - আমাদের প্রোগ্রাম এমনকি হার্ডওয়্যার ব্যর্থতা থেকেও বাঁচতে পারে, 24/7 পরিষেবা প্রদান করে এবং একটি প্রতিযোগিতামূলক সুবিধা অর্জন করতে পারে। বৃহৎ কর্পোরেশনগুলি অনেক আগে আরও এগিয়ে গিয়েছিল এবং এখন ইন্টারনেট জায়ান্টগুলি বিভিন্ন ডেটাসেন্টার এবং এমনকি মহাদেশগুলিতে অনুলিপি চালায়, এইভাবে একটি প্রোগ্রামকে টাইফুন বা সাধারণ বিদ্যুৎ বিভ্রাটের জন্য স্থিতিস্থাপক করে তোলে। ভার্চুয়াল মেশিন কিন্তু এই স্বাধীনতা একটি মূল্যে আসে: পুরানো পরিবর্তনগুলি প্রয়োগ করা হয় না, আমরা আমাদের নিজস্ব। কোন চিন্তা নেই, আমরা প্রথম নই। আমাদের সাহায্য করার জন্য প্রচুর কৌশল, সরঞ্জাম এবং পরিষেবা রয়েছে৷ Takeaways আমরা সবেমাত্র সিস্টেম এবং তাদের নিজ নিজ কার্যকরী ব্যবস্থা সম্পর্কে যুক্তি করার ক্ষমতা অর্জন করেছি। প্রতিটি বৃহৎ স্কেল আউট সিস্টেমের অভ্যন্তরে বেশিরভাগ অংশগুলি পরিচিত অনুক্রমিক এবং রাষ্ট্রহীন, অনেক উপাদান মেমরির ধরন এবং শ্রেণিবিন্যাস সহ বহু-থ্রেডেড কিছু সত্যিকারের বিতরণ করা অংশগুলির মিশ্রণ দ্বারা একত্রিত হয়: লক্ষ্য হল আমরা বর্তমানে কোথায় আছি, কী পরিবর্তনকারীরা ধারণ করে এবং সেই অনুযায়ী কাজ (পরিবর্তন/ডিজাইন) করে তা আলাদা করতে সক্ষম হওয়া। আমরা মৌলিক যুক্তি হাইলাইট করেছি, "অজানা অজানা" কে "জানা অজানা" তে রূপান্তরিত করেছি। এটিকে হালকাভাবে নেবেন না, এটি একটি উল্লেখযোগ্য অগ্রগতি।