সফ্টওয়্যার / ফার্মওয়্যার অটো আপডেট কৌশল


9

আমি এখন একটি মাঝারি আকারের প্রকল্প পেয়েছি যা ক্লায়েন্ট ডেমোসের জন্য "opালু ক্যাফিন চালিত প্রোটোটাইপস" পর্বের শেষের দিকে এবং "ভবিষ্যতের বিষয়ে চিন্তাভাবনা" পর্যায়ে রূপান্তরিত হয়েছে। প্রকল্পটিতে সফ্টওয়্যার এবং ফার্মওয়্যারযুক্ত লিনাক্স-ভিত্তিক ডিভাইস এবং একটি কেন্দ্রীয় প্রশাসনিক ওয়েব সার্ভার রয়েছে। 10 টি প্রোটোটাইপ বর্তমানে বিদ্যমান, উত্পাদন কম 1000 এর ক্রম অনুযায়ী প্রত্যাশিত।

অটো-আপডেটের শিল্পে ভালভাবে দক্ষ না হওয়া এবং সময়মতো সংক্ষিপ্ত হওয়ার কারণে আমি খুব দ্রুত আমার নিজের সফ্টওয়্যার মোতায়েন / অটো-আপডেট কৌশল ঘুরিয়ে দিয়েছিলাম এবং সত্যি বলতে গেলে এটি সফল হয়। এটি বর্তমানে নিম্নলিখিতটি নিয়ে গঠিত:

  • একটি প্রোডাকশন রিলিজ শাখা সহ একটি হোস্টেড গিট রেপো (গিটল্যাব) নোট করুন ওয়েব সার্ভার উত্সটিও একই রেপোতে রয়েছে, পাশাপাশি আরও কয়েকটি জিনিস রয়েছে)।
  • ওয়েব ইন্টারফেসে একটি "ডিপ্লয় আপডেট" বোতাম যা:
    1. স্থানীয় রিপো অঞ্চলে উত্পাদন রিলিজ শাখা থেকে সর্বশেষতম সংস্করণ টানতে এবং এটি একটি অস্থায়ী প্যাকেজ প্রস্তুতি মঞ্চে অনুলিপি করে।
    2. সম্পর্কিত না হওয়া উত্স ফাইলগুলি (যেমন সার্ভার উত্স, ফার্মওয়্যার উত্স, ইত্যাদি) এবং .git ফাইলগুলি সরাতে মঞ্চে একটি স্যানিটাইজেশন স্ক্রিপ্ট (রেপোতে সঞ্চিত) চালায়।
    3. আপডেট প্যাকেজের কোনও ফাইলটিতে বর্তমান গিট হ্যাশ লিখেছেন (উদ্দেশ্য নীচে পরিষ্কার হবে)।
    4. যদি সবকিছু ঠিকঠাক হয় তবে এটি জিপ্স করে এবং একই নামের কোনও ফাইলের সাথে পূর্ববর্তী জিজিপড প্যাকেজটি ওভাররাইট করে পরিবেশন করতে প্রস্তুত করে, তারপরে মঞ্চ অঞ্চলটি মুছে ফেলবে।
    5. নোট করুন যে সার্ভারে এখনকার ডিভাইস সফ্টওয়্যারটির দুটি অনুলিপি রয়েছে, যা প্রত্যাশিত সিঙ্কে প্রত্যাশিত: সর্বশেষ উত্পাদনের শাখায় একটি সম্পূর্ণ লোকাল গিট রেপো এবং এখন একটি উপ-গজ জিপড প্যাকেজ যা এটি প্রতিনিধিত্ব করে বলে মনে করা হচ্ছে একই সংস্করণ।
  • ডিভাইসে থাকা সফ্টওয়্যারটি নামের একটি ডিরেক্টরিতে স্ব-অন্তর্ভুক্ত /opt/example/current, যা সফ্টওয়্যারটির বর্তমান সংস্করণটির একটি সিমিলিংক।
  • ডিভাইসে একটি স্বয়ংক্রিয় আপডেট ফাংশন যা বুটে:
    1. কোনও do_not_updateফাইলের উপস্থিতি যাচাই করে এবং এটি উপস্থিত থাকলে আর কোনও পদক্ষেপ নেয় না (ডেভ ডিভাইসের জন্য, নীচে দেখুন)।
    2. উপরে উল্লিখিত পাঠ্য ফাইল থেকে বর্তমান কমিট হ্যাশ পড়ুন s
    3. কোয়েরি প্যারামিটার হিসাবে সেই হ্যাশ দিয়ে সার্ভারে একটি HTTP অনুরোধ করে। সার্ভারটি হয় 304 (হ্যাশ বর্তমান সংস্করণ) দিয়ে প্রতিক্রিয়া জানাবে বা জিজেপড আপডেট প্যাকেজটি পরিবেশন করবে।
    4. আপডেট প্যাকেজটি ইনস্টল করে, যদি একটি প্রাপ্ত হয় তবে এর /opt/exampleমাধ্যমে:
      1. নামযুক্ত একটি ফোল্ডার আপডেট হওয়া সফ্টওয়্যার সম্পর্কিত তথ্য বের করা stage
      2. আপডেট প্যাকেজ থেকে কোনও পোস্ট-ইন্সটলেশন স্ক্রিপ্ট চালানো যা কিছু আপডেট করে যেমন আপডেটের জন্য প্রয়োজনীয় স্থানীয় পরিবর্তন করা ইত্যাদি does
      3. এতে বর্তমান সফ্টওয়্যার রুট ফোল্ডারটি অনুলিপি করা হচ্ছে previous(বিদ্যমান থাকলে previousপ্রথমে মুছে ফেলা হয়)।
      4. এতে stageফোল্ডারটি অনুলিপি করা হচ্ছে latest(বিদ্যমান থাকলে মুছে ফেলা latestহয়))
      5. currentসিলেমিংকে নির্দেশ করে নিশ্চিত করা latest
      6. ডিভাইসটি পুনরায় বুট করা হচ্ছে (ফার্মওয়্যার আপডেটগুলি, উপস্থিত থাকলে পুনরায় বুটে প্রয়োগ করা হয়)।

