১৭ সেপ, ২০২৫·7 মিনিট পড়তে

মোবাইল অ্যাপের API ভার্সনিং: এন্ডপয়েন্ট নিরাপদে উন্নয়ন করুন

মোবাইল অ্যাপের জন্য API ভার্সনিং সহজ ভাষায়: ধাপে রোলআউট প্ল্যান, পিছনে سازযোগ্য পরিবর্তন এবং ডিপ্রেকশন পদক্ষেপ যাতে পুরনো অ্যাপগুলো কাজ করে থাকে।

মোবাইল অ্যাপের API ভার্সনিং: এন্ডপয়েন্ট নিরাপদে উন্নয়ন করুন

কেন API পরিবর্তন মোবাইল ব্যবহারকারীদের ভাঙে

মোবাইল অ্যাপ একসাথে সব ব্যবহারকারীর কাছে আপডেট হয় না। আপনি আজ যদি ফিক্স পাঠান তবুও অনেকেই পুরনো ভার্সনে কয়েক দিন বা সপ্তাহ থাকেন। কেউ অটো-আপডেট বন্ধ করে রাখে। কেউ স্টোরেজ কম থাকায় আপডেট করতে পারে না। কেউ সহজেই অ্যাপ খুলে না। অ্যাপ স্টোর রিভিউ সময় এবং স্টেজড রিলিজ আরো বিলম্ব যোগ করে।

এই ব্যবধান গুরুত্বপূর্ণ কারণ আপনার ব্যাকএন্ড সাধারণত মোবাইল ক্লায়েন্টদের তুলনায় দ্রুত বদলায়। সার্ভার যদি কোনো এন্ডপয়েন্ট বদলে দেয় এবং পুরনো অ্যাপ সেটি কল করে, তাহলে যে ব্যবহারকারীর ফোনে কিছুই বদলায়নি তবুও অ্যাপ ভেঙে যেতে পারে।

ভাঙচুর সাধারণত পরিষ্কার এরর মেসেজ হিসেবে দেখা যায় না। এটি দৈনন্দিন প্রোডাকশন কষ্টের মতো দেখা যায়:

  • ব্যাকএন্ড রিলিজের পরে লগইন বা সাইন-আপ ব্যর্থ হওয়া
  • কোনো ফিল্ড নাম বদলানোর বা সরানোর কারণে তালিকা খালি দেখা যাওয়া
  • মিসিং ভ্যালু পড়ার সময় অ্যাপ ক্র্যাশ করা
  • যাচাই কড়া হওয়ার কারণে পেমেন্ট ব্যর্থ হওয়া
  • রেসপন্স শেপ বদলায় ফিচার নীরবে অদৃশ্য হয়ে যাওয়া

ভার্সনিং-এর মূল উদ্দেশ্য সোজা: সবার একসঙ্গে আপডেট করার জন্য বাধ্য না করে সার্ভার উন্নতি চালিয়ে যাওয়া। আপনার API-কে একটি দীর্ঘমেয়াদি চুক্তি হিসেবে দেখতে হবে। নতুন অ্যাপ ভার্সনগুলো নতুন সার্ভার আচরণে কাজ করবে, এবং পুরনো ভার্সনগুলো বাস্তব আপডেট চক্রে পর্যাপ্ত সময় চলে যাবে।

বেশিরভাগ কনসিউমার অ্যাপের জন্য, একই সময়ে একাধিক অ্যাপ ভার্সন সমর্থন করতে হবে বলে توقع করুন। অভ্যন্তরীণ অ্যাপ কখনও দ্রুত এগোতে পারে, তবুও তা দ্রুতই সম্পূর্ণ নয়। ওভারল্যাপের পরিকল্পনা করলে ধাপবদ্ধ রোলআউটগুলো শান্ত থাকে এবং প্রতিটি ব্যাকএন্ড রিলিজ সাপোর্ট স্পাইক হয়ে ওঠে না।

API চুক্তিতে “কম্প্যাটিবল” মানে কী

API চুক্তি হলো আপনার মোবাইল অ্যাপ এবং সার্ভারের মধ্যকার প্রতিশ্রুতি: কোন URL কল করবে, কী ইনপুট গ্রহণ করবে, রেসপন্স কেমন হবে, এবং প্রতিটি ফিল্ডের মানে কী। অ্যাপ যদি সেই প্রতিশ্রুতির উপর নির্ভর করে এবং সার্ভার তা বদলে ফেলে, ব্যবহারকারীরা সেটিকে ক্র্যাশ, মিসিং ডেটা বা কাজ না করা ফিচার হিসেবে অনুভব করবে।

কোনও পরিবর্তন তখনই কম্প্যাটিবল যখন পুরনো অ্যাপগুলো কোনো কোড পরিবর্তন ছাড়াই API ব্যবহার চালিয়ে যেতে পারে। অনুশীলনে এর মানে সার্ভার এখনও পুরনো অ্যাপের পাঠানো জিনিসগুলো বুঝে এবং সেই রেসপন্স পুরনো অ্যাপ পার্স করতে পারে।

নিম্নে নিরাপদ পরিবর্তন এবং ঝুঁকিপূর্ণ পরিবর্তনের দ্রুত বিভাজন:

  • ব্রেকিং পরিবর্তন: একটি ফিল্ড সরানো বা নাম বদলানো, টাইপ বদলানো (নাম্বর থেকে স্ট্রিং), একটি অপশনাল ফিল্ডকে বাধ্যতামূলক করা, এরর ফরম্যাট বদলানো, এমনভাবে ভ্যালিডেশন কড়া করা যাতে পুরনো অ্যাপ তা মেটাতে পারে না।
  • সাধারণত নিরাপদ পরিবর্তন: নতুন অপশনাল ফিল্ড যোগ করা, নতুন এন্ডপয়েন্ট যোগ করা, পুরনো এবং নতুন রিকোয়েস্ট ফরম্যাট দুটোই গ্রহণ করা, নতুন enum মান যোগ করা (শর্তে যে অ্যাপ অজানা মানকে “other” হিসেবে হ্যান্ডেল করে)।

