ক্যাসান্দ্রা কমপ্যাকশন কৌশল পরিবর্তন করুন, ক্যাসান্দ্রা কমপ্যাকশন কৌশল পরিবর্তন করুন

Apigee প্রক্সি, ক্যাশে এবং টোকেনগুলির ডেটা সহ এর বেশিরভাগ ডেটা সঞ্চয় করতে ক্যাসান্ড্রা ডাটাবেস ব্যবহার করে। ডাটাবেসে সংরক্ষিত ডেটার আকার কমানোর জন্য কমপ্যাকশন একটি গুরুত্বপূর্ণ প্রক্রিয়া, দক্ষ ডাটাবেস অপারেশন বজায় রাখার জন্য অপরিহার্য। ক্যাসান্ড্রা কম্প্যাকশনের জন্য বিভিন্ন কৌশল সমর্থন করে। Apigee সুপারিশ করে যে সমস্ত এজ প্রাইভেট ক্লাউড গ্রাহকদের জন্য তাদের Cassandra ক্লাস্টারগুলিকে সমস্ত টেবিলের জন্য ডিফল্ট SizeTieredCompactionStrategy এর পরিবর্তে LeveledCompactionStrategy এর সাথে পরিচালনা করে৷ LeveledCompactionStrategy আরও ভাল পারফরম্যান্স, উন্নত ডিস্ক ব্যবহার, আরও দক্ষ কমপ্যাকশন অফার করে এবং SizeTieredCompactionStrategy তুলনায় কম ফাঁকা জায়গা প্রয়োজন।

Apigee 4.52.02 বা তার পরবর্তী সমস্ত নতুন ইনস্টলেশন স্বয়ংক্রিয়ভাবে LeveledCompactionStrategy সাথে ক্যাসান্দ্রা কনফিগার করে। যাইহোক, যদি আপনি Apigee-এর একটি পুরানো সংস্করণ ব্যবহার করেন বা পুরানো সংস্করণ থেকে Apigee 4.52.02-এ আপগ্রেড করেন, আপনার ইনস্টলেশন এখনও SizeTieredCompactionStrategy এর সাথে Cassandra ব্যবহার করতে পারে।

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

প্রস্তুতি

বিদ্যমান কম্প্যাকশন কৌশল পরীক্ষা করুন

আপনি পরিশিষ্ট 1- এর নির্দেশাবলী অনুসরণ করে টেবিলে বিদ্যমান কমপ্যাকশন কৌশলটি পরীক্ষা করতে পারেন। যদি কমপ্যাকশন কৌশলটি ইতিমধ্যেই LeveledCompactionStrategy হয়ে থাকে, তাহলে এটি OPDK 4.51 বা তার পরে ইনস্টলেশন দিয়ে শুরু করার কারণে হতে পারে, অথবা পূর্বে Apigee দ্বারা সুপারিশকৃত LeveledCompactionStrategy পরিবর্তন করা হতে পারে। আপনি যদি ইতিমধ্যেই LeveledCompactionStrategy ব্যবহার করছেন, Apigee এই কৌশলটি চালিয়ে যাওয়ার এবং পরিবর্তনগুলি এড়ানোর পরামর্শ দেয়৷ যাইহোক, যেহেতু প্রাইভেট ক্লাউডের জন্য এজ আপনার দ্বারা পরিচালিত হয়, তাই নিম্নোক্ত নির্দেশাবলী ব্যাখ্যা করে যে কীভাবে কমপ্যাকশন কৌশল পরিবর্তন করতে হয়।

ব্যাকআপ

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

কম্প্যাকশন থ্রুপুট

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

সমস্ত ক্যাসান্ড্রা নোডে সর্বোচ্চ 128MB তে কমপ্যাকশন থ্রুপুট সেট করতে প্রতিটি নোডে নিম্নলিখিত nodetool কমান্ডটি চালান:

nodetool setcompactionthroughput 128

কমপ্যাকশনের জন্য VM-এর সাইজিং

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