নতুন নির্মিত ডিভাইসগুলিতে প্রাথমিক স্থাপনার বিষয়টিও রয়েছে। ডিভাইসগুলি বর্তমানে এসডি কার্ড ভিত্তিক (এখানে সমস্যাগুলির বাইরে নিজস্ব সমস্যার একটি সেট রয়েছে) তাই এই প্রক্রিয়াটি নিয়ে গঠিত:

  1. একটি এসডি চিত্র উপস্থিত রয়েছে যাতে এটিতে সফ্টওয়্যারটির কিছু পূর্ববর্তী সংস্করণ রয়েছে।
  2. এই চিত্র থেকে একটি এসডি কার্ড তৈরি করা হয়েছে।
  3. প্রথম বুটে, প্রথম প্রথমবারের বিভিন্ন ডিভাইস-নির্দিষ্ট (ক্রমিক সংখ্যা ভিত্তিক) আরম্ভ হয় এবং তারপরে অটো-আপডেটার গ্রাফিক্স এবং যথারীতি সফ্টওয়্যারটির সর্বশেষতম উত্পাদন সংস্করণ ইনস্টল করে।

অতিরিক্তভাবে, বিকাশকারী ডিভাইসগুলির জন্য আমার সমর্থন দরকার। বিকাশের ডিভাইসগুলির জন্য:

  • ডিভাইসে একটি সম্পূর্ণ স্থানীয় গিট রেপো রক্ষণাবেক্ষণ করা হয়।
  • currentসিমবলিক লিঙ্ক উন্নয়ন ডিরেক্টরির স্থানটিকে চিহ্নিত করে।
  • একটি স্থানীয় do_not_updateফাইল উপস্থিত রয়েছে যা অটো-আপডেটারকে একটি প্রোডাকশন আপডেটের সাহায্যে ডেভলপমেন্ট কোডটি ফুটিয়ে তুলতে বাধা দেয়।