কম্প্যাটিবিলিটির জন্য একটি অবসান পরিকল্পনাও দরকার। পুরনো আচরণ অবসর দেওয়া ঠিক আছে, কিন্তু এটি নির্ধারিত হওয়া উচিৎ (উদাহরণ: “v2 রিলিজের 90 দিন পর v1 বজায় রাখুন”) যাতে ব্যবহারকারীদের অবাক না করা যায়।

সাধারণ ভার্সনিং পদ্ধতি ও ট্রেডঅফ

ভার্সনিং হলো পুরনো বিল্ডগুলোকেই একটি স্থিতিশীল চুক্তি দেওয়া যাতে আপনি এগিয়ে যেতে পারেন। কয়েকটি পরিচিত পন্থা আছে, এবং প্রত্যেকটি জটিলতা আলাদা জায়গায় রাখে।

URL ভার্সনিং

পাথেই ভার্সন রাখা (যেমন /v1/ এবং /v2/) দেখতেও সহজ এবং ডিবাগ করতেও সুবিধাজনক। এটি caching, logging, এবং routing-এর সঙ্গে ভালো কাজ করে কারণ ভার্সন URL-এর অংশ। অসমতা হল দলগুলো প্রায়শই পার্শ্ববর্তী হ্যান্ডলার দীর্ঘ সময় ধরে ধরে রাখে, এমনকি যখন পার্থক্য ছোট।

হেডার-ভিত্তিক ভার্সনিং

ক্লায়েন্ট একটি হেডারে ভার্সন পাঠায় (উদাহরণ: Accept হেডার বা কাস্টম হেডার)। URL পরিষ্কার থাকে, এবং প্রতিটি পাথ বদলানোর প্রয়োজন পড়ে না। অসমতা হল দৃশ্যমানতা: প্রক্সি, লগ এবং মানুষ মাঝে মাঝে ভার্সন মিস করে, এবং মোবাইল ক্লায়েন্টগুলোকে প্রতিটি অনুরোধে হেডার নির্ভরভাবে সেট করতে হবে।

কুয়েরি প্যারামিটার ভার্সনিং

কুয়েরি ভার্সনিং (যেমন ?v=2) দেখতে সহজ, কিন্তু এটি বিশৃঙ্খল হয়ে যায়। প্যারামিটারগুলো বুকমার্ক, অ্যানালিটিক্স টুল এবং স্ক্রিপ্টগুলোতে কপি হয়ে যায়, এবং নানা “ভার্সন” ভেসে বেড়াতে পারে যার পরিষ্কার মালিকানা নেই।

সরল তুলনা করতে চাইলে:

  • URL ভার্সনিং: ইনস্পেক্ট করা সহজ, কিন্তু দীর্ঘমেয়াদি পার্শ্ববর্তী API তৈরি করতে পারে
  • Header ভার্সনিং: পরিষ্কার URL, কিন্তু ট্রাবলশুটিং কঠিন
  • Query ভার্সনিং: শুরুতে দ্রুত, কিন্তু অপব্যবহারের সহজ পথ

ফিচার ফ্ল্যাগগুলো আলাদা টুল। এগুলো একই চুক্তির পেছনে আচরণ বদলাতে দেয় (উদাহরণ: নতুন র‍্যাঙ্কিং অ্যালগরিদম) बिना নতুন API ভার্সন তৈরি করার। যখন রিকোয়েস্ট বা রেসপন্স শেপ বদলাতে হবে, ফিচার ফ্ল্যাগ ভার্সনিংকে প্রতিস্থাপিত করতে পারবে না।

একটি পদ্ধতি বেছে নিন এবং এতে স্থির থাকুন। ধারাবাহিকতা “পারফেক্ট” পছন্দের চেয়ে বেশি গুরুত্বপূর্ণ।

পিছনে سازযোগ্য পরিবর্তনের সাধারণ নির্দেশিকা

সবচেয়ে নিরাপদ মানসিকতা: পুরনো ক্লায়েন্টগুলো আপডেট না করে থাকলেও কাজ চালিয়ে যেতে পারে। সাধারণত এর মানে হলো নতুন যোগ করা, পুরনো বদলানো নয়।

অ্যাডিটিভ পরিবর্তনকে প্রাধান্য দিন: নতুন ফিল্ড, নতুন এন্ডপয়েন্ট, নতুন অপশনাল প্যারামিটার। যখন আপনি কিছু যোগ করেন, সার্ভারের দিক থেকে এটাকে প্রকৃতপক্ষে অপশনাল রাখুন। যদি পুরনো অ্যাপ এটি না পাঠায়, সার্ভার ঠিক আগের মতো আচরণ করা উচিত।

কিছু অভ্যাস যা অধিকাংশ ব্রেকেজ আটকায়:

  • ফিল্ড যোগ করুন, কিন্তু বিদ্যমান ফিল্ডের টাইপ বা মান বদলাবেন না।
  • সুসঙ্গত ডিফল্ট ব্যবহার করে মিসিং ইনপুট নর্মাল হিসেবে বিবেচনা করুন।
  • অজানা রিকোয়েস্ট ফিল্ডগুলো উপেক্ষা করুন যাতে পুরনো ও নতুন ক্লায়েন্ট একসঙ্গে থাকতে পারে।
  • এরর ফরম্যাট স্থিতিশীল রাখুন। যদি বদলাতে হয়, এরর পে-লোড ভার্সন করুন।
  • আচরণ পরিবর্তন প্রয়োজন হলে নতুন এন্ডপয়েন্ট বা ভার্সন চালু করুন, “নীরব” টুইকের বদলে।