একটি কমপ্যাকশন কৌশল পরিবর্তনের পরে, একটি সম্পূর্ণ কমপ্যাকশন চক্র চালানোর প্রত্যাশিত, তাই কম ট্রাফিক সময়কালে কমপ্যাকশন কৌশল পরিবর্তন করার সুপারিশ করা হয়।

স্তব্ধ রান

আপনি এক দিনের মধ্যে সমস্ত নোডের পরিবর্তন সম্পূর্ণ করতে সক্ষম নাও হতে পারেন, বিশেষ করে যদি আপনি বড় ক্যাসান্ড্রা ক্লাস্টারগুলি পরিচালনা করেন, কারণ প্রতিটি নোডে একে একে সূচকগুলি পুনর্নির্মাণ করতে হবে। আপনি একবারে একটি স্কিমা বা একটি টেবিলের কম্প্যাকশন কৌশল পরিবর্তন করতে পারেন। এর জন্য, কম্প্যাকশন কৌশল পরিবর্তন করতে টেবিলটি পরিবর্তন করুন এবং তারপরে সমস্ত নোডের টেবিলে (যদি থাকে) সমস্ত সূচক পুনর্নির্মাণ করুন। তারপরে প্রতিটি টেবিল বা কীস্পেসের জন্য উপরের পদ্ধতিটি পুনরাবৃত্তি করুন। একটি টেবিল বা একটি কীস্পেসের জন্য এই ধরনের রান বিভিন্ন দিন জুড়ে চালানোর জন্য ভেঙে দেওয়া যেতে পারে।

উদাহরণস্বরূপ, kms স্কিমাতে oauth_20_access_tokens টেবিলের কম্প্যাকশন কৌশলটিকে LeveledCompactionStrategy এ পরিবর্তন করতে, আপনি নিম্নলিখিতগুলি করতে পারেন:

  1. নিম্নোক্ত CQL চালানোর মাধ্যমে কমপ্যাকশন কৌশল পরিবর্তন করতে টেবিল পরিবর্তন করুন:

    ALTER TABLE kms.oauth_20_access_tokens WITH compaction = {'class' : 'LeveledCompactionStrategy'};
  2. শুধুমাত্র এই টেবিলের সমস্ত সূচক পুনর্নির্মাণ করুন:

    nodetool rebuild_index kms oauth_20_access_tokens oauth_20_access_tokens_app_id_idx
    nodetool rebuild_index kms oauth_20_access_tokens oauth_20_access_tokens_client_id_idx
    nodetool rebuild_index kms oauth_20_access_tokens oauth_20_access_tokens_refresh_token_idx   
        

কম্প্যাকশন কৌশল পরিবর্তন করা

একটি উচ্চ স্তরে, কম্প্যাকশন কৌশল পরিবর্তন করা একটি দ্বি-পদক্ষেপ প্রক্রিয়া:

  1. প্রতিটি টেবিলের কম্প্যাকশন কৌশল পরিবর্তন করুন।
  2. এক এক করে প্রতিটি নোডের সমস্ত সূচক পুনর্নির্মাণ করুন।

কমপ্যাকশন কৌশল পরিবর্তন করার জন্য, আপনাকে প্রতিটি টেবিলে একবারে একটি করে ALTER TABLE কমান্ড চালাতে হবে। একটি নমুনা ALTER TABLE কমান্ড নীচের মত দেখাবে:

# To change to LeveledCompactionStrategy
ALTER TABLE kms.oauth_20_access_tokens WITH compaction = {'class' : 'LeveledCompactionStrategy'};
  
# To change to SizeTieredCompactionStrategy
ALTER TABLE kms.oauth_20_access_tokens WITH compaction = {'class' : 'SizeTieredCompactionStrategy'};

নতুন কম্প্যাকশন কৌশল সেট করতে টেবিল পরিবর্তন করুন

একটি সময়ে একটি কীস্পেসের জন্য কৌশল পরিবর্তন করতে যেকোনো একটি ক্যাসান্ড্রা নোডে নিম্নলিখিত CQLগুলি চালান। CQLগুলি CQL প্রম্পটে চালানো যেতে পারে। CQL প্রম্পট আহ্বান করার নির্দেশাবলী:

/opt/apigee/apigee-cassandra/bin/cqlsh `hostname -i`

XXXXXXXX:9042 এ Apigee এর সাথে সংযুক্ত।

[cqlsh 5.0.1 | Cassandra 3.11.16 | CQL spec 3.4.4 | Native protocol v4]
Use HELP for help.
cqlsh>

নীচের কমান্ডগুলি কম্প্যাকশন কৌশলকে LeveledCompactionStrategy স্ট্র্যাটেজিতে পরিবর্তন করে, তবে অনুরূপ কমান্ডগুলি অন্যান্য কমপ্যাকশন কৌশলগুলিতে পরিবর্তন করতে ব্যবহার করা যেতে পারে।

নিচের ধাপ 14 থেকে 16 শুধুমাত্র প্রযোজ্য যদি আপনি নগদীকরণ ব্যবহার করেন।

  1. কীস্পেসের জন্য কমপ্যাকশন কৌশল পরিবর্তন করতে CQLs: kms
    ALTER TABLE kms.organizations WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE kms.maps WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE kms.apps WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE kms.app_credentials WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE kms.api_products WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE kms.apiproducts_appslist WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE kms.api_resources WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE kms.app_end_user WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE kms.oauth_20_authorization_codes WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE kms.oauth_20_access_tokens WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE kms.oauth_10_request_tokens WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE kms.oauth_10_access_tokens WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE kms.oauth_10_verifiers WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE kms.app_enduser_tokens WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    
  2. কীস্পেসের জন্য কমপ্যাকশন কৌশল পরিবর্তন করতে CQLs: user_settings
    ALTER TABLE user_settings.user_settings WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    
  3. কীস্পেসের জন্য কমপ্যাকশন কৌশল পরিবর্তন করতে CQLs: keyvaluemap
    ALTER TABLE keyvaluemap.keyvaluemaps_r21 WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    
  4. কীস্পেসের জন্য কমপ্যাকশন কৌশল পরিবর্তন করতে CQLs: devconnect
    ALTER TABLE devconnect.developers WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE devconnect.companies WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE devconnect.company_developers WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    
  5. কীস্পেসের জন্য কমপ্যাকশন কৌশল পরিবর্তন করতে CQL: counter
    ALTER TABLE counter.counters_current_version WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE counter.counters_with_expiry WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE counter.counters WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE counter.key_timestamp_count WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE counter.timestamp_key WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE counter.period_timestamp WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE counter.gateway_quota WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    
  6. কীস্পেসের জন্য কমপ্যাকশন কৌশল পরিবর্তন করতে CQL: cache
    ALTER TABLE cache.cache_entries WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE cache.cache_sequence_id_r24 WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    
  7. কীস্পেসের জন্য কমপ্যাকশন কৌশল পরিবর্তন করতে CQLs: auth
    ALTER TABLE auth.totp WITH compaction = {'class' : 'LeveledCompactionStrategy'};
  8. কীস্পেসের জন্য কমপ্যাকশন কৌশল পরিবর্তন করতে CQLs: audit
    ALTER TABLE audit.audits WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE audit.audits_ref WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    
  9. কীস্পেসের জন্য কমপ্যাকশন কৌশল পরিবর্তন করতে CQLs: apprepo
    ALTER TABLE apprepo.organizations WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE apprepo.environments WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE apprepo.apiproxies WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE apprepo.apiproxy_revisions WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE apprepo.api_proxy_revisions_r21 WITH compaction = {'class' : 'LeveledCompactionStrategy'};
  10. কীস্পেসের জন্য কমপ্যাকশন কৌশল পরিবর্তন করতে CQLs: apimodel_v2
    ALTER TABLE apimodel_v2.apis WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE apimodel_v2.apis_revision WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE apimodel_v2.resource WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE apimodel_v2.method WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE apimodel_v2.revision_counters WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE apimodel_v2.template_counters WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE apimodel_v2.template WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE apimodel_v2.credentials WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE apimodel_v2.credentialsv2 WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE apimodel_v2.schemas WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE apimodel_v2.security WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE apimodel_v2.template_auth WITH compaction = {'class' : 'LeveledCompactionStrategy'};
  11. কীস্পেসের জন্য কমপ্যাকশন কৌশল পরিবর্তন করতে CQLs: identityzone
    ALTER TABLE identityzone.IdentityZones WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE identityzone.OrgToIdentityZone WITH compaction = {'class' : 'LeveledCompactionStrategy'};
  12. কীস্পেসের জন্য কমপ্যাকশন কৌশল পরিবর্তন করতে CQLs: dek
    ALTER TABLE dek.keys WITH compaction = {'class' : 'LeveledCompactionStrategy'};
  13. কীস্পেসের জন্য কমপ্যাকশন কৌশল পরিবর্তন করতে CQLs: analytics
    ALTER TABLE analytics.custom_aggregates_defn WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE analytics.custom_rules_defn WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE analytics.custom_aggregates_defn_updates WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE analytics.custom_rules_defn_updates WITH compaction = {'class' : 'LeveledCompactionStrategy'};
  14. [শুধু নগদীকরণ] কীস্পেসের জন্য কমপ্যাকশন কৌশল পরিবর্তন করতে CQL: mint
    ALTER TABLE mint.limits WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE mint.suspended_developer_products WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE mint.invitations WITH compaction = {'class' : 'LeveledCompactionStrategy'};
  15. [শুধু নগদীকরণ] কীস্পেসের জন্য কমপ্যাকশন কৌশল পরিবর্তন করতে CQL: taurus
    ALTER TABLE taurus.triggers WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE taurus.job_details WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE taurus.org_triggers WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE taurus.triggers_suite WITH compaction = {'class' : 'LeveledCompactionStrategy'};
  16. [শুধু নগদীকরণ] কীস্পেসের জন্য কমপ্যাকশন কৌশল পরিবর্তন করতে CQL: notification
    ALTER TABLE notification.notification_service_item WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE notification.notification_service_black_list_item WITH compaction = {'class' : 'LeveledCompactionStrategy'};
    ALTER TABLE notification.notification_email_template_item WITH compaction = {'class' : 'LeveledCompactionStrategy'};

