ZooKeeper রক্ষণাবেক্ষণ সম্পর্কে

প্রাইভেট ক্লাউড v4.18.05 এর জন্য এজ

ZooKeeper ensembles এক বা একাধিক ZooKeeper নোডের ক্ষতি হওয়া সত্ত্বেও, কোন ডেটা ক্ষতি ছাড়াই কার্যকরী থাকার জন্য ডিজাইন করা হয়েছে। এই স্থিতিস্থাপকতা কোন সিস্টেম ডাউনটাইম ছাড়া ZooKeeper নোডগুলিতে রক্ষণাবেক্ষণ করতে কার্যকরভাবে ব্যবহার করা যেতে পারে।

ZooKeeper এবং Edge সম্পর্কে

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

ZooKeeper নোডগুলি নির্দিষ্ট করতে এজ কনফিগারেশন ফাইলে ZK_HOSTS এবং ZK_CLIENT_HOSTS বৈশিষ্ট্যগুলি ব্যবহার করুন৷ পরীক্ষার জন্য

ZK_HOSTS="$IP1 $IP2 $IP3"
ZK_CLIENT_HOSTS="$IP1 $IP2 $IP3"

কোথায়:

  • ZK_HOSTS ZooKeeper নোডের IP ঠিকানা নির্দিষ্ট করে। সমস্ত ZooKeeper নোডগুলিতে আইপি ঠিকানাগুলি অবশ্যই একই ক্রমে তালিকাভুক্ত করা উচিত।

    একটি মাল্টি-ডেটা সেন্টার পরিবেশে, সমস্ত ডেটা সেন্টার থেকে সমস্ত ZooKeeper নোড তালিকাভুক্ত করুন।

  • ZK_CLIENT_HOSTS শুধুমাত্র এই ডেটা সেন্টার দ্বারা ব্যবহৃত ZooKeeper নোডগুলির IP ঠিকানাগুলি নির্দিষ্ট করে৷ আইপি ঠিকানাগুলিকে ডেটা সেন্টারের সমস্ত ZooKeeper নোডগুলিতে একই ক্রমে তালিকাভুক্ত করা আবশ্যক৷

    একটি একক ডেটা সেন্টার ইনস্টলেশনে, এইগুলি একই নোডগুলি যেমন ZK_HOSTS দ্বারা নির্দিষ্ট করা হয়েছে৷ একটি মাল্টি-ডেটা সেন্টার পরিবেশে, প্রতিটি ডেটা সেন্টারের জন্য এজ কনফিগার ফাইলটি শুধুমাত্র সেই ডেটা সেন্টারের জন্য ZooKeeper নোডগুলি তালিকাভুক্ত করা উচিত।

ডিফল্টরূপে, সমস্ত ZooKeeper নোড ভোটার নোড হিসাবে মনোনীত হয়। এর মানে হল নোডগুলি সবই ZooKeeper নেতা নির্বাচন করতে অংশগ্রহণ করে। নোটটি একটি পর্যবেক্ষক নোড, ভোটার নয় তা বোঝাতে আপনি ZK_HOSTS এর সাথে :observer মডিফায়ার অন্তর্ভুক্ত করতে পারেন। একজন পর্যবেক্ষক নোড নেতা নির্বাচনে অংশগ্রহণ করে না।

একাধিক এজ ডেটা সেন্টার তৈরি করার সময় আপনি সাধারণত :observer মডিফায়ার নির্দিষ্ট করেন, অথবা যখন একটি ডাটা সেন্টারে প্রচুর পরিমাণে ZooKeeper নোড থাকে। উদাহরণস্বরূপ, দুটি ডেটা সেন্টার সহ একটি 12-হোস্ট এজ ইনস্টলেশনে, ডেটা সেন্টার 2-এ নোড 9-এর ZooKeeper হল পর্যবেক্ষক:

তারপরে আপনি ডেটা সেন্টার 1 এর জন্য আপনার কনফিগার ফাইলে নিম্নলিখিত সেটিংস ব্যবহার করুন:

ZK_HOSTS="$IP1 $IP2 $IP3 $IP7 $IP8 $IP9:observer"
ZK_CLIENT_HOSTS="$IP1 $IP2 $IP3"

এবং ডেটা সেন্টারের জন্য

ZK_HOSTS="$IP1 $IP2 $IP3 $IP7 $IP8 $IP9:observer"
ZK_CLIENT_HOSTS="$IP7 $IP8 $IP9"

নেতা, অনুসারী, ভোটার এবং পর্যবেক্ষকদের সম্পর্কে