একটি বিদ্যমান ফিল্ডের মান বদলানো এড়িয়ে চলুন যতক্ষণ না ভার্সন বাম্প করা হয়েছে। উদাহরণ: যদি status=1 পূর্বে “paid” বোঝাত এবং আপনি এটিকে “authorized” হিসেবে পুনরায় ব্যবহার করেন, তাহলে পুরনো অ্যাপ ভুল সিদ্ধান্ত নেবে এবং ব্যবহারকারীর অভিযোগ না পাওয়া পর্যন্ত সেটা ধরা পড়বে না।

রিনেম এবং রিমুভাল-এর জন্য একটি পরিকল্পনা থাকুক। সবচেয়ে নিরাপদ প্যাটার্ন হলো পুরনো ফিল্ডকে রেখে নতুনটি সাইড-বাই-সাই যোগ করা। উভয় রেসপন্সেPopulate করুন, রিকোয়েস্টেও দুটোই গ্রহণ করুন, এবং লগ করে রাখুন কে এখনও পুরনো ফিল্ড ব্যবহার করছে। অবসর উইন্ডো শেষে পুরনো ফিল্ডটি মুছে দিন।

একটি ছোট কিন্তু শক্তিশালী অভ্যাস: যখন নতুন বাধ্যতামূলক ব্যবসায়িক নিয়ম প্রবেশ করান, ক্লায়েন্টকে দিন একদিনে দায়ী করবেন না। প্রথমে সার্ভারে ডিফল্ট রেখে দিন, পরে অধিকাংশ ব্যবহারকারী আপডেট করলে ক্লায়েন্টকে নতুন মান পাঠাতে বাধ্য করুন।

একটি সরল ভার্সনিং ও ডিপ্রেকেশন নীতি নির্ধারণ করুন

Generate a real backend
Model data in minutes and generate a production-ready Go backend.
Create Backend

ভার্সনিং সবচেয়ে ভালো কাজ করে যখন নিয়মগুলো সাধারণ ও লিখিত থাকে। নীতি এত ছোট রাখুন যাতে প্রোডাক্ট, মোবাইল ও ব্যাকএন্ড দলগুলো সেটা বাস্তব ভাবে অনুসরণ করে।

সাপোর্ট উইন্ডো দিয়ে শুরু করুন। সিদ্ধান্ত নিন নতুন ভার্সন শিপ হওয়ার পরে পুরনো API সংস্করণগুলো কতদিন চালু থাকবে (উদাহরণ: 6–12 মাস), এবং কোনো ব্যতিক্রম (সিকিউরিটি ইস্যু, আইনি বদল)।

এরপর নির্ধারিত করুন কিভাবে ক্লায়েন্টকে ভাঙার আগে সতর্ক করা হবে। একটি ডিপ্রেকশন সিগন্যাল বেছে নিন এবং সব জায়গায় সেটি ব্যবহার করুন। সাধারণ অপশনগুলো হলো রেসপন্স হেডার যেমন Deprecation: true সহ একটি রিটায়ারমেন্ট তারিখ, অথবা নির্বাচিত রেসপন্সে একটি JSON ফিল্ড যেমন "deprecation": {"will_stop_working_on": "2026-04-01"}। গুরুত্বপূর্ণ বিষয় হলো ধারাবাহিকতা: ক্লায়েন্ট এটি সনাক্ত করতে পারে, ড্যাশবোর্ড রিপোর্ট করতে পারে, এবং সাপোর্ট দল ব্যাখ্যা করতে পারে।

একটি ন্যূনতম সমর্থিত অ্যাপ ভার্সন নির্ধারণ করুন এবং প্রয়োগ সম্পর্কে স্পষ্ট থাকুন। আচমকা হার্ড-ব্লক এড়িয়ে চলুন। ব্যবহারিক পন্থা:

  1. একটি সফট ওয়ার্নিং পাঠান (উদাহরণ: ইন-অ্যাপে আপডেট প্রম্পট ট্রিগার করবে এমন একটি ফিল্ড)।
  2. ঘোষিত ডেডলাইন পরেই প্রয়োগ করুন।

আপনি যদি রিকোয়েস্ট ব্লক করেন, স্পষ্ট এরর পে-লোড দিন যাতে মানব-গ্রাহ্য মেসেজ এবং মেশিন-রিডেবল কোড থাকে।

শেষে, নির্ধারণ করুন কে ব্রেকিং পরিবর্তন অনুমোদন করতে পারে এবং কি ডকুমেন্ট দরকার। এটাকে সোজা রাখুন:

  • একজন মালিক ব্রেকিং পরিবর্তন অনুমোদন করবেন।
  • একটি সংক্ষিপ্ত চেঞ্জ নোট হবে: কী বদলেছে, কারা প্রভাবিত, এবং মাইগ্রেশন পথ।
  • টেস্ট প্ল্যানে কমপক্ষে একটি পুরনো অ্যাপ ভার্সন কভার থাকবে।
  • ডিপ্রেকশনের সময় শুরু হলে একটি রিটায়ারমেন্ট তারিখ নির্ধারণ করা হবে।

ধাপে ধাপে রোলআউট প্ল্যান যা পুরনো অ্যাপগুলোকে কাজ চালাতে দেয়

Make version logic predictable
Centralize version routing and logic with visual business processes.
Try It Now

মোবাইল ব্যবহারকারীরা একদিনে আপডেট হয় না। সবচেয়ে নিরাপদ পন্থা হলো একটি নতুন API পাঠানো যখন পুরনোটি অক্ষত থাকে, তারপর ট্রাফিক ধীরে ধীরে সরে নিয়ে যাওয়া।