সূচক পুনর্নির্মাণ

যেকোন কমপ্যাকশন কৌশল পরিবর্তনের পরে এই পদক্ষেপটি কার্যকর করা দরকার। প্রতিটি ক্যাসান্ড্রা নোডে একের পর এক নিম্নলিখিত nodetool কমান্ডগুলি চালান।

নীচের 7 থেকে 9 ধাপগুলি শুধুমাত্র প্রযোজ্য যদি আপনি নগদীকরণ ব্যবহার করেন৷

  1. কীস্পেসের জন্য সূচকগুলি পুনর্নির্মাণ করুন: kms

    nodetool rebuild_index kms api_products api_products_organization_name_idx
    nodetool rebuild_index kms app_credentials app_credentials_api_products_idx
    nodetool rebuild_index kms app_credentials app_credentials_organization_app_id_idx
    nodetool rebuild_index kms app_credentials app_credentials_organization_name_idx
    nodetool rebuild_index kms app_end_user app_end_user_app_id_idx
    nodetool rebuild_index kms apps apps_app_family_idx
    nodetool rebuild_index kms apps apps_app_id_idx
    nodetool rebuild_index kms apps apps_app_type_idx
    nodetool rebuild_index kms apps apps_name_idx
    nodetool rebuild_index kms apps apps_organization_name_idx
    nodetool rebuild_index kms apps apps_parent_id_idx
    nodetool rebuild_index kms apps apps_parent_status_idx
    nodetool rebuild_index kms apps apps_status_idx
    nodetool rebuild_index kms maps maps_organization_name_idx
    nodetool rebuild_index kms oauth_10_access_tokens oauth_10_access_tokens_app_id_idx
    nodetool rebuild_index kms oauth_10_access_tokens oauth_10_access_tokens_consumer_key_idx
    nodetool rebuild_index kms oauth_10_access_tokens oauth_10_access_tokens_organization_name_idx
    nodetool rebuild_index kms oauth_10_access_tokens oauth_10_access_tokens_status_idx
    nodetool rebuild_index kms oauth_10_request_tokens oauth_10_request_tokens_consumer_key_idx
    nodetool rebuild_index kms oauth_10_request_tokens oauth_10_request_tokens_organization_name_idx
    nodetool rebuild_index kms oauth_10_verifiers oauth_10_verifiers_organization_name_idx
    nodetool rebuild_index kms oauth_10_verifiers oauth_10_verifiers_request_token_idx
    nodetool rebuild_index kms oauth_20_access_tokens oauth_20_access_tokens_app_id_idx
    nodetool rebuild_index kms oauth_20_access_tokens oauth_20_access_tokens_client_id_idx
    nodetool rebuild_index kms oauth_20_access_tokens oauth_20_access_tokens_refresh_token_idx
    nodetool rebuild_index kms oauth_20_authorization_codes oauth_20_authorization_codes_client_id_idx
    nodetool rebuild_index kms oauth_20_authorization_codes oauth_20_authorization_codes_organization_name_idx
    
  2. কীস্পেসের জন্য সূচকগুলি পুনর্নির্মাণ করুন: devconnect

    nodetool rebuild_index devconnect companies companies_name_idx
    nodetool rebuild_index devconnect companies companies_organization_name_idx
    nodetool rebuild_index devconnect companies companies_status_idx
    nodetool rebuild_index devconnect company_developers company_developers_company_name_idx
    nodetool rebuild_index devconnect company_developers company_developers_developer_email_idx
    nodetool rebuild_index devconnect company_developers company_developers_organization_name_idx
    nodetool rebuild_index devconnect developers developers_email_idx
    nodetool rebuild_index devconnect developers developers_organization_name_idx
    nodetool rebuild_index devconnect developers developers_status_idx
    
  3. কীস্পেসের জন্য সূচকগুলি পুনর্নির্মাণ করুন: cache

    nodetool rebuild_index cache cache_entries cache_entries_cache_name_idx
    
  4. কীস্পেসের জন্য সূচকগুলি পুনর্নির্মাণ করুন: audit

    nodetool rebuild_index audit audits audits_operation_idx
    nodetool rebuild_index audit audits audits_requesturi_idx
    nodetool rebuild_index audit audits audits_responsecode_idx
    nodetool rebuild_index audit audits audits_timestamp_idx
    nodetool rebuild_index audit audits audits_user_idx
    
  5. কীস্পেসের জন্য সূচকগুলি পুনর্নির্মাণ করুন: apimodel_v2

    nodetool rebuild_index apimodel_v2 apis a_name
    nodetool rebuild_index apimodel_v2 apis a_org_name
    nodetool rebuild_index apimodel_v2 apis_revision ar_a_active_rev
    nodetool rebuild_index apimodel_v2 apis_revision ar_a_def_index_template
    nodetool rebuild_index apimodel_v2 apis_revision ar_a_def_method_template
    nodetool rebuild_index apimodel_v2 apis_revision ar_a_latest_rev
    nodetool rebuild_index apimodel_v2 apis_revision ar_a_name
    nodetool rebuild_index apimodel_v2 apis_revision ar_a_uuid
    nodetool rebuild_index apimodel_v2 apis_revision ar_base_url
    nodetool rebuild_index apimodel_v2 apis_revision ar_is_active
    nodetool rebuild_index apimodel_v2 apis_revision ar_is_latest
    nodetool rebuild_index apimodel_v2 apis_revision ar_name
    nodetool rebuild_index apimodel_v2 apis_revision ar_org_name
    nodetool rebuild_index apimodel_v2 apis_revision ar_rel_ver
    nodetool rebuild_index apimodel_v2 apis_revision ar_rev_num
    nodetool rebuild_index apimodel_v2 method m_a_name
    nodetool rebuild_index apimodel_v2 method m_api_uuid
    nodetool rebuild_index apimodel_v2 method m_ar_uuid
    nodetool rebuild_index apimodel_v2 method m_base_url
    nodetool rebuild_index apimodel_v2 method m_name
    nodetool rebuild_index apimodel_v2 method m_org_name
    nodetool rebuild_index apimodel_v2 method m_r_name
    nodetool rebuild_index apimodel_v2 method m_r_uuid
    nodetool rebuild_index apimodel_v2 method m_res_path
    nodetool rebuild_index apimodel_v2 method m_rev_num
    nodetool rebuild_index apimodel_v2 resource r_a_name
    nodetool rebuild_index apimodel_v2 resource r_api_uuid
    nodetool rebuild_index apimodel_v2 resource r_ar_uuid
    nodetool rebuild_index apimodel_v2 resource r_base_url
    nodetool rebuild_index apimodel_v2 resource r_name
    nodetool rebuild_index apimodel_v2 resource r_org_name
    nodetool rebuild_index apimodel_v2 resource r_res_path
    nodetool rebuild_index apimodel_v2 resource r_rev_num
    nodetool rebuild_index apimodel_v2 schemas s_api_uuid
    nodetool rebuild_index apimodel_v2 schemas s_ar_uuid
    nodetool rebuild_index apimodel_v2 security sa_api_uuid
    nodetool rebuild_index apimodel_v2 security sa_ar_uuid
    nodetool rebuild_index apimodel_v2 template t_a_name
    nodetool rebuild_index apimodel_v2 template t_a_uuid
    nodetool rebuild_index apimodel_v2 template t_entity
    nodetool rebuild_index apimodel_v2 template t_name
    nodetool rebuild_index apimodel_v2 template t_org_name
    nodetool rebuild_index apimodel_v2 template_auth au_api_uuid
    
  6. কীস্পেসের জন্য সূচকগুলি পুনর্নির্মাণ করুন: dek

    nodetool rebuild_index dek keys usecase_index
    
  7. [শুধু নগদীকরণ] কীস্পেসের জন্য সূচকগুলি পুনর্নির্মাণ করুন: mint

    nodetool rebuild_index mint limits limits_created_date_idx
    nodetool rebuild_index mint limits limits_id_idx
    nodetool rebuild_index mint limits limits_org_id_idx
    nodetool rebuild_index mint limits limits_updated_date_idx
    nodetool rebuild_index mint suspended_developer_products suspended_developer_products_created_date_idx
    nodetool rebuild_index mint suspended_developer_products suspended_developer_products_currency_idx
    nodetool rebuild_index mint suspended_developer_products suspended_developer_products_dev_id_idx
    nodetool rebuild_index mint suspended_developer_products suspended_developer_products_id_idx
    nodetool rebuild_index mint suspended_developer_products suspended_developer_products_limit_id_idx
    nodetool rebuild_index mint suspended_developer_products suspended_developer_products_org_id_idx
    nodetool rebuild_index mint suspended_developer_products suspended_developer_products_prod_id_idx
    nodetool rebuild_index mint suspended_developer_products suspended_developer_products_reason_code_idx
    nodetool rebuild_index mint suspended_developer_products suspended_developer_products_sub_org_id_idx
    nodetool rebuild_index mint invitations invitations_company_id_idx
    nodetool rebuild_index mint invitations invitations_created_at_idx
    nodetool rebuild_index mint invitations invitations_developer_id_idx
    nodetool rebuild_index mint invitations invitations_lastmodified_at_idx
    nodetool rebuild_index mint invitations invitations_org_id_idx
    
  8. [শুধু নগদীকরণ] কীস্পেসের জন্য সূচকগুলি পুনর্নির্মাণ করুন: taurus

    nodetool rebuild_index taurus triggers triggers_env_idx
    nodetool rebuild_index taurus triggers triggers_job_id_idx
    nodetool rebuild_index taurus triggers triggers_org_id_idx
    nodetool rebuild_index taurus job_details job_details_job_class_name_idx
    nodetool rebuild_index taurus job_details job_details_job_group_idx
    nodetool rebuild_index taurus job_details job_details_job_name_idx
    nodetool rebuild_index taurus org_triggers org_triggers_org_id_idx
    nodetool rebuild_index taurus triggers_suite triggers_suite_group_idx
    nodetool rebuild_index taurus triggers_suite triggers_suite_name_idx
    nodetool rebuild_index taurus triggers_suite triggers_suite_suite_id_idx
    
  9. [শুধু নগদীকরণ] কীস্পেসের জন্য সূচকগুলি পুনর্নির্মাণ করুন: notification

    nodetool rebuild_index notification notification_service_item notification_service_item_org_id_idx
    nodetool rebuild_index notification notification_service_item notification_service_item_status_idx
    nodetool rebuild_index notification notification_service_black_list_item notification_service_black_list_item_org_id_idx
    nodetool rebuild_index notification notification_service_black_list_item notification_service_black_list_item_to_email_idx
    nodetool rebuild_index notification notification_email_template_item notification_email_template_item_name_idx
    nodetool rebuild_index notification notification_email_template_item notification_email_template_item_org_id_idx
    

