জন পোস্টেলের ব্যবহারিক স্ট্যান্ডার্ড মানসিকতা কিভাবে ইন্টারনেট গভর্নেন্স ও আন্তঃঅপারেবিলিটি গঠিত করলো—RFC, IETF-এর নীতি, এবং প্রারম্ভিক সমন্বয়ের নীরব কাজগুলো কীভাবে নেটওয়ার্কগুলোকে একসাথে রাখতে সাহায্য করলো।

প্রাথমিক কম্পিউটার নেটওয়ার্কিং ছিল “একই নেটওয়ার্ক যা বড় হয়ে উঠল” নয়। এটা ছিল অনেক আলাদা নেটওয়ার্ক—বিভিন্ন প্রতিষ্ঠানের দ্বারা চালিত, বিভিন্ন হার্ডওয়্যার ভিত্তিক, বিভিন্ন উদ্দেশ্যে তহবিলপ্রাপ্ত, এবং বিভিন্ন অনুমানের ওপর নির্মিত। কেউ ছিল একাডেমিক ও সহযোগিতামূলক, কেউ সামরিক, কেউ ব্যবসায়িক। প্রতিটি নেটওয়ার্ক নিজে ভালো কাজ করলেও অন্যদের সঙ্গে যোগাযোগ করতে অক্ষম (বা অনিচ্ছুক) হতে পারত।
বৃহৎ চিত্রে সমস্যাটা সরল: কীভাবে এমন নেটওয়ার্কগুলোকে সংযুক্ত করবেন যাদের নিয়মাবলী একই নয়?
অ্যাড্রেস ফরম্যাট ভিন্ন ছিল। বার্তার আকার ভিন্ন ছিল। ত্রুটি পরিচালনা ভিন্ন ছিল। এমনকি বেসিক প্রত্যাশাগুলিও—“আবার চেষ্টা করার আগে কতক্ষণ অপেক্ষা করা উচিত?”—ভিন্ন হতে পারত। শেয়ার করা চুক্তি না থাকলে আপনার কাছে ইন্টারনেট থাকে না—আপনি পান বিচ্ছিন্ন দ্বীপসমূহ, কিছু কাস্টম ব্রিজ নিয়ে।
সেই ব্রিজগুলো বানাতে খরচবহুল এবং ভাঙা সহজ। এগুলো সাধারণত মানুষকে একটি ভেন্ডর বা নির্দিষ্ট নেটওয়ার্ক অপারেটরের সাথে আটকে রাখে, কারণ “অনুবাদ স্তর” প্রতিযোগিতামূলক ঝামেলার কেন্দ্রবিন্দুতে পরিণত হয়।
প্রারম্ভিক নেটওয়ার্কিংকে প্রোটোকল যুদ্ধ হিসেবে ব্যাখ্যা করা সহজ—যেখানে “সেরা” প্রযুক্তি জিতেছে। বাস্তবে, প্রযুক্তিগত সৌন্দর্য বা বাজার আধিপত্যের চেয়েও ইন্টারঅপারেবিলিটি প্রায়ই বেশি গুরুত্বপূর্ণ ছিল। একটি একটু অসম্পূর্ণ কিন্তু ব্যাপকভাবে বাস্তবায়নযোগ্য প্রটোকল সেই তুলনায় অনেক বেশি মানুষকে সংযুক্ত করতে পারে, যে প্রটোকলটি তত্ত্বগতভাবে উন্নত কিন্তু কেবল একটি ইকোসিস্টেমেই কাজ করে।
ইন্টারনেটের সাফল্য বিরাটভাবে এমন এক সংস্কৃতির ওপর নির্ভর করেছিল যা একসঙ্গে কাজ করাকে পুরস্কৃত করত—প্রতিষ্ঠান ও সীমানা ছাড়িয়ে—যখন কোনো একক প্রতিষ্ঠান বাধ্য করতে পারে না।
জন পোস্টেল ঘুরে ফিরে সেই সহযোগিতার সবচেয়ে বিশ্বাসযোগ্য রক্ষণশীলদের একজন হয়ে উঠেন। না যে তাঁর একটি বিশাল সরকারি ম্যানডেট ছিল—বরং তিনি অভ্যাস ও নীতি গড়ে তুলেছেন যা ভাগ করা স্ট্যান্ডার্ডকে বিশ্বাসযোগ্য করে তোলে: স্পষ্টভাবে লিখুন, বাস্তব ইমপ্লিমেন্টেশনে পরীক্ষা করুন, এবং নাম ও নম্বরের মতো বেসিক কিন্তু জরুরি বিবরণ সমন্বয় করুন যাতে সবাই সঙ্গত থাকে।
এটি প্যাকেট ফরম্যাটের প্রযুক্তিগত গভীরতায় ঢুকবে না। এটি নিয়ে হবে সেই ব্যবহারিক অনুশীলন ও গভর্নেন্স পছন্দগুলোর—যারা ইন্টারঅপারেবিলিটিকে সম্ভব করেছে: RFC-গুলোর চারপাশে গড়ে ওঠা স্ট্যান্ডার্ড সংস্কৃতি, IETF-এর কাজের ধারা, এবং নীরব সমন্বয় কাজ যা বৃদ্দিমান নেটওয়ার্ককে অযোগ্য “মিনি-ইন্টারনেটে” ফেটে যাওয়া থেকে রক্ষা করেছে।
জন পোস্টেল কোনো বিখ্যাত সিইও বা সরকারি কর্মকর্তা ছিলেন না। তিনি ছিলেন একজন কাজ করা ইঞ্জিনিয়ার এবং সম্পাদক, যিনি UCLA এবং পরে Information Sciences Institute (ISI)-তে কাজ করে প্রারম্ভিক নেটওয়ার্কিং ধারণাগুলোকে ভাগ করা, ব্যবহারযোগ্য অনুশীলনে পরিণত করতে সাহায্য করেছেন।
আপনি যদি কখনও কোনো ডোমেইন নাম টাইপ করে থাকেন, ইমেল পাঠিয়েছেন, বা বিভিন্ন ভেন্ডরের ডিভাইসগুলোকে "সোজা কাজ করে" ভেবেছেন—তবে আপনি সেই ধরণের সমন্বয় থেকে উপকৃত হয়েছেন যা পোস্টেল কয়েক দশক ধরে নীরবে প্রদান করতেন।
পোস্টেল কার্যকর ছিলেন কারণ তিনি স্ট্যান্ডার্ডকে একটি পাবলিক ইউটিলিটির মতো বিবেচনা করতেন: এমন কিছু যাতে মানুষ নির্মাণ করতে পারে এবং যার রক্ষণাবেক্ষণ অপরিহার্য। তিনি স্পষ্ট লেখার জন্য, বিতর্কে ধৈর্যের জন্য, এবং বিবরণ ঠিক করার জন্য অধ্যবসায়ের খ্যাতি পেয়েছিলেন। এই সংমিশ্রণটি এমন একটি কমিউনিটিতে গুরুত্বপূর্ণ ছিল যেখানে মতবিরোধগুলো একাডেমিক বিষয় নয়—এগুলো বাস্তবায়ন ভাগ করে দিতে পারে এবং ব্যবহারকারীদের বিচ্ছিন্ন করে রাখতে পারে।
তিনি আরেকটি অপ্রশংসিত কাজও করতেন: টেকনিক্যাল নোটগুলো সম্পাদনা ও কিউরেট করা, প্রশ্নের জবাব দেওয়া, গ্রুপগুলিকে সিদ্ধান্তের দিকে ঠেলে দেওয়া, এবং শেয়ার্ড রেজিস্ট্রিগুলো সুশৃঙ্খল রাখা। সেই স্থির, দৃশ্যমান সেবা তাঁকে একটি নির্ভরযোগ্য রেফারেন্স পয়েন্ট করে তুলেছিল যখন উত্তেজনা বাড়ত বা সময়সীমা পিছিয়ে যেত।
পোস্টেল প্রভাব ফেলতেন মূলত কারণ তিনি ধারাবাহিক, ন্যায়পরায়ণ, ও গভীরভাবে জ্ঞানশীল ছিলেন—এবং কারণ তিনি বারবার কাজটা করতেন। অন্য কথায়, তিনি “কর্তৃত্ব” ধারণ করতেন এমনভাবে যেভাবে ভালো মেইনটেইনাররা করেন: সহায়ক, অনুমেয়, এবং বদলাতে কষ্টকর।
প্রাথমিক ইন্টারনেট ছিল বিশ্ববিদ্যালয়, ল্যাব, কনট্রাক্টর, ও ভেন্ডারের এক প্যাচওয়ার্ক যার অগ্রাধিকার ভিন্ন। পোস্টেলের বিশ্বাসযোগ্যতা সেই গ্রুপগুলিকে সহযোগিতা করতে সাহায্য করত। যখন কেউ বিশ্বাস করত যে একটি সিদ্ধান্ত ইন্টারঅপারেবিলিটির জন্য নেওয়া হচ্ছে—রাজনীতি বা লাভের জন্য নয়—তাহলে তারা তাদের সিস্টেমগুলো মিলাতে আরো ইচ্ছুক হতো, যদিও তার মানে ছিল আপোষ করা।
RFC—Request for Comments—একটি পাবলিক মেমো যা ব্যাখ্যা করে কিভাবে কোনো ইন্টারনেট প্রটোকল বা অনুশীলন কাজ করবে। ভাবুন: “এখানে আইডিয়া, এখানে ফরম্যাট, এখানে নিয়ম—বলুন কোথায় ভেঙে যায়।” কিছু RFC প্রাথমিক খসড়া; অন্যগুলো ব্যাপকভাবে ব্যবহৃত স্ট্যান্ডার্ড হয়ে ওঠে। মূল অভ্যাস একই: লিখে রাখুন যাতে অন্যরা একই পৃষ্ঠায় থেকে নির্মাণ করতে পারে।
RFC-গুলো ইচ্ছাকৃতভাবে ব্যবহারিক ছিল। এগুলো বাস্তবায়নকারীদের জন্য উপযোগী হতে মনস্থ করেছিল, কমিটির সামনে বড় দেখাতে নয়। এর মানে ছিল কংক্রিট বিবরণ: বার্তা ফরম্যাট, ত্রুটি কেস, উদাহরণ, এবং সেই নীরস কিন্তু সমালোচনামূলক স্পষ্টতা যা প্রতিটি টিমকে একই বাক্যকে ভিন্নভাবে ব্যাখ্যা করা থেকে রক্ষা করে।
ততটাই গুরুত্বপূর্ণ, RFCগুলো লেখা হতো পরীক্ষা করা এবং সংশোধন করার জন্য। প্রকাশনা ফিনিশ লাইন নয়—এটা বাস্তব-দুনিয়ায় প্রতিক্রিয়ার শুরু। যদি কোনো ধারণা কোডে কাজ করে কিন্তু নেটওয়ার্কগুলির মধ্যে ব্যর্থ হয়, নথিটি আপডেট বা প্রতিস্থাপন করা যেত। এই “শুরুতে প্রকাশ করুন, উন্মুক্তভাবে উন্নত করুন” ছন্দ প্রোটোকলগুলোকে বাস্তবে রাখল।
যখন স্পেসিফিকেশনগুলো ব্যক্তিগত থাকে, ভুলভাবাবুঝি বেড়ে যায়: একজন ভেন্ডর এক ব্যাখ্যা শুনে, অন্য ভেন্ডর একটু ভিন্নটি শুনে, এবং ইন্টারঅপারেবিলিটি পরে একটি চিন্তা বসে যায়।
RFCগুলোকে সর্বজনীন বানানো গবেষক, ভেন্ডর, বিশ্ববিদ্যালয়, এবং পরে বাণিজ্যিক প্রদানকারীদের সবাইকে একই রেফারেন্স টেক্সটে লাইন আপ করতে সাহায্য করত। মতবিরোধ বিলুপ্ত হয়নি, কিন্তু সেগুলো দৃশ্যমান হয়ে উঠেছিল এবং সুতরাং সমাধানযোগ্য হয়ে উঠেছিল।
RFC গুলো পাঠযোগ্য ও সঙ্গত থাকার একটি মূল কারণ ছিল সম্পাদকীয় শৃঙ্খলা। সম্পাদকরা (অনেক বছর জন পোস্টেলসহ) স্পষ্টতা, স্থিতিশীল পরিভাষা, এবং সাধারণ কাঠামো বজায় রাখতে উৎসাহ দিতেন।
তারপর বিস্তৃত কমিউনিটি রিভিউ করত—প্রশ্ন করত, অনুমান চ্যালেঞ্জ করত, এবং এজ কেস ঠিক করত। সেই মিশ্রণ—কঠোর সম্পাদনা প্লাস উন্মুক্ত সমালোচনা—এমন নথি তৈরি করত যা মূল কক্ষে না থাকা মানুষও বাস্তবায়ন করতে পারত।
“IETF”-এর এই নীতি বলে: দীর্ঘ তর্কের বদলে কিছু তৈরি করুন যা কাজ করে—তারপর অন্যদের দেখান, এবং শিখে লিখে নিন।
রানিং কোড কোনো স্লোগান নয়; এটা একটি প্রমাণ মানদণ্ড:
প্রায়োগিকভাবে, এটা স্ট্যান্ডার্ড কাজকে প্রোটোটাইপ, ইন্টারঅপারেবিলিটি ডেমো, টেস্ট সুইট, এবং বারবার “চেষ্টা কর, ঠিক কর, আবার চেষ্টা কর” চক্রের দিকে ঠেলে দেয়।
নেটওয়ার্কগুলো বিশৃঙ্খল: লেটেন্সি পরিবর্তিত হয়, লিঙ্ক পড়ে যায়, মেশিন ভিন্ন, এবং মানুষ অপ্রত্যাশিতভাবে জিনিস বানায়। দ্রুত কিছু রানযোগ্য বস্তু প্রয়োজন করে এই সংস্কৃতিটি অসীম দার্শনিক তর্ক এড়াতে সাহায্য করল।
ফায়দাগুলো বাস্তবিক ছিল:
এই পদ্ধতি ঝুঁকিমুক্ত নয়। “প্রথম কাজ করা জিনিসই জয়ী” হওয়া সময়োপযোগী লক-ইনে পরিণত করতে পারে, যেখানে একটি প্রাথমিক ডিজাইন পরে বদলানো কঠিন হয়ে যায়। এটি তাদের টিমকে পুরস্কৃত করতে পারে যাদের কাছে বেশি সম্পদ—তারা দ্রুত বাস্তবায়ন তৈরি করে প্রভাব গড়ে তুলতে পারে।
সংস্কৃতিটিকে “শিপ করে তারপর ভুলে যাওয়া” তে পরিণত হওয়া থেকে রক্ষা করতে IETF টেস্টিং ও পুনরাবৃত্তির ওপর ভর করে। ইন্টারঅপারেবিলিটি ইভেন্ট, একাধিক বাস্তবায়ন, এবং সতর্ক সংশোধনী চক্র “মাই মেশিনে চলে” এবং “সবাই-র জন্য কাজ করে” পার্থক্য করতে সাহায্য করত।
মূলে আছে ধারণা: স্ট্যান্ডার্ডগুলো প্রমাণিত অনুশীলনের রেকর্ড—ঐকান্তিক ফিচার তালিকা নয়।
এখানে “ফ্র্যাগমেন্টেশন” বলতে কেবল একাধিক নেটওয়ার্ক আছে তা বোঝানো নয়। অর্থ হল এমন অমিলপূর্ণ নেটওয়ার্কগুলো যা পরস্পর পরিস্কারভাবে কথা বলতে পারে না, সাথে প্রতিটি গ্রুপ প্রায় একই মৌলিক প্লাম্বিং পুনরায় আবিষ্কার করে।
যদি প্রতিটি নেটওয়ার্ক, ভেন্ডর, বা সরকারি প্রকল্প তাদের নিজস্ব অ্যাড্রেসিং, নামকরণ, এবং ট্রান্সপোর্ট নিয়ম নির্ধারণ করত, তাহলে সিস্টেম সংযুক্ত করতে ক্রমাগত অনুবাদ দরকার হত। সেই অনুবাদ সাধারণত প্রকাশ পায় হিসাবে:
ফলাফল শুধু প্রযুক্তিগত জটিলতা নয়—এটা উচ্চতর দাম, ধীর উদ্ভাবন, এবং কম মানুষ যোগ দিতে পারা।
শেয়ার্ড, পাবলিক স্ট্যান্ডার্ড ইন্টারনেটকে যোগ দিতে সস্তা করে তুলল। একটি নতুন বিশ্ববিদ্যালয় নেটওয়ার্ক, এক স্টার্টআপ ISP, বা একটি হার্ডওয়্যার ভেন্ডর বিশেষ অনুমতি বা কাস্টম ইন্টিগ্রেশন চুক্তি প্রয়োজন ছাড়াই প্রকাশিত স্পেসিফিকেশন বাস্তবায়ন করে আশা করতে পারত যে তারা অন্যদের সাথে ইন্টারঅপারেবল হবে।
এটি পরীক্ষার খরচও কমাল: আপনি বিদ্যমান প্রটোকলের ওপর নতুন অ্যাপ্লিকেশন বানাতে পারেন আলাদা-অপারেটরের সাথে পৃথকভাবে উপযোগীতা নিয়ে দরকষাকষি না করে।
বিভাজন এড়াতে ভালো আইডিয়া ছাড়া নিরপেক্ষ সমন্বয়ও দরকার ছিল—এই ধরনের সমন্বয় এমন একবার যা প্রতিযোগিতামূলক প্রেরণাগুলো সহজে প্রদান করতে পারত না। বিভিন্ন দল বিভিন্ন ফলাফল চেয়েছিল—বাণিজ্যিক সুবিধা, জাতীয় অগ্রাধিকার, গবেষণা লক্ষ্য—কিন্তু তাদের সাধারণ শনাক্তকরণকারী ও প্রটোকল আচরণে মিল থাকতে বাস্তব প্রয়োজন ছিল।
নিরপেক্ষ সমন্বয় সংযুক্ত টিস্যুকে ভাগ করে না; বরং এটা ভাগ করে দেয় যাতে পার্থক্য থাকা সত্ত্বেও উপরে নির্মিত বিষয়গুলো ভাগ করা থাকে। এটি একটি নীরব, ব্যবহারিক ধরনের গভর্নেন্স: নেটওয়ার্ক নিয়ন্ত্রণ না করে, কিন্তু এটিকে বিচ্ছিন্ন দ্বীপে ভেঙে যাওয়া প্রতিরোধ করে।
IETF সাফল্য পেয়েছে কারণ এটি সবচেয়ে বেশি কর্তৃত্ব ছিল বলে নয়। বরং কারণ এটি বহু স্বাধীন মানুষ ও প্রতিষ্ঠানের জন্য একটি নির্ভরযোগ্য উপায় গড়ে তুলেছিল যাতে তারা একমত হতে পারে—কোনো এক কোম্পানি, সরকার, বা ল্যাব ফলাফলটির মালিক না হয়ে।
IETF একটি পাবলিক ওয়ার্কশপের মতো কাজ করে। কেউ মেলিং লিস্টে যোগ দিতে পারে, খসড়া পড়তে পারে, মিটিংয়ে যাচাই করতে পারে, এবং মন্তব্য করতে পারে। সেই খোলামেলা ব্যবস্থা গুরুত্বপূর্ণ ছিল কারণ ইন্টারঅপারেবিলিটি সমস্যাগুলো প্রায়ই এজ-এ দেখা যায়—যেখানে ভিন্ন সিস্টেম মিলিত হয়—আর সেই এজগুলো বহু ভিন্ন মানুষের দখলে থাকে।
বাইরের মতামতকে একটি ঝুঁকিভোগ সমস্যা হিসেবে না দেখে প্রক্রিয়াটি এটাকে অপরিহার্য ইনপুট হিসেবে দেখায়। যদি কোনো প্রস্তাব বাস্তব নেটওয়ার্ক ভাঙে, কেউ সাধারণত তা দ্রুত বলবে।
অধিকাংশ কাজ হয় ওয়ার্কিং গ্রুপে, প্রতিটি নির্দিষ্ট সমস্যার উপর ফোকাস করে (উদাহরণস্বরূপ, ইমেলের ফরম্যাটিং, বা রাউটিং তথ্য কিভাবে বিনিময় হবে)। একটি ওয়ার্কিং গ্রুপ তখন গঠিত হয় যখন স্পষ্ট একটি চাহিদা, পর্যাপ্ত আগ্রহী অবদানকারী, এবং সীমানা নির্ধারণ করে এমন একটি চার্টার থাকে।
অগ্রগতি সাধারণত ব্যবহারিকভাবে দেখতে এমন:
IETF-এ প্রভাব অর্জন হয় উপস্থিত থেকে, কঠোর কাজ করে, এবং সমালোচনার জবাব দিয়ে—পদের নাম দিয়ে নয়। সম্পাদক, বাস্তবায়নকারী, অপারেটর, এবং রিভিউয়াররা ফলাফল গঠনে সবাই অংশ নেয়। এই রীতি একটি দরকারী চাপ সৃষ্টি করে: আপনার আইডিয়া গ্রহণযোগ্য করতে চাইলে আপনাকে তা বোঝার যোগ্য ও বাস্তবায়নযোগ্য করে তুলতে হবে।
খোলা বিতর্ক সহজেই সীমাহীন তর্কে পরিণত হতে পারে। IETF এমন কিছু নিয়ম-নীতি গড়ে তুলেছে যা আলোচনাকে লক্ষ্যভিত্তিক রাখে:
এখানে জয় রেটরিক নয়—জয় হল স্বাধীনভাবে নির্মিত সিস্টেমগুলো এখনও একসঙ্গে কাজ করতে পারছে।
লোকেরা যখন ইন্টারনেট কীভাবে কাজ করে বলে ভাবেন, তারা সাধারণত বড় আবিষ্কারগুলোর কথা ভাবেন: TCP/IP, DNS, বা ওয়েব। কিন্তু অনেক ইন্টারঅপারেবিলিটি কম চিত্তাকর্ষক কিছুতে নির্ভর করে: সবাই একই মাস্টার তালিকা নিয়ে একমত থাকা। সেটাই IANA-এর মৌলিক কাজ—ইন্টারনেট অ্যাসাইন্ড নাম্বার অথরিটি।
IANA একটি সমন্বয় ফাংশন যা শেয়ার্ড রেজিস্ট্রি বজায় রাখে যাতে ভিন্ন সিস্টেমগুলো তাদের সেটিংস মিলিয়ে নিতে পারে। যদি দুটি স্বাধীন টিম একই স্ট্যান্ডার্ড থেকে সফটওয়্যার বানায়, সেই স্ট্যান্ডার্ডগুলোর জন্য কংক্রিট মান—সংখ্যা, নাম, লেবেল—প্রয়োজন যাতে বাস্তবে তাদের বাস্তবায়নসমূহ মিলিয়ে যায়।
কয়েকটি উদাহরণ বিষয়টাকে স্পষ্ট করে:
শেয়ার্ড রেজিস্ট্রি না থাকলে সংঘর্ষ হয়। দুটি দল একই সংখ্যাকে ভিন্ন ফিচারের জন্য বরাদ্দ করতে পারে, বা একই ধারণার জন্য ভিন্ন লেবেল ব্যবহার করতে পারে। ফলাফল নাটকীয় ব্যর্থতা না করেও হল—অবিচ্ছিন্ন বাগ, বিভ্রান্তিকর অসামঞ্জস্য, এবং এমন পণ্য যা কেবল নিজের বুদ থেকে কাজ করে।
IANA-এর কাজ সেরা ধরণের “বিরক্তিকর”: এটি বিমূর্ত চুক্তিকে দৈনন্দিন সামঞ্জস্যে রূপায়িত করে। সেই নীরব সমন্বয়ই স্ট্যান্ডার্ডগুলোকে সাজায়—ভেন্ডার, দেশ, এবং দশক জুড়ে—ভালভাবে পুনরায় আলোচনার দরকার ছাড়াই।
জন পোস্টেলের সঙ্গে একটি নিয়মখানা জড়িয়ে আছে: আপনি যা পাঠান তাতে কঠোর থাকুন, যা গ্রহণ করেন তাতে নমনীয় থাকুন। এটা শোনায় প্রযুক্তিগত নির্দেশিকা হলেও এটি অচেনা লোকেদের মধ্যে একটি সামাজিক চুক্তি হিসেবে কাজ করেছিল—যারা সিস্টেমগুলোকে একসাথে কাজ করতে বাধ্য ছিল।
“যা আপনি পাঠান তাতে কঠোর হন” মানে আপনার সফটওয়্যার যখন ডেটা প্রেরণ করে তখন স্পেসিফিকেশনের কঠোর অনুসরণ করুন—কোনও সৃজনশীল শর্টকাট নয়, “সবাই জানে আমি কী বোঝাতে চাই” নয়। উদ্দেশ্য হলো অদ্ভুত ব্যাখ্যাগুলো সম্প্রচার করা থেকে বিরত থাকা যাতে অন্যরা তা অনুলিপি করতে বাধ্য না হয়।
“যা আপনি গ্রহণ করেন তাতে নমনীয় হন” মানে আপনি যখন কিছু সামান্য ভিন্ন পেয়েছেন—কোনো মিসিং ফিল্ড, অস্বাভাবিক ফরম্যাট, বা এক্সট্রিম কেস—আপনি গ্রেসফুলি হ্যান্ডেল করার চেষ্টা করবেন, বরং সংযোগটি ক্র্যাশ বা প্রত্যাখ্যান করবেন না।
প্রাথমিক ইন্টারনেটে বাস্তবায়নগুলো অসম ছিল: ভিন্ন মেশিন, ভিন্ন প্রোগ্রামিং ভাষা, এবং বাস্তবায়নের সময় স্পেসিফিকেশন অসম্পূর্ণ—সব কিছু একসাথে। নমনীয়তা সিস্টেমগুলোকে যোগাযোগ করতে দিয়েছিল এমনকি যখন উভয় পক্ষই পুরোপুরি নিখুঁত ছিল না।
সেই সহনশীলতা স্ট্যান্ডার্ড প্রক্রিয়াটিকে একত্রিত হওয়ার জন্য সময় কিনে দিয়েছিল। এটি ফর্কিং চাপও কমিয়েছে—টিমগুলোকে কিছু কাজ করার জন্য তাদের নিজস্ব অমিলকৃত ভ্যারিয়েন্ট বানানোর দরকার ছিল না।
সময়ভিত্তিকভাবে অতিরিক্ত নমনীয়তা সমস্যা তৈরি করেছে। যদি একটি বাস্তবায়ন অসংগত বা অবৈধ ইনপুট গ্রহণ করে, তাহলে অন্যরা সেই আচরণে নির্ভর করতে পারে, বাগকে “ফিচার” এ পরিণত করে। আরো খারাপ, উদার পার্সিং নিরাপত্তা সমস্যাও খোলে (ইঞ্জেকশন-শৈলীর আক্রমণ বা অননুমোদিত বাইপাস তৈরি করে)।
আপডেট করা পাঠ হল: ইন্টারঅপারেবিলিটি সর্বাধিক করুন, কিন্তু বিকৃত ইনপুটকে স্বাভাবিক করবেন না। ডিফল্টভাবে কঠোর থাকুন, ব্যতিক্রম নথিভুক্ত করুন, “গ্রহণ করা কিন্তু অননুমত” ডেটাকে লগ/সীমাবদ্ধ করুন, এবং শেষে ধাপে ধাপে মুছুন।
“ইন্টারঅপারেবিলিটি”র মত বড় ধারণাগুলো বিমূর্ত লাগতে পারে—কিন্তু প্রতিদিনের সিস্টেমগুলো দেখলে সেটা স্পষ্ট হয়: আপনি যখন কোনো ওয়েবসাইট খুলেন বা মেসেজ পাঠান, TCP/IP, DNS, এবং ইমেল (SMTP) নীরবে একে অপরের সঙ্গে সহযোগিতা করে।
প্রারম্ভিক নেটওয়ার্কগুলো হয়ত দ্বীপে পরিণত হত: প্রতিটি ভেন্ডর বা দেশই একটি অসামঞ্জস্যপূর্ণ প্রটোকল স্ট্যাক চালাত। TCP/IP এমন একটি সাধারণ “ডেটা কিভাবে চলে” ভিত্তি দিয়েছিল যা সবাইকে একই হার্ডওয়্যার কিনতে বা একই অপারেটিং সিস্টেম চালাতে বাধ্য করত না।
মুখ্য বিজয় ছিল TCP/IP নিখুঁত হওয়া নয়—বরং এটি যথেষ্ট ভালো, খোলা স্পেসিফাইড, এবং বহু পক্ষের দ্বারা বাস্তবায়নযোগ্য ছিল। একবার পর্যাপ্ত নেটওয়ার্ক এটিকে গ্রহণ করল, একটি অসামঞ্জস্যপূর্ণ স্ট্যাক বেছে নেওয়া মানে পরিণত হত বিচ্ছিন্নতা বেছে নেওয়া।
IP ঠিকানাগুলো মানুষের জন্য কঠিন এবং সার্ভিসের জন্য ভঙ্গুর। DNS নামকরণ সমাধান করল—মানব-বন্ধু নামগুলোকে রুটেবল ঠিকানায় রূপান্তর করে।
কিন্তু নামকরণ শুধুমাত্র প্রযুক্তিগত মানচিত্র নয়। এটা পরিষ্কার ডেলিগেশন চায়: কে নাম তৈরি করতে পারে, কে পরিবর্তন করতে পারে, এবং দ্বন্দ্ব কিভাবে প্রতিরোধ করা হবে। DNS কাজ করেছে কারণ এটি একটি সরল প্রটোকলকে সমন্বিত নামস্পেসের সঙ্গে জোড়া দিয়েছিল, যা স্বাধীন অপারেটরদের তাদের নিজস্ব ডোমেইন চালাতে দেয় বিঘ্ন না করে।
ইমেল সফল হয় কারণ SMTP সংকীর্ণ প্রতিশ্রুতি উপর মনোযোগ দিয়েছিল: সার্ভারের মধ্যে বার্তা স্থানান্তরের জন্য একটি সাধারণ ফরম্যাট এবং প্রত্যাশিত কথোপকথন।
ঐ ঢিলা কাপলিং গুরুত্বপূর্ণ ছিল। ভিন্ন প্রতিষ্ঠান ভিন্ন মেইল সফটওয়্যার, স্টোরেজ পদ্ধতি, এবং স্প্যাম নীতি চালিয়ে যেতে পারতেন, তবুও মেইল একে অপরের সাথে বিনিময় করতে পারে। SMTP একটি একক প্রদানকারী বা একক ব্যবহারকারীর অভিজ্ঞতা জোর করে না—এটি কেবল হ্যান্ডঅফ মানক করে দেয়।
একসাথে, এই স্ট্যান্ডার্ডগুলি একটি ব্যবহারিক চেইন গঠন করে: DNS সঠিক গন্তব্য খুঁজে পেতে সাহায্য করে, TCP/IP প্যাকেটগুলো পৌঁছে দেয়, এবং SMTP সংযুক্ত হলে মেইল সার্ভারগুলো কী বলে সে কথাটি নির্ধারণ করে।
“ইন্টারনেট গভর্নেন্স” শোনা যায় সমঝোতা ও নিয়ন্ত্রকের কথায়। প্রাথমিক ইন্টারনেটে এটি প্রায়ই দেখায় ছোট, ব্যবহারিক সিদ্ধান্তগুলোর ধারাবাহিকতা: কোন সংখ্যা রিজার্ভ করা হবে, একটি প্রটোকল ফিল্ডের মান কী বোঝায়, কিভাবে সংশোধনী প্রকাশ করা হবে, বা কখন দুই প্রস্তাব মিশবে। পোস্টেলের প্রভাব আনুষ্ঠানিক কর্তৃত্ব থেকে কম এসেছিল এবং তিনি ছিলেন সেই ব্যক্তি যিনি সেই সিদ্ধান্তগুলো চালিয়ে নিয়ে যেতেন—এবং নথিভুক্ত করতেন।
কোনো কেন্দ্রীয় “ইন্টারনেট পুলিশ” ছিল না। গভর্নেন্স অভ্যাসের মাধ্যমে ঘটত যা সহযোগিতা করা সহজ পথ করেছিল। যখন কোনো প্রশ্ন উঠে—যেমন প্যারামিটার রেজিস্ট্রি বা স্পেসিফিকেশনের অস্পষ্টতা—তাহলে কাউকে একটা উত্তর নিতে হতো, লিখে রাখতে হতো, এবং সেটা প্রচার করতে হতো। পোস্টেল, এবং পরে তিনি যে IANA ফাংশন তত্ত্বাবধান করেছিলেন, পরিষ্কার সমন্বয় পয়েন্ট হিসেবে কাজ করত। ক্ষমতা ছিল নীরব: যদি আপনি চান আপনার সিস্টেম অন্যদের সাথে কাজ করুক, আপনি শেয়ার্ড সিদ্ধান্তগুলোর সাথে তাল মিলিয়ে নিতেন।
বিশ্বাস তৈরি হত স্বচ্ছ রেকর্ডের মাধ্যমে। RFC এবং পাবলিক মেলিং লিস্ট আলোচনাগুলো মানে সিদ্ধান্তগুলো ব্যক্তিগত মিটিংয়ে লুকানো ছিল না। এমনকি ব্যক্তিরা বিচারবলি করলে তাদের একটি অডিট ট্রেইল রেখে যাওয়া প্রত্যাশিত ছিল: কারণ, প্রসঙ্গ, এবং অন্যরা কিভাবে চ্যালেঞ্জ বা উন্নতি করতে পারে তার পথ।
জবাবদিহিতা মূলত বাস্তবায়নকারীদের ও সহকর্মীদের মাধ্যমে আসত। যদি কোনো সিদ্ধান্ত ভাঙন ঘটায়, প্রতিক্রিয়া তাৎক্ষণিক ছিল—সফটওয়্যার ব্যর্থ হয়, অপারেটররা অভিযোগ করে, এবং বিকল্প বাস্তবায়নগুলো এজ কেসগুলো প্রমাণ করে। বাস্তবে জোর হতো গ্রহণের ওপর: কাজ করা স্ট্যান্ডার্ড ছড়িয়ে পড়ে; কাজ না করা স্ট্যান্ডার্ড উপেক্ষিত বা সংশোধিত হয়।
এই কারণে ইন্টারনেট গভর্নেন্স প্রায়ই ইঞ্জিনিয়ারিং ট্রিয়াজের মতো দেখায়: অস্পষ্টতা কমানো, সংঘর্ষ প্রতিরোধ, সামঞ্জস্য বজায় রাখা, এবং এমন কিছু পাঠানো যা মানুষ বাস্তবায়ন করতে পারে। লক্ষ্য নিখুঁত নীতি নয়—এটি একটি নেটওয়ার্ক যা ক্রমাগত সংযুক্ত থাকছে।
ইন্টারনেটের স্ট্যান্ডার্ড সংস্কৃতি—হালকা ডকুমেন্ট, খোলা আলোচনা, এবং কার্যক্ষম বাস্তবায়ন প্রকাশের পছন্দ—বিভিন্ন নেটওয়ার্ককে দ্রুত ইন্টারঅপারেবল করে তুলতে সাহায্য করেছিল। কিন্তু একই অভ্যাসগুলোর সঙ্গেও ট্রেড-অফ ছিল যা ইন্টারনেট যখন গবেষণা প্রকল্প থেকে বৈশ্বিক অবকাঠামোতে পরিণত হলো তখন কঠিন হয়ে পড়ল।
“যে কেউই অংশ নিতে পারে” স্বয়ংক্রিয়ভাবে “সবাই অংশ নিতে পারে” বোঝায় না। অংশগ্রহণের জন্য সময়, ভ্রমণ (প্রাথমিক বছরগুলোতে), ইংরেজি দক্ষতা, এবং প্রতিষ্ঠানের সমর্থন প্রয়োজন—এগুলো অংশগ্রহণকে অসম করে তোলে এবং ক্ষমতার অসমতা সৃষ্টি করে: ভাল-অর্থায়িত কোম্পানি বা দেশ ধারাবাহিকভাবে উপস্থিত থাকতে পারে, অন্যরা শোনা কঠিন। জনগণীন সিদ্ধান্ত হলে ওখানে এজেন্ডা চালানো এবং টেক্সট খসড়া করার সক্ষমতা প্রভাবকেন্দ্রীভূত করতে পারে।
আপনি যা গ্রহণ করেন তাতে উদারতা সামঞ্জস্যকে উৎসাহ দিত, কিন্তু এটি অস্পষ্ট স্পেসিফিকেশনকেও পুরস্কৃত করতে পারে। অস্পষ্টতা ভিন্ন বাস্তবায়নকে জন্ম দেয়, এবং অসামঞ্জস্য একটি নিরাপত্তা ঝুঁকি তৈরি করে যখন সিস্টেম ভিন্ন অনুমান করে। “ক্ষমাশীল হও” কি ধীরে ধীরে “অপ্রত্যাশিত ইনপুট গ্রহণ কর” এ পরিণত হতে পারে—যা আক্রমণকারীদের জন্য আদর্শ।
প্রথমে কার্যকর কোড শিপ করা মূল্যবান, কিন্তু এটি ফলাফলগুলোকে সেই দলে পক্ষপাতী করে দিতে পারে যারা দ্রুত বাস্তবায়ন করতে পারে—প্রায়শই সম্পূর্ণভাবে সম্প্রদায় এখনও গোপনীয়তা, অপব্যবহার, বা দীর্ঘমেয়াদী অপারেশনাল প্রভাবগুলি বিবেচনা করতে পারেনি। পরে সংশোধন সম্ভব, কিন্তু অনুকূলতা বজায় রাখার কারণে কিছু ভুল অনাবদ্য হতে পারে।
অনেক প্রাথমিক ডিজাইন সিদ্ধান্ত একটি ছোট, তুলনামূলকভাবে বিশ্বাসযোগ্য সম্প্রদায়কে ধরে নিত। বাণিজ্যিক প্রেরণা, রাষ্ট্র আচরণ, এবং বৃহৎ পরিসর এসে গেলে গভর্নেন্স বিতর্ক পুনরায় উঠে আসে: কে সিদ্ধান্ত নেবে, বৈধতা কীভাবে অর্জিত হবে, এবং “rough consensus” এখন কীভাবে মান্য হবে যখন জিয়ারিংয়ে সেডাম, সার্ভেইল্যান্স, এবং বৈশ্বিক গুরুত্বপূর্ণ অবকাঠামো জড়িত।
পোস্টেল ইন্টারনেটকে কোনো মহাপরিকল্পনা দিয়ে “ম্যানেজ” করতেন না। তিনি সামঞ্জস্যকে দৈনন্দিন অনুশীলন হিসেবে গ্রহণ করে ইন্টারনেটকে একসাথে রেখেছিলেন: লিখে রাখুন, অন্যদের টেস্ট করতে দিন, এবং শেয়ার্ড শনাক্তকারীগুলো ধারাবাহিক রাখুন। আধুনিক প্রোডাক্ট টিম—বিশেষত তারা যারা প্ল্যাটফর্ম, API, বা ইন্টিগ্রেশন তৈরি করে—সরাসরি সেই মানসিকতা ধার করতে পারে।
যদি দুই টিম (বা দুই কোম্পানি) একসঙ্গে কাজ করতে হয়, কেবল ট্রাইবাল নলেজ বা “তুমি-আমাকে-কল-এ-বলবে” উপর নির্ভর করবেন না। আপনার ইন্টারফেসগুলো ডকুমেন্ট করুন: ইনপুট, আউটপুট, ত্রুটি কেস, এবং সীমাবদ্ধতা।
সরল নিয়ম: যদি এটা অন্য সিস্টেমকে প্রভাবিত করে, তাহলে এর একটি লিখিত স্পেক প্রয়োজন। স্পেক হালকা হতে পারে, কিন্তু যারা নির্ভর করে তাদের কাছে তা প্রকাশ্য হতে হবে।
ইন্টারঅপারেবিলিটি সমস্যা বাস্তব ট্র্যাফিক ও বাস্তব বাস্তবায়ন ছাড়া লুকিয়ে থাকে। একটি খসড়া স্পেক পাঠান, একটি মৌলিক রেফারেন্স ইমপ্লিমেন্টেশন তৈরি করুন, এবং অংশীদারদের আমন্ত্রণ করুন পরীক্ষায় যখন পরিবর্তন করা সহজ।
শেয়ার্ড স্পেক ও রেফারেন্স ইমপ্লিমেন্টেশন অস্পষ্টতা কমায়, এবং সবার জন্য একটি বাস্তব শুরুর পয়েন্ট দেয় বদলে-ব্যাখ্যার যুদ্ধের বদলে।
সামঞ্জস্য অনুভব হওয়া না—এটা পরীক্ষা করা যায়।
সফলতার মানদণ্ড সংজ্ঞায়িত করুন ("কীভাবে একসঙ্গে কাজ করে" তা কী বোঝায়), তারপর কনফরম্যান্স টেস্ট ও কম্প্যাটিবিলিটি লক্ষ্য তৈরি করুন যা টিমগুলো CI-তে চালাতে পারে। যখন অংশীদাররা একই টেস্ট চালাতে পারে, বিরোধগুলো অ্যাকশনযোগ্য বাগ হয়ে যায় অনন্ত তর্ক নয়।
স্থিতিশীলতার জন্য পরিবর্তনের একটি পূর্বানুমিত পথ দরকার:
পোস্টেলের ব্যবহারিক পাঠ সহজ: সমন্বয় তখনই স্কেল করে যখন আপনি মানুষ ও মেশিনের উভয়ের জন্য বিস্ময় কমান।
IETF কেন দ্রুত একত্রিত হতে পারত—একটি কারণ হলো আইডিয়াগুলো তত্ত্বে বেশিক্ষণ থাকত না—সেগুলো দ্রুত রানযোগ্য বাস্তবায়নে পরিণত হত যাতে অন্যরা পরীক্ষা করতে পারে। আধুনিক দলগুলোও লাভ করতে পারে যদি তারা “আমরা ইন্টারফেসে একমত” থেকে “দুই স্বাধীন বাস্তবায়ন ইন্টারঅপারেবল” পর্যন্ত পথটি ঝঞ্ঝাটহীন করে।
প্ল্যাটফর্মগুলো যেমন Koder.ai সেই অভিন্ন চেষ্টায় সহায়ক: আপনি একটি লিখিত API খসড়া থেকে একটি কাজ করা ওয়েব অ্যাপ (React), ব্যাকএন্ড (Go + PostgreSQL), বা মোবাইল ক্লায়েন্ট (Flutter) পর্যন্ত যেতে পারেন চ্যাট-চালিত ওয়ার্কফ্লোর মাধ্যমে, তারপর দ্রুত স্ন্যাপশট/রোলব্যাক ও সোর্স-কোড এক্সপোর্ট দিয়ে পুনরাবৃত্তি করতে পারেন। টুলইনগ মান নয়—কিন্তু এগুলো স্পষ্ট চুক্তি, দ্রুত প্রোটোটাইপিং, এবং পুনরুৎপাদনযোগ্য বাস্তবায়নের মতো স্ট্যান্ডার্ড-সদৃশ অভ্যাসগুলো ধারাবাহিকভাবে অনুশীলন করা সহজ করে।
ইন্টারঅপারেবিলিটি স্বয়ংক্রিয় ছিল না কারণ প্রাথমিক নেটওয়ার্কিং ছিল ভিন্ন ভিন্ন অনুমান ও আর্কিটেকচারের একটা প্যাচওয়ার্ক—এড্রেস ফরম্যাট, বার্তা আকার, পুনরায় চেষ্টা করার টাইমার, ত্রুটি পরিচালনা, এবং এমনকি প্ররোচনা (incentives) ভিন্ন ছিল।
শেয়ার করা চুক্তি না থাকলে আপনি পেলেন বিচ্ছিন্ন "দ্বীপ"—যেগুলোকে কেবল কাচা, ভাঙনশীল কাস্টম গেটওয়ে দিয়ে যোগ করা যায়।
কাস্টম প্রটোকল ব্রিজগুলো বানানো ও রক্ষণাবেক্ষণ করা ব্যয়বহুল এবং সহজে ভেঙে যায়, এবং যখন যেকোনো দিক পরিবর্তিত হয় তখন সেগুলো খুঁত বিঘ্নিত করে।
এটি গড়ে তোলে ভেন্ডর/অপারেটর লক-ইন, কারণ “অনুবাদ স্তর” কন্ট্রোল করা পক্ষটি নিয়ম নির্ধারণ করতে পারে এবং প্রতিদ্বন্দীদের ধীর করতে পারে।
কারণ যদি একটি “সেরা” প্রটোকল বিস্তৃতভাবে বাস্তবায়িত না করা যায় তবে তা জয়ের যোগ্য নয়।
একটি সামান্য আপোষপ্রবণ কিন্তু ব্যাপকভাবে বাস্তবায়নযোগ্য স্ট্যান্ডার্ড অনেক বেশি নেটওয়ার্ককে সংযুক্ত করতে পারে, তুলনায় একটি তত্ত্বগতভাবে উৎকৃষ্ট পদ্ধতির যা কেবল একটিই ইকোসিস্টেমে কাজ করে।
তিনি আনুষ্ঠানিক কর্তৃত্বের ওপর নির্ভর না করে অর্জিত বিশ্বাস-এর মাধ্যমে প্রভাব ফেলতেন: পরিষ্কার লেখা, ধৈর্যশীল সমন্বয়, এবং ধারাবাহিক বাস্তবায়ন।
তিনি সেই অপ্রীতিকর কাজও করতেন (সম্পাদকীয় কাজ, স্পষ্টকরণ, সিদ্ধান্তের দিকে টেনে নেওয়া, রেজিস্ট্রিগুলো বজায় রাখা) যা স্বাধীন বাস্তবায়নকারীদের একসাথে রাখে।
RFC (Request for Comments) হলো একটি সর্বজনীন মেমো যা ইন্টারনেট প্রটোকল বা অপারেশনাল পদ্ধতি ব্যাখ্যা করে।
ব্যবহারিকভাবে, এটি বাস্তবায়নকারীদের একটি সাধারণ রেফারেন্স দেয়: ফরম্যাট, এজ কেস, এবং আচরণগুলো লিখে রাখা যাতে ভিন্ন দলে একইভাবে নির্মাণ করা যায়।
“Rough consensus” মানে দলের মধ্যে বিস্তৃত একমতানুকূলে পৌঁছানো—সম্পূর্ণ ঐক্যমত্য নয়।
“Running code” মানে প্রস্তাবিত আইডিয়াগুলোকে বাস্তবে প্রমাণ করা—ইডিয়াগুলো কাজ করে কিনা তা বাস্তবায়ন দেখিয়ে দেখানো, ইচ্ছাকৃতভাবে স্বতন্ত্র কয়েকটি ইম্প্লিমেন্টেশন থাকা উত্তম।
ফ্র্যাগমেন্টেশন মানে হবে অসামঞ্জস্যপূর্ণ মিনি-নেটওয়ার্কগুলো—বারবার কাস্টম ইন্টিগ্রেশন, উচ্চ সোয়াচিং খরচ, এবং ভেন্ডর লক-ইন।
ব্যবহারিকভাবে এর খরচগুলো হলো:
IETF একটি খোলা প্রক্রিয়া দেয় যেখানে কেউই ড্রাফট পড়তে, আলোচনায় অংশ নিতে, ও বাস্তবায়ন থেকে প্রমাণ দিতে পারে।
ঐতিহ্যগত হায়ারার্কির পরিবর্তে প্রভাব আসে কাজ করে দেখানোর মাধ্যমে: ড্রাফট লেখা, আইডিয়া পরীক্ষা করা, রিভিউ-তে জবাব দেওয়া, এবং স্পষ্টতা উন্নত করা—যখন পর্যন্ত সিস্টেমগুলো আন্তঃকার্যকর না হয়ে ওঠে।
IANA শেয়ার্ড রেজিস্ট্রি বজায় রাখে (প্রটোকল সংখ্যা, পোর্ট সংখ্যা, প্যারামিটার কোড ইত্যাদি) যাতে স্বাধীন বাস্তবায়নকারীরা একই মান ব্যবহার করে।
একক রেফারেন্স না থাকলে সংঘর্ষ দেখা দেয় (একই সংখ্যাকে ভিন্ন অর্থে বরাদ্দ করা) এবং কঠিন-ডিবাগ অমিল তৈরি হয় যা অন্যথায় সঠিক স্ট্যান্ডার্ডকেও দুর্বল করে দেয়।
পোস্টেল-র নির্দেশ: যা আপনি পাঠান তাতে কঠোর হন, যা আপনি গ্রহণ করেন তাতে নমনীয় হন—প্রাথমিক সিস্টেমগুলোকে একে অপরের সঙ্গে যোগাযোগ করতে সাহায্য করছিল।
কিন্তু অতিরিক্ত সহনশীলতা বিকৃত ইনপুটকে স্বাভাবিক করে দিতে পারে এবং নিরাপত্তা ও ইন্টারঅপারেবিলিটি সমস্যার কারণ হয়ে দাঁড়ায়। আধুনিক ধরণ: ইন্টারঅপারেবিলিটি কিন্তু রক্ষনশীলতা সহ—কঠোরভাবে যাচাই করুন, ব্যতিক্রম নথিভুক্ত করুন, লগ করুন এবং ধাপে ধাপে বন্ধ করুন।