প্রথমে নির্ধারণ করুন v2 কী বদলায় এবং v1 আচরণ লক করুন। v1-কে একটি প্রতিশ্রুতি হিসেবে বিবেচনা করুন: একই ফিল্ড, একই মানে, একই এরর কোড। যদি v2-এ ভিন্ন রেসপন্স শেপ লাগে, v1-এর সাথে মিলিয়ে ফাটা ঠিক না।

পরবর্তী ধাপে v2 সমান্তরালভাবে চালান। এটি আলাদা রুট হতে পারে (যেমন /v1/... এবং /v2/...) বা একই গেটওয়ের নীচে আলাদা হ্যান্ডলার। শেয়ার করা লজিক এক জায়গায় রাখুন, কিন্তু চুক্তি আলাদা রাখুন যাতে v2 রিফ্যাক্টর হঠাৎ করে v1 বদলে না দেয়।

এরপর মোবাইল অ্যাপ আপডেট করুন যাতে এটি v2 পছন্দ করে। একটি সহজ fallback তৈরি করুন: যদি v2 “not supported” (অথবা অন্য কোন পরিচিত এরর) ফেরত দেয়, তবে v1-এ পুনরায় চেষ্টা করুক। স্টেজড রিলিজ ও নেটওয়ার্ক মেশিনারিজের সময় এটি সাহায্য করে।

অ্যাপ রিলিজের পরে গ্রহণ ও এরর মনিটর করুন। দরকারী চেকগুলো:

  • অ্যাপ ভার্সন অনুযায়ী v1 বনাম v2 অনুরোধ ভলিউম
  • v2-এর এরর রেট ও ল্যাটেন্সি
  • রেসপন্স পার্সিং ব্যর্থতা
  • নেটওয়ার্কিং স্ক্রিনের সাথে সংযুক্ত ক্র্যাশ

v2 স্থিতিশীল হলে v1-এর জন্য স্পষ্ট ডিপ্রেকশন সতর্কতা যোগ করুন এবং একটি টাইমলাইন জানিয়ে দিন। v1 তখনই অবসর দিন যখন ব্যবহার কয়েক সপ্তাহ ধরে একটি স্বীকার্য সীমারচেয়ে কমে যায় (উদাহরণ: 1–2% এর নিচে)।

উদাহরণ: আপনি GET /orders-এ ফিল্টারিং ও নতুন স্ট্যাটাস যোগ করেন। v2 status_details যোগ করে আর v1 অপরিবর্তিত থাকে। নতুন অ্যাপ v2 কল করে, কিন্তু কোনো এজ কেসে যদি ব্যর্থ হয় তবে v1-এ fallback করে এবং অর্ডার তালিকা এখনও দেখায়।

সার্ভার সাইডে বাস্তবায়নের টিপস

বেশিরভাগ রোলআউট ব্রেকেজ হয় কারণ ভার্সন হ্যান্ডলিং কন্ট্রোলার, হেল্পার এবং ডেটাবেস কোড জুড়ে ছড়িয়ে থাকে। “এই অনুরোধের ভার্সন কী?” সিদ্ধান্ত এক জায়গায় রাখুন, এবং বাকী লজিকটি পূর্বানুমেয় রাখুন।

ভার্সন রাউটিং একটি গেটে রাখুন

একটি সিগন্যাল বেছে নিন (URL সেগমেন্ট, হেডার, বা অ্যাপ বিল্ড নম্বর) এবং শুরুর দিকে তা নরমালাইজ করুন। একটি মডিউল বা মিডলওয়্যারের মাধ্যমে সঠিক হ্যান্ডলার-এ রুট করুন যাতে প্রতিটি অনুরোধ একই পথ অনুসরণ করে।

ব্যবহারিক প্যাটার্ন:

  • একবার ভার্সন পার্স করুন (এবং লগ করুন)।
  • একটি রেজিস্ট্রীতে ভার্সনকে হ্যান্ডলারের সাথে ম্যাপ করুন (v1, v2, ...)।
  • শেয়ার করা ইউটিলিটিজ ভার্সন-নিরপেক্ষ রাখুন (ডেট পার্সিং, auth চেক), না যে রেসপন্স-শেপ লজিক।

ভার্সনের মধ্যে শেয়ার করা কোড ব্যবহার করার সময় সতর্ক থাকুন। shared কোডে v2 বাগ ফিক্স করলে সেটা অসাবধানতাবশত v1 আচরণ বদলে দিতে পারে। যদি লজিক আউটপুট ফিল্ড বা ভ্যালিডেশন নিয়ম প্রভাবিত করে, তবে তা ভার্সনভিত্তিক রাখুন বা ভের্সন-নির্দিষ্ট টেস্ট কভারেজ রাখুন।

রোলআউটের সময় ডেটা পরিবর্তনগুলিকে কম্প্যাটিবল রাখুন

ডাটাবেস মাইগ্রেশনকে এমনভাবে করুন যাতে উভয় ভার্সন একসাথে কাজ করতে পারে। প্রথমে কলাম যোগ করুন, প্রয়োজনে ব্যাকফিল করুন, এবং পরে কনস্ট্রেইন্ট সরান বা কষাটান। মাঝপথে নাম পরিবর্তন বা অর্থ বদলাবেন না। যদি ফরম্যাট পরিবর্তন দরকার হয়, তাহলে একটি সময়ের জন্য দুটো ফরম্যাট লিখুন যতক্ষণ না বেশিরভাগ ক্লায়েন্ট সরে যায়।

এররগুলোকে পূর্বানুমেয় করুন। পুরনো অ্যাপগুলো প্রায়ই অজানা এররকে “কিছু ভুল হয়েছে” হিসেবে ধরে। স্থিতিশীল স্ট্যাটাস কোড, সোজা এরর আইডেন্টিফায়ার, এবং সংক্ষিপ্ত মেসেজ ব্যবহার করুন যাতে ক্লায়েন্টরা সিদ্ধান্ত নিতে পারে (রিট্রাই, পুনরায় প্রমাণীকরণ, বা আপডেট দেখানো)।