একটি মাল্টি-নোড ZooKeeper ইনস্টলেশনে, নোডগুলির মধ্যে একটিকে নেতা হিসাবে মনোনীত করা হয়। অন্যান্য সমস্ত ZooKeeper নোড অনুসরণকারী হিসাবে মনোনীত করা হয়েছে। যেকোন ZooKeeper নোড থেকে রিডগুলি ঘটতে পারে, সমস্ত লেখার অনুরোধ লিডারের কাছে ফরোয়ার্ড করা হয়। উদাহরণস্বরূপ, এজে একটি নতুন বার্তা প্রসেসর যুক্ত করা হয়েছে। সেই তথ্য চিড়িয়াখানার নেতাকে লেখা হয়েছে। সমস্ত অনুসরণকারীরা তারপর ডেটা প্রতিলিপি করে।

এজ ইনস্টলেশনের সময়, আপনি প্রতিটি ZooKeeper নোডকে ভোটার বা পর্যবেক্ষক হিসাবে মনোনীত করেন। নেতা তারপর সব ভোটার ZooKeeper নোড দ্বারা নির্বাচিত হয়. একজন নেতা নির্বাচনের জন্য একটি প্রয়োজনীয়তা হল কার্যকরী ZooKeeper ভোটার নোডের একটি কোরাম থাকতে হবে। একটি কোরাম মানে সমস্ত ভোটার ZooKeeper নোডের অর্ধেকেরও বেশি, সমস্ত ডেটা সেন্টার জুড়ে, কার্যকরী৷

ভোটার নোডের কোরাম না থাকলে কোনো নেতা নির্বাচন করা যাবে না। এই পরিস্থিতিতে, Zookeeper অনুরোধগুলি পরিবেশন করতে পারে না। এর মানে হল আপনি এজ ম্যানেজমেন্ট সার্ভারের কাছে একটি অনুরোধ করতে পারবেন না, ম্যানেজমেন্ট API অনুরোধগুলি প্রক্রিয়া করতে পারবেন না বা কোরাম পুনরুদ্ধার না হওয়া পর্যন্ত এজ UI-তে লগ ইন করতে পারবেন না।

উদাহরণস্বরূপ, একটি একক ডেটা সেন্টার ইনস্টলেশনে:

  • আপনি তিনটি ZooKeeper নোড ইনস্টল করেছেন
  • সমস্ত ZooKeeper নোড ভোটার হয়
  • কোরাম হল দুটি কার্যকরী ভোটার নোড
  • যদি শুধুমাত্র একটি ভোটার নোড পাওয়া যায় তাহলে ZooKeeper ensemble কাজ করতে পারবে না

দুটি ডেটা সেন্টার সহ একটি ইনস্টলেশনে:

  • আপনি প্রতি ডেটা সেন্টারে তিনটি ZooKeeper নোড ইনস্টল করেছেন, মোট ছয়টি নোডের জন্য
  • ডেটা সেন্টার 1-এ তিনটি ভোটার নোড রয়েছে
  • ডেটা সেন্টার 2-এ দুটি ভোটার নোড এবং একটি পর্যবেক্ষক নোড রয়েছে
  • কোরাম উভয় ডেটা সেন্টারের পাঁচজন ভোটারের উপর ভিত্তি করে, এবং তাই তিনটি কার্যকরী ভোটার নোড।
  • যদি মাত্র দুই বা তার কম ভোটার নোড পাওয়া যায় তাহলে ZooKeeper ensemble কাজ করতে পারবে না

ভোটার বা পর্যবেক্ষক হিসাবে নোড যোগ করা

আপনার সিস্টেমের প্রয়োজনীয়তার জন্য আপনার এজ ইনস্টলেশনে অতিরিক্ত ZooKeeper নোড যোগ করার প্রয়োজন হতে পারে। ZooKeeper নোড যুক্ত করা ডকুমেন্টেশন বর্ণনা করে কিভাবে এজ-এ অতিরিক্ত ZooKeeper নোড যোগ করা যায়। ZooKeeper নোডগুলি যোগ করার সময়, আপনাকে অবশ্যই বিবেচনা করতে হবে যে নোডগুলি যোগ করতে হবে: ভোটার বা পর্যবেক্ষক৷

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

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

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