এখন, মোতায়েন প্রক্রিয়াটি তাত্ত্বিকভাবে এই উদ্দেশ্যে করা হয়েছিল:

  1. কোড একবার স্থাপনার জন্য প্রস্তুত হয়ে গেলে এটিকে রিলিজ শাখায় চাপ দিন।
  2. সার্ভারের "আপডেট প্রয়োগ করুন" বোতাম টিপুন।
  3. আপডেটটি এখন লাইভ এবং ডিভাইসগুলি পরের বার চেক করলে স্বয়ংক্রিয়ভাবে আপডেট হবে।

তবে বাস্তবে এক টন সমস্যা রয়েছে:

  • ওয়েব সার্ভার কোডটি ডিভাইস কোডের মতোই রেপোতে রয়েছে এবং সার্ভারের একটি স্থানীয় গিট রেপো রয়েছে যা আমি কার্যকর করি। সর্বশেষতম ওয়েব সার্ভার কোড সর্বশেষতম ডিভাইস কোডের মতো একই শাখায় নেই। ডিরেক্টরি কাঠামো সমস্যাযুক্ত। যখন "ডিপ্লয়ে আপডেট" বোতামটি প্রযোজনা শাখা থেকে সর্বশেষ সংস্করণটি টানবে, তখন এটি সার্ভার কোডের একটি উপ-ডিরেক্টরিতে টেনে আনবে। এর অর্থ হ'ল আমি যখন কোনও স্ক্র্যাচ থেকে কোনও সার্ভারে স্থাপন করি, তখন ডিভাইস উত্পাদন শাখাটিকে এটির মধ্যে দিয়ে আমাকে এই সাব-ডাইরেক্টরিটিকে ম্যানুয়ালি "বীজ" করতে হবে, কারণ সম্ভবত আমার পক্ষ থেকে গিট ব্যবহারকারী ত্রুটি থেকে, যদি আমি স্থাপনার চেষ্টা না করি প্যারেন্ট ডিরেক্টরিগুলির ওয়েব সার্ভার শাখা থেকে ডিভাইস কোডটি টানুন । আমি মনে করি এটি স্টেজেজ এরিয়া সার্ভারের স্থানীয় গিট রেপোর একটি উপ-ডিরেক্টরি হিসাবে না করে এটি সমাধানযোগ্য।
  • ওয়েব সার্ভার বর্তমানে অবিচ্ছিন্নভাবে ডিভাইস সফটওয়্যারের গিট হ্যাশ বজায় রাখে না। সার্ভার শুরুর সময়, এটি git rev-parse HEADবর্তমান হ্যাশটি পুনরুদ্ধার করতে এর স্থানীয় ডিভাইস সফ্টওয়্যার রেপোতে একটি করে । এই কারণে আমি আমার মাথাটি গুটিয়ে রাখতে পারি না এমন কারণেই আমি এখানে বর্ণনা করব না এমন একটি যুক্তিযুক্ত ত্রুটি সৃষ্টি করছে, এটি যথেষ্ট বলে যথেষ্ট হয়েছে যে কখনও কখনও সার্ভারটি পুনরায় চালু করে জিনিসগুলি স্ক্রু আপ করে দেওয়া হয়, বিশেষত যদি সার্ভারটি একেবারেই নতুন এবং কোনও উত্পাদন না হয় শাখা রেপো এখনও টানা হয়েছে। অনুরোধ করা হলে আমি আনন্দের সাথে সেই যুক্তিটির উত্সটি ভাগ করে নিই, তবে এই পোস্টটি দীর্ঘ হচ্ছে।
  • যদি স্যানিটাইজেশন স্ক্রিপ্ট (সার্ভার সাইড) কোনও কারণে ব্যর্থ হয়, তবে সার্ভারটি একটি আপ টু ডেট রেপো রেখে গেছে তবে একটি সিঙ্ক / অদৃশ্য আপডেট প্যাকেজ রয়েছে, সুতরাং git rev-parse HEADএমন একটি হ্যাশ ফিরে আসবে যা আসলে কী ঘটছে তার সাথে মেলে না that ডিভাইসগুলিতে পরিবেশন করা হয়েছে এবং এখানে সমস্যাগুলি অবশ্যই সার্ভার কমান্ড লাইনে ম্যানুয়ালি সংশোধন করতে হবে। অর্থাৎ সার্ভারটি জানে না আপডেট প্যাকেজটি সঠিক নয়, এটি কেবল সর্বদা খাঁটি বিশ্বাসের উপর নির্ভর করে। এটি পূর্ববর্তী পয়েন্টগুলির সাথে মিলিতভাবে সার্ভারকে অনুশীলনে অত্যন্ত ভঙ্গুর করে তোলে।
  • সবচেয়ে বড় সমস্যা হ'ল : ডিভাইসে বর্তমানে কোনও পৃথক আপডেটেটর ডেমন চলছে না। ওয়াইফাই ইন্টারনেট অ্যাক্সেস আসার জন্য অপেক্ষা করতে থাকা জটিলতা এবং শেষ মুহুর্তের কিছু হ্যাকারিগুলির কারণে এটি নিজেই মূল ডিভাইস নিয়ন্ত্রণ সফ্টওয়্যার যা ডিভাইসটি পরীক্ষা করে আপডেট করে। এর অর্থ হ'ল যদি কোনওভাবে খারাপভাবে পরীক্ষিত সংস্করণ এটিকে উত্পাদন করে তোলে এবং নিয়ন্ত্রণ সফ্টওয়্যারটি শুরু করতে না পারে তবে উপস্থিত সমস্ত ডিভাইসই মূলত ব্রিকযুক্ত, কারণ এটি আর আপডেট হতে পারে না। এটি উত্পাদন একটি নিখুঁত দুঃস্বপ্ন হবে। কোনও একক ডিভাইসের জন্য একই চুক্তি যদি এটি দুর্ভাগ্যজনক সময়ে শক্তি হারিয়ে ফেলে।
  • অন্যান্য বড় সমস্যা হ'ল : ইনক্রিমেন্টাল আপডেটের জন্য কোনও সমর্থন নেই। যদি কোনও ডিভাইস বলে, কিছুক্ষণের জন্য চালু না করা হয়, তার পরের বার এটি আপডেট হয়ে গেলে এটি প্রকাশের সংস্করণগুলির একগুচ্ছ এড়িয়ে যায়, এটি সরাসরি সংস্করণ-এড়িয়ে যাওয়া আপডেট করতে সক্ষম হতে হবে। এর পরিণতি আপডেট করা হয়েছে স্থাপনাকে হ'ল এটি নিশ্চিত করার একটি দুঃস্বপ্ন যা কোনও প্রদত্ত আপডেট কোনও অতীত সংস্করণের উপরে প্রয়োগ করা যেতে পারে। তদতিরিক্ত, যেহেতু গিট হ্যাশগুলি সংস্করণ সংখ্যাগুলির পরিবর্তে সংস্করণগুলি সনাক্ত করতে ব্যবহৃত হয়, বর্ধিত আপডেটগুলি সহজতর করার জন্য সংস্করণগুলির অভিধানের তুলনামূলক তুলনা বর্তমানে সম্ভব নয়।
  • একটি নতুন প্রয়োজনীয়তা যা আমি বর্তমানে সমর্থন করি না তা হ'ল প্রতি ডিভাইস কনফিগারেশন বিকল্প (কী / মান জোড়া) বিদ্যমান থাকবে যা প্রশাসনিক সার্ভারের পাশে কনফিগার করা উচিত। সফটওয়্যার আপডেট হিসাবে একই HTTP অনুরোধে ডিভাইসে এই প্রতি-ডিভাইস বিকল্পগুলি কোনওভাবেই সরবরাহ করা আমার কোনও আপত্তি হবে না (সম্ভবত আমি এটি HTTP শিরোনাম / কুকিগুলিতে আবদ্ধ করতে পারি) যদিও আমি এই বিষয়ে খুব বেশি উদ্বিগ্ন নই, আমি যেমন পারি সর্বদা এটির জন্য পৃথক এইচটিটিপি অনুরোধ করুন।
  • হার্ডওয়্যারটির দুটি (এবং ভবিষ্যতে আরও বেশি) সংস্করণ বিদ্যমান রয়েছে বলে কিছুটা জটিলতা রয়েছে। হার্ডওয়্যার বর্তমান সংস্করণটি আসলে তার প্রাথমিক এসডি চিত্রে পরিবেশের পরিবর্তনশীল হিসাবে সংরক্ষণ করা হয় (তারা স্ব-সনাক্ত করতে পারে না) এবং সমস্ত সফ্টওয়্যার ডিভাইসগুলির সমস্ত সংস্করণের সাথে সামঞ্জস্যপূর্ণ হওয়ার জন্য ডিজাইন করা হয়েছে। ফার্মওয়্যার আপডেটগুলি এই এনভায়রনমেন্ট ভেরিয়েবলের ভিত্তিতে বেছে নেওয়া হয় এবং আপডেট প্যাকেজে হার্ডওয়্যারের সমস্ত সংস্করণের জন্য ফার্মওয়্যার থাকে। আমি এটির সাথে বেঁচে থাকতে পারি যদিও এটি কিছুটা জটিল।
  • ডিভাইসে ম্যানুয়ালি আপডেট আপলোড করার কোনও উপায় নেই (দীর্ঘ কাহিনী সংক্ষেপে এই ডিভাইসগুলির মধ্যে দুটি ওয়াইফাই অ্যাডাপ্টার রয়েছে, একটি ইন্টারনেটে সংযোগ স্থাপন করতে, এবং একটি এপি মোডে যা ব্যবহারকারী ডিভাইসটি কনফিগার করতে ব্যবহার করে; ভবিষ্যতে আমি ডিভাইসের স্থানীয় ওয়েব ইন্টারফেসে একটি "আপডেট সফ্টওয়্যার" ফাংশন যুক্ত করতে চাইছি)। এটি কোনও বিশাল চুক্তি নয় তবে আপডেট ইনস্টলেশন পদ্ধতিতে এর কিছুটা প্রভাব রয়েছে।
  • একগুচ্ছ অন্যান্য হতাশা এবং সাধারণ অসতর্কতা।