অবশেষে, মিসিং ফিল্ড যেগুলো পুরনো অ্যাপ পাঠায় না সেগুলো থেকে সাবধান থাকুন। নিরাপদ ডিফল্ট ব্যবহার করুন এবং স্পষ্ট, স্থিতিশীল এরর ডিটেইল দিয়ে ভ্যালিডেট করুন।

মোবাইল অ্যাপ বিবেচ্য বিষয়সমূহ যা ভার্সনিং-কে প্রভাবিত করে

Build safer mobile APIs
Design and ship a versioned backend without hand-coding every endpoint.
Try AppMaster

ব্যবহারকারীরা কয়েক সপ্তাহ পুরনো বিল্ডে থাকতে পারে বলে ভার্সনিংকে ধরে রাখতে হবে যে একাধিক ক্লায়েন্ট ভার্সন একই সময়ে সার্ভারকে ট্রাফিক দিচ্ছে।

একটি বড় লাভ হলো ক্লায়েন্ট-সাইড সহনশীলতা। সার্ভার নতুন ফিল্ড যোগ করলে যদি অ্যাপ ক্র্যাশ করে বা পার্সিং ব্যর্থ করে, তখন আপনি “র‍্যাণ্ডম” রোলআউট বাগ পাবেন।

  • অজানা JSON ফিল্ড উপেক্ষা করুন।
  • মিসিং ফিল্ডকে নর্মাল ধরে ডিফল্ট ব্যবহার করুন।
  • নাল safely হ্যান্ডেল করুন (মাইগ্রেশনের সময় ফিল্ডগুলো nullable হতে পারে)।
  • অ্যারে ordering-এ নির্ভর করবেন না যদি চুক্তি তা গ্যারান্টি না করে।
  • এরর হ্যান্ডলিং ব্যবহারকারী-বান্ধব রাখুন (রিট্রাই স্টেট একটি খালি স্ক্রিনের থেকে ভালো)।

নেটওয়ার্ক আচরণও গুরুত্বপূর্ণ। রোলআউটের সময় লোড ব্যালান্সার বা ক্যাশের পেছনে মিশ্র সার্ভার ভার্সন থাকতে পারে, এবং মোবাইল নেটওয়ার্ক ছোট সমস্যাগুলোকেও বাড়িয়ে দেয়।

স্পষ্ট টাইমআউট ও রিট্রাই নিয়ম বেছে নিন: রিড কলগুলোর জন্য ছোট টাইমআউট, আপলোডের জন্য একটু বড়, এবং সীমিত ব্যাকঅফসহ রিট্রাই। ক্রিয়েট বা পেমেন্ট-জাতীয় কলগুলোর জন্য idempotency স্ট্যান্ডার্ড করুন যাতে রিট্রাই ডাবল-সাবমিশন না করে।

অথেন্টিকেশন পরিবর্তন সবচেয়ে দ্রুতভাবে পুরনো অ্যাপকে লক আউট করে। যদি আপনি টোকেন ফরম্যাট, আবশ্যক স্কোপ, বা সেশন নিয়ম বদলান, একটি overlap উইন্ডো রাখুন যেখানে পুরনো ও নতুন টোকেন দুটোই কাজ করে। কীগুলো বা ক্লেইম রোটেট করতে হলে স্টেজড মাইগ্রেশন পরিকল্পনা করুন, একই দিনে কাটওভার নয়।

প্রতি রিকোয়েস্টে অ্যাপ মেটাডেটা পাঠান (উদাহরণ: অ্যাপ ভার্সন ও প্ল্যাটফর্ম)। এতে টার্গেটেড সতর্কতা ফিরিয়ে দিতে সুবিধা হবে, পুরো API ভাঙতে না গিয়েও।

মনিটরিং এবং ধাপে ধাপে রোলআউট ছাড়া আগাম আশ্চর্যবিস্ময়

একটি ধাপে ধাপে রোলআউট তখনই কাজ করে যখন আপনি দেখতে পারেন বিভিন্ন অ্যাপ ভার্সন কী করছে। লক্ষ্য সরল: কে এখনও পুরনো এন্ডপয়েন্ট ব্যবহার করছে তা জানুন, এবং সমস্যা সবাইকে পৌঁছানোর আগেই ধরুন।

প্রতিদিন API ভার্সন অনুযায়ী ব্যবহার ট্র্যাক করা দিয়ে শুরু করুন। মোট অনুরোধ গোনা মাত্রই নয়—সক্রিয় ডিভাইস গননা করুন, এবং লগইন, প্রোফাইল ও পেমেন্টসের মতো গুরুত্বপূর্ণ এন্ডপয়েন্টগুলো ভেঙে দেখুন। এটি বলে দেবে কোন পুরনো ভার্সন এখনও “লাইভ” আছে এমনকি মোট ট্রাফিক কম থাকলেও।

তারপর এররগুলো ভার্সন ও টাইপ অনুযায়ী দেখুন। 4xx বৃদ্ধির মানে সাধারণত চুক্তি মিলছে না (বাধ্যতামূলক ফিল্ড বদলেছে, enum মান সরল হয়েছে, auth কঠোর হয়েছে)। 5xx বৃদ্ধি সাধারণত সার্ভার রিগ্রেশন নির্দেশ করে (খারাপ ডেপ্লয়, ধীর কুয়েরি, ডিপেন্ডেন্সি ব্যর্থতা)। ভার্সন অনুযায়ী এগুলো দেখা আপনাকে দ্রুত সঠিক সমাধান নিতে সাহায্য করে।