যাচাইকরণ

  1. পরিশিষ্ট 1- এর নির্দেশাবলী অনুসরণ করে স্কিমাতে কমপ্যাকশন কৌশল পরিবর্তন কার্যকর হয়েছে কিনা তা পরীক্ষা করুন।
  2. যাচাই করুন কমপ্যাকশন সফলভাবে চালানো হয়েছে এবং কৌশল পরিবর্তনের পরে ডেটা কম্প্যাক্ট করা হয়েছে:
    1. প্রতিটি ক্যাসান্ড্রা নোডে, সমস্ত কমপ্যাকশন সম্পন্ন হয়েছে এবং কিছুই মুলতুবি আছে কিনা তা দেখতে নিম্নলিখিত নোডটুল কমান্ডটি চালান:
      nodetool compactionstats
    2. কোন কমপ্যাকশন মুলতুবি নেই তা নিশ্চিত করতে উপরের কমান্ডটি ব্যবহার করে একবার যাচাই করা হলে, কম্প্যাকশন কৌশল পরিবর্তন করার সময় টাইমস্ট্যাম্পের পরে ডেটা ফাইলের ( /opt/apigee/data/apigee-cassandra/data/ এর অধীনে) শেষ পরিবর্তিত টাইমস্ট্যাম্প পরীক্ষা করুন। মৃত্যুদন্ড কার্যকর করা হয়েছিল।