সুতরাং ... যে দীর্ঘ ছিল। তবে আমার প্রশ্নটি এখানে ফোটে:

আমি কীভাবে এটি সঠিকভাবে এবং নিরাপদে করব? আমার বিদ্যমান প্রক্রিয়াটিতে আমি কি সামঞ্জস্য করতে পারি? আমি কি নিজের ক্রেপী আপডেট সিস্টেমটি রোল করতে না পারি তার জন্য কি এমন কোনও সময়-পরীক্ষিত কৌশল / বিদ্যমান সিস্টেমটি উত্সাহ অর্জন করতে পারে ? বা যদি আমার নিজের নিজস্ব রোল করতে হয়, তবে কোন স্থাপনা / আপডেট প্রক্রিয়াটি নিরাপদ ও সফল হওয়ার জন্য কোন জিনিসগুলি সত্য হতে হবে? আমি মিশ্রণে বিকাশ ডিভাইসগুলি অন্তর্ভুক্ত করতে সক্ষম হতে হবে।

আমি আশা করি প্রশ্নটি পরিষ্কার হয়ে গেছে। আমি বুঝতে পারি যে এটি কিছুটা অস্পষ্ট, তবে আমি 100% নিশ্চিত যে এটি একটি সমস্যা যা আগে মোকাবেলা করা হয়েছে এবং সফলতার সাথে সমাধান করা হয়েছে, আমি বর্তমানে জানি না যে বর্তমানে গৃহীত কৌশলগুলি কী।