অ্যাপ স্টোরে স্টেজড রোলআউট ব্যবহার করুন যাতে ব্লাস্ট রেডিয়াস সীমিত থাকে। প্রকাশের ধাপগুলো বাড়ান এবং প্রতিটি ধাপের পরে একই ড্যাশবোর্ডগুলো দেখুন (উদাহরণ: 5%, 25%, 50%)। যদি নতুন ভার্সনে সমস্যা দেখায়, রোলআউট বন্ধ করুন আগেই যাতে পূর্ণ আউটেজ না হয়।

রোলব্যাক ট্রিগারগুলো আগেই লিখে রাখুন, ঘটনা ঘটার সময় সিদ্ধান্ত নেবেন না। সাধারণ ট্রিগারগুলো:

  • নির্দিষ্ট সময়ের জন্য নির্ধারিত থ্রেশহোল্ডের ওপরে এরর রেট (15–30 মিনিট)
  • লগইন সাকসেস রেট কমে গেলে (বা টোকেন রিফ্রেশ ব্যর্থতা বাড়লে)
  • পেমেন্ট ব্যর্থতা বাড়লে (বা চেকআউট টাইমআউট বাড়লে)
  • নির্দিষ্ট ভার্সনের সাথে যুক্ত সাপোর্ট টিকিটে বৃদ্ধি
  • গুরুত্বপূর্ণ এন্ডপয়েন্টে ল্যাটেন্সি বৃদ্ধি

ভার্সন-সংক্রান্ত আউটেজের জন্য একটি সংক্ষিপ্ত INCIDENT প্লেবুক রাখুন: কাদের পেজ করা হবে, ঝুঁকিপূর্ণ ফ্ল্যাগ কীভাবে নিষ্ক্রিয় করতে হবে, কোন সার্ভার রিলিজে রোলব্যাক করতে হবে, এবং কিভাবে ডিপ্রেকশন উইন্ডো বাড়ানো যাবে যদি পুরনো ক্লায়েন্ট এখনও সক্রিয় থাকে।

উদাহরণ: বাস্তব রিলিজে একটি এন্ডপয়েন্ট কিভাবে বদলাবেন

Move faster with no code
Build internal tools and customer portals faster, with APIs that can evolve safely.
Try AppMaster

চেকআউট একটি ক্লাসিক বাস্তব-জগত পরিবর্তন। আপনি সাধারণ ফ্লো থেকে শুরু করেন, পরে একটি নতুন পেমেন্ট ধাপ (যেমন শক্তিশালী প্রমাণীকরণ) যোগ করেন এবং ব্যবসায়িক কথোপকথনের সাথে মিলিয়ে ফিল্ডগুলো নামান্তর করেন।

ধরা যাক আপনার মোবাইল অ্যাপ POST /checkout কল করে।

v1-এ কি থাকে বনাম v2-এ কি বদলায়

v1-এ বিদ্যমান রিকোয়েস্ট ও আচরণ রাখুন যাতে পুরনো অ্যাপগুলো পেমেন্ট শেষ করতে পারে। v2-এ নতুন ফ্লো ও পরিষ্কার নাম ব্যবহার করুন।

  • v1 রাখে: amount, currency, card_token, এবং একটি সাদামাটা রেসপন্স যেমন status=paid|failed
  • v2 যোগ করে: payment_method_id (যা card_token প্রতিস্থাপন করে) এবং একটি next_action ফিল্ড যাতে অ্যাপ অতিরিক্ত ধাপ হ্যান্ডেল করতে পারে (verify, retry, redirect)।
  • v2 রিনেম করে: amount থেকে total_amount এবং currency থেকে billing_currency

পুরনো অ্যাপগুলো কাজ চালিয়ে যায় কারণ সার্ভার নিরাপদ ডিফল্ট প্রয়োগ করে। যদি v1 রিকোয়েস্ট next_action-এর বিষয়ে জানে না, সার্ভার সম্ভব হলে পেমেন্ট সম্পন্ন করবে এবং একই v1-স্টাইল ফলাফল ফেরত দেবে। যদি নতুন ধাপ বাধ্যতামূলক হয়, v1-কে একটি পরিষ্কার, স্থির এরর কোড দেওয়া হবে যেমন requires_update যাতে এটি বিভ্রান্তিকর জেনেরিক ব্যর্থতা না হয়।

গ্রহণ, অবসর নীতিও এবং রোলব্যাক

ভার্সন অনুযায়ী গ্রহণ ট্র্যাক করুন: Checkout কলগুলোর কী অংশ v2-তে যায়, এরর রেট, এবং কতজন ব্যবহারকারী কেবল v1 সমর্থন করে এমন বিল্ড চালাচ্ছেন। যখন v2 ব্যবহার ধারাবাহিকভাবে উচ্চ (উদাহরণ: কয়েক সপ্তাহ 95%+) এবং v1 ব্যবহার কম, একটি v1 রিটায়ারমেন্ট তারিখ নির্বাচন করে তা জানিয়ে দিন (রিলিজ নোট, ইন-অ্যাপ মেসেজিং)।

লঞ্চের পরে কিছু ভুল হলে, রোলব্যাক হালকা হওয়া উচিত:

  • ট্রাফিক আবার v1 আচরণে রুট করুন।
  • সার্ভার-সাইড ফ্ল্যাগ দিয়ে নতুন পেমেন্ট ধাপ অক্ষম করুন।
  • উভয় ফিল্ড সেট গ্রহণ চালিয়ে যান, এবং লোগ রাখুন আপনি কোনটি অটো-কনভার্ট করছিলেন।

নীরব ব্রেকেজের সাধারণ ভুলগুলো

Prototype the full flow
Test your rollout plan with a working API and client apps from one project.
Prototype Now