রোলব্যাক

যদি আপনাকে রোলব্যাক করতে হয়, আপনি নীচের বিকল্পগুলির মধ্যে একটি বেছে নিতে পারেন:

বিকল্প 1: পরিবর্তন প্রত্যাবর্তন করুন

কম্প্যাকশন স্ট্র্যাটেজিকে রোলব্যাক করুন সেই স্ট্র্যাটেজিতে যা আপনার কাছে ছিল।

CQL প্রম্পটে অনুরূপ ALTER TABLE কমান্ডগুলি চালান যা আপনি কমপ্যাকশন কৌশল পরিবর্তন করতে আগে চালিয়েছিলেন।

কম্প্যাকশন কৌশলটি LeveledCompactionStrategy এ পরিবর্তন করার সময় আপনি যদি ইতিমধ্যে সূচকগুলি পুনর্নির্মাণ করে থাকেন, তাহলে আপনাকে আবার সূচকগুলি পুনর্নির্মাণ করতে হবে। সমস্ত সূচক পুনর্নির্মাণের জন্য আগের মতো একই পদক্ষেপগুলি অনুসরণ করুন৷ আপনি যদি আগে সূচকগুলি পুনর্নির্মাণ না করেন তবে রোলব্যাকের সময় আপনাকে সূচকগুলি পুনর্নির্মাণের দরকার নেই।