একটি একক ডেটা সেন্টারে, Apigee সুপারিশ করে যে পর্যবেক্ষক নোডের সংখ্যা নির্বিশেষে আপনার পাঁচটির বেশি ভোটার নেই। দুটি ডেটা সেন্টারে, Apigee সুপারিশ করে যে আপনার নয়জনের বেশি ভোটার নেই (একটি ডেটা সেন্টারে পাঁচজন এবং অন্যটিতে চারজন)। তারপরে আপনি আপনার সিস্টেমের প্রয়োজনীয়তার জন্য প্রয়োজনীয় যতগুলি পর্যবেক্ষক নোড যোগ করতে পারেন।

রক্ষণাবেক্ষণ বিবেচনা

ZooKeeper রক্ষণাবেক্ষণ সম্পূর্ণরূপে কার্যকরী ensemble-এ কোনো ডাউনটাইম ছাড়াই করা যেতে পারে যদি এটি একবারে একটি একক নোডে সঞ্চালিত হয়। যে কোনো সময়ে শুধুমাত্র একটি ZooKeeper নোড ডাউন আছে তা নিশ্চিত করার মাধ্যমে, আপনি নিশ্চিত করতে পারেন যে একজন নেতা নির্বাচন করার জন্য সর্বদা ভোটার নোডের একটি কোরাম পাওয়া যায়।

একাধিক ডেটা সেন্টার জুড়ে রক্ষণাবেক্ষণ

একাধিক ডেটা সেন্টারের সাথে কাজ করার সময়, মনে রাখবেন যে ZooKeeper ensemble ডেটা সেন্টারের মধ্যে পার্থক্য করে না। ZooKeeper সমাবেশগুলি সমস্ত ডেটা সেন্টার জুড়ে ZooKeeper নোডগুলিকে একটি ensemble হিসাবে দেখে।

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

রক্ষণাবেক্ষণের প্রভাব

বিভিন্ন সময়ে, আপনাকে রক্ষণাবেক্ষণের জন্য একটি ZooKeeper নোড নিতে হবে, একটি ভোটার নোড বা একটি পর্যবেক্ষক নোড। উদাহরণস্বরূপ, আপনাকে নোডে এজ-এর সংস্করণ আপগ্রেড করতে হতে পারে, মেশিন হোস্টিং ZooKeeper ব্যর্থ হতে পারে, অথবা নেটওয়ার্ক ত্রুটির মতো অন্য কোনো কারণে নোডটি অনুপলব্ধ হতে পারে।

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

রক্ষণাবেক্ষণ পদ্ধতি

একটি ZooKeeper ensemble কার্যকরী কিনা তা নিশ্চিত করার পরেই আপনার যেকোন রক্ষণাবেক্ষণ প্রক্রিয়া সম্পাদন করার কথা বিবেচনা করা উচিত। এটি অনুমান করে যে পর্যবেক্ষক নোডগুলি কার্যকরী এবং একটি কোরাম বজায় রাখার জন্য রক্ষণাবেক্ষণের সময় পর্যাপ্ত ভোটার নোড উপলব্ধ রয়েছে৷

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

রক্ষণাবেক্ষণের অংশ হিসাবে, একটি ZooKeeper নোডের ধরন নির্ধারণ করতে নিম্নলিখিত পদ্ধতি ব্যবহার করুন (নেতা, ভোটার, বা পর্যবেক্ষক):

  1. এটি ZooKeeper নোডে ইনস্টল করা না থাকলে, nc ইনস্টল করুন:
    sudo yum install nc
  2. নোডে নিম্নলিখিত nc কমান্ডটি চালান:
    echo stat | nc localhost 2181

    যেখানে 2181 হল ZooKeeper পোর্ট। আপনি ফর্মে আউটপুট দেখতে হবে:

    Zookeeper version: 3.4.5-1392090,
    built on 09/30/2012 17:52 GMT
    Clients: /a.b.c.d:xxxx[0](queued=0,recved=1,sent=0)
    Latency min/avg/max: 0/0/0
    Received: 1
    Sent: 0
    Connections: 1
    Outstanding: 0
    Zxid: 0xc00000044
    Mode: follower
    Node count: 653

    নোডগুলির জন্য আউটপুটের Mode লাইনে, আপনি নোড কনফিগারেশনের উপর নির্ভর করে observer , leader বা follower (অর্থাৎ একজন ভোটার যে নেতা নয়) দেখতে পাবেন।

  3. প্রতিটি ZooKeeper নোডে পদক্ষেপ 1 এবং 2 পুনরাবৃত্তি করুন।

সারাংশ

একটি ZooKeeper ensemble এ রক্ষণাবেক্ষণ করার সর্বোত্তম উপায় হল এটি একবারে একটি নোড সম্পাদন করা। মনে রাখবেন:

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