2
আপনার ডিভাইসগুলি লিনাক্স ভিত্তিক হিসাবে, আমি আপনাকে সুপারিশ করব যে সেখানে উপস্থিত লিনাক্স প্যাকেজ ম্যানেজারগুলির মধ্যে একটিকে ব্যবহার করুন (অ্যাপটি, ইয়াম, আরপিএম, ইত্যাদি)। প্রথম পদক্ষেপ হিসাবে, আপনার লিনাক্স বেস ইনস্টলেশন ইতিমধ্যে এক সাথে না আসে কিনা তা পরীক্ষা করে দেখুন।
বার্ট ভ্যান ইনজেন শেহানাউ

আপনি সিস্টেমের আকার সম্পর্কে ধারণা দিতে পারেন? আমরা কি এমবি বা জিবি নিয়ে কথা বলছি?
lbenini

মেগাবাইট; প্যাকেজগুলি আপডেট করুন, যখন জিজিপ করা হয়, সাধারণত 1-2MB হয়।
জেসন সি

উত্তর:


1

আপনি কি দয়া করে ব্যবহারযোগ্য লিনাক্স বিতরণ, বুটলোডার এবং আর্কিটেকচার (x86, এআরএম, এমআইপিএস?) সম্পর্কে আরও তথ্য সরবরাহ করতে পারেন?