বিকল্প 2: ব্যাকআপ থেকে সম্পূর্ণ ডেটা পুনরুদ্ধার

সমস্ত কীস্পেসের জন্য ব্যাকআপ থেকে ডেটা পুনরুদ্ধার করুন:

ব্যাকআপ থেকে পুনরুদ্ধারে নথিভুক্ত হিসাবে পুনরুদ্ধার করতে অনুগ্রহ করে নির্দেশাবলী অনুসরণ করুন৷

পরিশিষ্ট 1: কমপ্যাকশন কৌশল পরীক্ষা করুন

কম্প্যাকশন কৌশলগুলি ক্যাসান্দ্রার একটি টেবিল স্তরে সেট করা হয়েছে। আপনি প্রতিটি টেবিলের জন্য কমপ্যাকশন কৌশল পরীক্ষা করতে নীচের প্রশ্নগুলি ব্যবহার করতে পারেন।

আপনি CQL প্রম্পটে CQL চালাতে পারেন। CQL প্রম্পট আহ্বান করতে:

/opt/apigee/apigee-cassandra/bin/cqlsh `hostname -i`

আপনি নিম্নলিখিত মত একটি প্রতিক্রিয়া দেখতে পাবেন:

Connected to apigee at XX.XX.XX.XX:9042.
[cqlsh 5.0.1 | Cassandra 3.11.16 | CQL spec 3.4.4 | Native protocol v4]
Use HELP for help.
cqlsh>