বেশিরভাগ মোবাইল API ব্যর্থতা জোরে আওয়াজ করে না। রিকোয়েস্ট সফল হয়, অ্যাপ চালিয়ে যায়, কিন্তু ব্যবহারকারীরা মিসিং ডেটা, ভুল টোটাল, বা কাজ না করা বোতাম দেখতে পায়। এই ইস্যুগুলো ধাপবদ্ধ রোলআউটের সময় পুরনো অ্যাপ ভার্সনগুলোর উপর পড়ে এবং খুঁজে বের করা কঠিন।

সাধারণ কারণগুলো:

  • ফিল্ড বদলানো বা সরিয়ে ফেলা (বা টাইপ পরিবর্তন) ছাড়া স্পষ্ট ভার্সন প্ল্যান না থাকা।
  • নতুন রিকোয়েস্ট ফিল্ড তৎক্ষণাৎ বাধ্যতামূলক করা, ফলে পুরনো অ্যাপগুলো প্রত্যাখ্যাত হতে শুরু করে।
  • একটি ডেটাবেস মাইগ্রেশন পাঠানো যা কেবল নতুন অ্যাপটি মনে করে চলছে।
  • ইনস্টল ভিত্তিক v1 অবসান সিদ্ধান্ত নেওয়া, সক্রিয় ব্যবহার না মেপে।
  • ব্যাকগ্রাউন্ড জব ও ওয়েবহুক ভুলে যাওয়া যা এখনও পুরনো পে-লোড পাঠায়।

একটা বাস্তব উদাহরণ: আপনার রেসপন্স ফিল্ড total ছিল স্ট্রিং ("12.50") এবং আপনি এটিকে নাম্বারে (12.5) বদলে দেন। নতুন অ্যাপগুলো ঠিক থাকে। পুরনো অ্যাপগুলো এমনকি এটিকে শূন্য ধরতে পারে, লুকিয়ে রাখতে পারে বা নির্দিষ্ট স্ক্রীনে ক্র্যাশ করতে পারে। যদি আপনি অ্যাপ ভার্সন অনুযায়ী ক্লায়েন্ট এরর না দেখেন, এটি অনুধাবন ছাড়া চলতে পারে।

দ্রুত চেকলিস্ট এবং পরবর্তী ধাপ

ভার্সনিং(endpoint naming-এর চেয়েও) বেশি হয়ে ওঠে একই নিরাপত্তা চেকগুলো প্রতিটি রিলিজেই পুনরাবৃত্তি করা।

রিলিজ পূর্বের দ্রুত চেকগুলো

  • পরিবর্তনগুলো অ্যাডিটিভ রাখুন। পুরনো অ্যাপ যা পড়ে তার ফিল্ড সরান বা রিনেম করবেন না।
  • নিরাপদ ডিফল্ট দিন যাতে নতুন ফিল্ড অনুপস্থিত থাকলেও পুরনো ফ্লো-এর মতো আচরণ হয়।
  • এরর রেসপন্স স্থিতিশীল রাখুন (স্ট্যাটাস + শেপ + মানে)।
  • enum নিয়ে সতর্ক থাকুন এবং বিদ্যমান মানের অর্থ বদলাবেন না।
  • পুরনো অ্যাপ ভার্সন থেকে কিছু বাস্তব রিকোয়েস্ট রেপ্লে করে দেখুন এবং নিশ্চিত করুন রেসপন্সগুলো এখনও পার্স করা যায়।

রোলআউটের সময় ও অবসর নেওয়ার আগে দ্রুত চেকগুলো

  • অ্যাপ ভার্সন অনুযায়ী গ্রহণ ট্র্যাক করুন। আপনি v1 থেকে v2-তে একটি স্পষ্ট কার্ভ দেখতে চান, সমতল রেখা নয়।
  • ভার্সন অনুযায়ী এরর রেট দেখুন। স্পাইক মানে parsing বা validation-এ পুরনো ক্লায়েন্ট ক্ষতিগ্রস্ত।
  • প্রথমে সবচেয়ে বেশী ফেল করছে এমন এন্ডপয়েন্ট ঠিক করুন, তারপর রোলআউট বাড়ান।
  • সক্রিয় ব্যবহার সত্যিই কম হলে তবেই অবসর নিন, এবং তারিখ জানিয়ে দিন।
  • অবসরনিরতির পর শেষেই fallback কোড মুছুন।

আপনার ভার্সনিং ও ডিপ্রেকশন নীতিটি এক পাতায় লিখুন, তারপর চেকলিস্টটিকে প্রতিটি রিলিজে ব্যবহার করার গেট হিসেবে তৈরি করুন।

আপনি যদি ইন্টারনাল টুল বা গ্রাহক-সম্মুখীন অ্যাপগুলো নো-কোড প্ল্যাটফর্ম দিয়ে বানান, তাও API-কে একটি চুক্তি হিসেবে ডিপ্রেকশন উইন্ডো সহ বিবেচনা করা উপকারী। AppMaster (appmaster.io) ব্যবহার করা দলগুলোর জন্য v1 ও v2 পাশাপাশিই রাখা প্রায়ই সহজ কারণ আপনি ব্যাকএন্ড ও ক্লায়েন্ট অ্যাপগুলো পুনরায় জেনারেট করতে পারবেন যখন প্রয়োজন পরিবর্তিত হবে, একই সময়ে পুরনো চুক্তিগুলো রোলআউট চলাকালীন চালু রাখার সুযোগ পাবেন।

প্রশ্নোত্তর

Why do backend API changes break mobile apps even when users didn’t update anything?

মোবাইল ব্যবহারকারীরা সবাই একসঙ্গে আপডেট করে না, তাই পুরনো অ্যাপ বিল্ডগুলো আপনার ব্যাকএন্ডে ডাকা চালিয়ে যায়। যদি আপনি কোনো এন্ডপয়েন্ট, ভ্যালিডেশন বা রেসপন্সের আকার বদলান, তাহলে সেই পুরনো বিল্ডগুলো মানিয়ে নিতে পারে না এবং ফলাফল হয় খালি স্ক্রিন, ক্র্যাশ বা পেমেন্ট ব্যর্থতা।