আমি যে কোনও উপায়ে অনুমান করার চেষ্টা করব এবং আশা করি আপনার সঠিক দিকের দিকে চালিত করব।

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

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

মেন্ডার গোতে লিখিত একটি ডিমন (এবং সিস্টেমযুক্ত স্ক্রিপ্টগুলির একটি গুচ্ছ) সহ একাধিক সরঞ্জাম সরবরাহ করে যা আপনার কাঁধ থেকে এই বোঝাটি তুলবে। এই প্রকল্পটি Yocto এর সাথে ব্যবহার করা বেশ সহজ (তারা অনেকগুলি ডিভাইসের জন্য একটি মেটা-স্তর সরবরাহ করে যা আপনার নির্দিষ্ট কেস এবং পার্টিশন বিন্যাসের জন্য খাপ খাইয়ে নেওয়া সহজ হওয়া উচিত popular জনপ্রিয় এসওসিগুলির জন্য তাদের প্রচুর প্রস্তুত সমাধান রয়েছে) । আপনি যদি ইয়োক্টো ব্যবহার না করেন আপনি এই পোস্টটি সন্ধান করতে পারেন যা এটি নন-ইওক্টো ভিত্তিক ডিস্ট্রোসগুলির সাথে ব্যবহার করার জন্য আপনাকে ঠিক কী পদক্ষেপগুলি গ্রহণ করা উচিত তা ব্যাখ্যা করে।

সোয়াপডেটটিও দুর্দান্ত চমত্কার তবে এটি ডেনএক্সের একটি লোকের (ইউ-বুটের পিছনে একটি সংগঠন) এক ব্যক্তির প্রচেষ্টার মতো বলে মনে হচ্ছে। এটিও বেশ পরিপক্ক বলে মনে হচ্ছে।

উবুন্টু স্নাপ্পি এর সাথে আমারও কোনও অভিজ্ঞতা নেই এবং আমি এটি সম্পর্কে দক্ষতার সাথে মন্তব্য করতে পারি না (হতে পারে কেউ এলোমেলো হয়ে যাবে)। ধারণাটি হ'ল আপনাকে অ্যাপগুলিকে স্বয়ংসম্পূর্ণ "স্ন্যাপস" এ চালিত করা। আমি যা বুঝতে পেরেছি তা থেকে আপনার সমস্যার সবেমাত্র সমাধান হতে পারে, যদিও এটি সিস্টেমভিত্তিক নয়।

আমি আশা করি প্রশ্নটি পরিষ্কার হয়ে গেছে। আমি বুঝতে পারি এটি কিছুটা অস্পষ্ট, তবে আমি 100% নিশ্চিত যে এটি এমন একটি সমস্যা যা আগে মোকাবেলা করা হয়েছে এবং সফলতার সাথে সমাধান করা হয়েছে, আমি জানি না বর্তমান গৃহীত কৌশলগুলি কী।

প্রকৃতপক্ষে মনে হচ্ছে প্রবণতাটি আজ ডকার (এমনকি এম্বেড থাকা সিস্টেমগুলিতে) এবং এপিটি / ইউইউএম-র বন্ধুদেরও ব্যবহার করা। পরবর্তীকালে ধারাবাহিকতা নিশ্চিত করা খুব কঠিন হয়ে উঠতে পারে।


এটি দুর্দান্ত আমি নিশ্চিত না যে আমি কীভাবে এই উত্তরটি লক্ষ্য করিনি। আমি শীঘ্রই অনুরোধ করা তথ্য সরবরাহ করব, সেই প্রকল্পটি অস্থায়ীভাবে স্থগিত হয়ে গতকাল পুনরায় শুরু হয়েছিল, সুতরাং আমি কেবল ঘোড়ায় ফিরে আসছি, এবং এই বিশেষ সমস্যাটি এখন # 1 অগ্রাধিকার is
জেসন সি
আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.