আপনি নিম্নরূপ বর্তমান কম্প্যাকশন কৌশল নির্ধারণ করতে পারেন:

আউটপুটের প্রতিটি সারি একটি কীস্পেসের মধ্যে একটি টেবিলের সাথে সম্পর্কিত। প্রতিটি সারির জন্য, কলাম কম্প্যাকশন টেবিল দ্বারা ব্যবহৃত কম্প্যাকশন কৌশল নির্দেশ করে।

  • যদি কমপ্যাকশন কৌশলটি SizeTieredCompactionStrategy-তে সেট করা থাকে, তাহলে নীচের ক্যোয়ারীগুলিতে কলামের কম্প্যাকশনটি এরকম কিছু হবে:
  • {'class': 'org.apache.cassandra.db.compaction.SizeTieredCompactionStrategy', 'max_threshold': '32', 'min_threshold': '4'}
  • যদি কমপ্যাকশন কৌশলটি লেভেলড কমপ্যাকশন স্ট্র্যাটেজিতে সেট করা থাকে, তাহলে নীচের ক্যোয়ারীতে কলামের কম্প্যাশনটি এরকম কিছু হবে:
  • {'class': 'org.apache.cassandra.db.compaction.LeveledCompactionStrategy'}

একটি নির্দিষ্ট কীস্পেসে প্রতিটি টেবিলের জন্য কমপ্যাকশন কৌশল নির্ধারণ করতে নীচের প্রশ্নগুলি চালানো যেতে পারে:

select keyspace_name, table_name, compaction from system_schema.tables where keyspace_name = 'kms';
select keyspace_name, table_name, compaction from system_schema.tables where keyspace_name = 'user_settings';
select keyspace_name, table_name, compaction from system_schema.tables where keyspace_name = 'keyvaluemap';
select keyspace_name, table_name, compaction from system_schema.tables where keyspace_name = 'devconnect';
select keyspace_name, table_name, compaction from system_schema.tables where keyspace_name = 'counter';
select keyspace_name, table_name, compaction from system_schema.tables where keyspace_name = 'cache';
select keyspace_name, table_name, compaction from system_schema.tables where keyspace_name = 'auth';
select keyspace_name, table_name, compaction from system_schema.tables where keyspace_name = 'audit';
select keyspace_name, table_name, compaction from system_schema.tables where keyspace_name = 'apprepo';
select keyspace_name, table_name, compaction from system_schema.tables where keyspace_name = 'apimodel_v2';
select keyspace_name, table_name, compaction from system_schema.tables where keyspace_name = 'identityzone';
select keyspace_name, table_name, compaction from system_schema.tables where keyspace_name = 'dek';
select keyspace_name, table_name, compaction from system_schema.tables where keyspace_name = 'analytics';

#If you are using Monetization, check the below as well
select keyspace_name, table_name, compaction from system_schema.tables where keyspace_name = 'mint';
select keyspace_name, table_name, compaction from system_schema.tables where keyspace_name = 'taurus';
select keyspace_name, table_name, compaction from system_schema.tables where keyspace_name = 'notification';