What does “backward compatible” actually mean for a mobile API?

“কোম্প্যাটিবল” মানে হলো একটি পুরনো অ্যাপ একই অনুরোধগুলো করেই এমন রেসপন্স পায় যা সেটা পার্স করে ও ব্যবহার করতে পারে—কোনো কোড বদল না করেই। সহজ ভাব হল API-কে একটা চুক্তি হিসেবে দেখা: নতুন ক্ষমতা যোগ করা যাবে, কিন্তু থাকা ফিল্ডগুলোর মান বদলান হবে না যা বর্তমান ক্লায়েন্টরা ব্যবহার করছে।

What are the most common breaking changes in mobile APIs?

ব্রেকিং পরিবর্তনগুলো সাধারণত এমন কিছু যা পুরনো অ্যাপ নির্ভর করে তা বদলে দেয়—ফিল্ড সরানো বা নাম বদলানো, ফিল্ডের টাইপ পরিবর্তন, ভ্যালিডেশন কড়া করা যাতে পুরনো রিকোয়েস্ট ফেইল করে, বা এরর পে-লোডের ফরম্যাট বদলানো। যদি পুরনো অ্যাপ রেসপন্স পার্স করতে না পারে বা রিকোয়েস্টের শর্ত পূরণ করতে না পারে, তাহলে সেটি ব্রেকিং।

Should I use URL versioning or header-based versioning for a mobile API?

URL ভার্সনিং ডিফল্ট হিসেবে সাধারণত সবচেয়ে সহজ—কারণ লোগ, ডিবাগিং ও রাউটিং-এ ভার্সন স্পষ্ট দেখা যায়। Header-ভিত্তিক ভার্সনিংও কাজ করে, কিন্তু ট্রাবলশুটিং-এ হারিয়ে যেতে পারে এবং প্রতিটি রিকোয়েস্টে হেডার সঠিকভাবে পাঠাতে হবে।

How long should we keep older API versions running?

আপনার রিয়েল মোবাইল আপডেট আচরণের সাথে মিল রেখে একটি পরিষ্কার সাপোর্ট উইন্ডো বেছে নিন এবং তাতে স্থির থাকুন; অনেক দল মাস ভিত্তিতে সময় দেয়, দিনের পরিবর্তে। মূল বিষয় হল একটি প্রকাশিত রিটায়ারমেন্ট তারিখ থাকা এবং সক্রিয় ব্যবহার মাপা যাতে সিদ্ধান্ত অনুমানভিত্তিক না হয়।

What’s a practical way to warn clients that an API version will be retired?

একটি ধারাবাহিক ডিপ্রেকেশন সিগন্যাল ব্যবহার করুন যাতে ক্লায়েন্ট এবং ড্যাশবোর্ড সহজে তা ধরতে পারে—উদাহরণ: একটি স্থায়ী রেসপন্স হেডার Deprecation: true এবং একটি রিটায়ারমেন্ট তারিখ, অথবা একটি ছোট JSON ফিল্ড "deprecation": {"will_stop_working_on": "2026-04-01"}। সরল ও পূর্বানুমেয় হওয়া গুরুত্বপূর্ণ।

How can we evolve responses without breaking older app versions?

অ্যাডিটিভ পরিবর্তন পছন্দ করুন: নতুন অপশনাল ফিল্ড যোগ করা বা নতুন এন্ডপয়েন্ট তৈরি করা। যখন rename করতে হবে, কিছু সময় দুটো ফিল্ড পাশাপাশি রাখুন এবং উভয়ই রেসপন্সে পূরণ করুন যাতে পুরনো অ্যাপ ডেটা হারায় না।

How do we handle database changes while v1 and v2 are live?

মাইগ্রেশনের সময় উভয় API সংস্করণ কাজ করতে পারে এমনভাবে ডিজাইন করুন: প্রথমে কলাম যোগ করুন, প্রয়োজনে ব্যাকফিল করুন, এবং পরে কনস্ট্রেইন্ট কষাটান বা পুরনো ফিল্ড মুছুন। রোলআউটের মাঝখানে নাম বা অর্থ বদলাবেন না—পুরনো এবং নতুন একে অপরকে পড়তে না পারলে সমস্যা হবে।

What should mobile apps do to be more resilient to API changes?

অ্যাপটিকে সহনশীল করুন: অজানা JSON ফিল্ডগুলো উপেক্ষা করুন, মিসিং ফিল্ডকে ডিফল্ট হিসেবে নিন, এবং null-কে নিরাপদভাবে হ্যান্ডেল করুন। এতে সার্ভার নতুন ফিল্ড যোগ করলে বা রেসপন্স সাময়িকভাবে ভিন্ন হলে আকস্মিক বাগ কম হবে।

What should we monitor during a phased rollout, and when is it safe to retire v1?

রোলআউটের সময় API ভার্সন এবং অ্যাপ ভার্সন অনুসারে ব্যবহার ও এররগুলো ট্র্যাক করুন, বিশেষত লগইন ও পেমেন্টস-এর জন্য। v1 আচরণ লক রেখে v2 পাশাপাশি চালান এবং স্পষ্ট ফallback কৌশল ব্যবহার করুন যতক্ষণ না অ্যাপ গ্রহণ উচ্চপর্যায়ে পৌঁছে এবং v1 নিরাপদে অবসর নেওয়া যায়।

শুরু করা সহজ
কিছু আশ্চর্যজনকতৈরি করুন

বিনামূল্যের পরিকল্পনা সহ অ্যাপমাস্টারের সাথে পরীক্ষা করুন।
আপনি যখন প্রস্তুত হবেন তখন আপনি সঠিক সদস্যতা বেছে নিতে পারেন৷

এবার শুরু করা যাক