1. ওভারভিউ
কোডল্যাবগুলির সার্ভারলেস মাইগ্রেশন স্টেশন সিরিজ (স্ব-গতিসম্পন্ন, হ্যান্ড-অন টিউটোরিয়াল) এবং সম্পর্কিত ভিডিওগুলির লক্ষ্য হল Google ক্লাউড সার্ভারহীন বিকাশকারীদের তাদের অ্যাপ্লিকেশনগুলিকে এক বা একাধিক মাইগ্রেশনের মাধ্যমে গাইড করে আধুনিকীকরণ করতে সাহায্য করা, প্রাথমিকভাবে উত্তরাধিকার পরিষেবাগুলি থেকে দূরে সরে যাওয়া৷ এটি করা আপনার অ্যাপগুলিকে আরও বহনযোগ্য করে তোলে এবং আপনাকে আরও বিকল্প এবং নমনীয়তা দেয়, যা আপনাকে ক্লাউড পণ্যগুলির একটি বিস্তৃত পরিসরের সাথে একীভূত করতে এবং অ্যাক্সেস করতে এবং আরও সহজে নতুন ভাষা প্রকাশগুলিতে আপগ্রেড করতে সক্ষম করে৷ প্রাথমিকভাবে প্রথম দিকের ক্লাউড ব্যবহারকারীদের উপর ফোকাস করার সময়, প্রাথমিকভাবে অ্যাপ ইঞ্জিন (স্ট্যান্ডার্ড এনভায়রনমেন্ট) ডেভেলপারদের, এই সিরিজটি ক্লাউড ফাংশন এবং ক্লাউড রানের মতো অন্যান্য সার্ভারহীন প্ল্যাটফর্মগুলিকে অন্তর্ভুক্ত করার জন্য যথেষ্ট বিস্তৃত, বা অন্য কোথাও প্রযোজ্য হলে।
এই কোডল্যাবের উদ্দেশ্য হল পাইথন 2 অ্যাপ ইঞ্জিন ডেভেলপারদের দেখানো যে কিভাবে অ্যাপ ইঞ্জিন মেমক্যাশ থেকে ক্লাউড মেমোরিস্টোরে ( রেডিসের জন্য) স্থানান্তর করা যায়। অ্যাপ ইঞ্জিন ndb থেকে ক্লাউড NDB- তে একটি অন্তর্নিহিত স্থানান্তরও রয়েছে, তবে এটি প্রাথমিকভাবে মডিউল 2 কোডল্যাবে কভার করা হয়েছে; আরও ধাপে ধাপে তথ্যের জন্য এটি পরীক্ষা করে দেখুন।
আপনি কিভাবে শিখবেন
- একটি ক্লাউড মেমোরিস্টোর ইনস্ট্যান্স সেট আপ করুন (ক্লাউড কনসোল বা
gcloudটুল থেকে) - একটি ক্লাউড সার্ভারহীন ভিপিসি অ্যাক্সেস সংযোগকারী সেট আপ করুন (ক্লাউড কনসোল বা
gcloudটুল থেকে) - App Engine Memcache থেকে Cloud Memorystore এ স্থানান্তর করুন
- একটি নমুনা অ্যাপে ক্লাউড মেমোরিস্টোরের সাথে ক্যাশিং প্রয়োগ করুন
- App Engine
ndbথেকে Cloud NDB-তে স্থানান্তর করুন
আপনি কি প্রয়োজন হবে
- একটি সক্রিয় বিলিং অ্যাকাউন্ট সহ একটি Google ক্লাউড প্রকল্প (এটি একটি বিনামূল্যের কোডল্যাব নয় )
- মৌলিক পাইথন দক্ষতা
- সাধারণ লিনাক্স কমান্ডের কাজের জ্ঞান
- অ্যাপ ইঞ্জিন অ্যাপ্লিকেশানগুলি বিকাশ এবং স্থাপন করার প্রাথমিক জ্ঞান
- একটি কার্যকরী মডিউল 12 অ্যাপ ইঞ্জিন অ্যাপ ( মডিউল 12 কোডল্যাবটি সম্পূর্ণ করুন [প্রস্তাবিত] বা রেপো থেকে মডিউল 12 অ্যাপটি অনুলিপি করুন)
সমীক্ষা
আপনি কিভাবে এই টিউটোরিয়াল ব্যবহার করবেন?
পাইথনের সাথে আপনার অভিজ্ঞতাকে আপনি কীভাবে মূল্যায়ন করবেন?
আপনি Google ক্লাউড পরিষেবাগুলি ব্যবহার করার সাথে আপনার অভিজ্ঞতাকে কীভাবে মূল্যায়ন করবেন?
2. পটভূমি
এই কোডল্যাবটি দেখায় কিভাবে অ্যাপ ইঞ্জিন মেমক্যাশে (এবং এনডিবি) থেকে ক্লাউড মেমোরিস্টোরে (এবং ক্লাউড এনডিবি) একটি নমুনা অ্যাপ স্থানান্তর করা যায়। এই প্রক্রিয়ায় অ্যাপ ইঞ্জিন বান্ডিল করা পরিষেবাগুলির উপর নির্ভরতা প্রতিস্থাপন করা জড়িত, আপনার অ্যাপগুলিকে আরও বহনযোগ্য করে তোলে৷ আপনি হয় অ্যাপ ইঞ্জিনে থাকতে বেছে নিতে পারেন অথবা আগে বর্ণিত বিকল্পগুলির মধ্যে যেকোনো একটিতে যাওয়ার কথা বিবেচনা করতে পারেন।
এই স্থানান্তরের জন্য এই সিরিজের অন্যদের তুলনায় আরও বেশি পরিশ্রমের প্রয়োজন৷ অ্যাপ ইঞ্জিন মেমক্যাশের জন্য প্রস্তাবিত প্রতিস্থাপন হল ক্লাউড মেমোরিস্টোর , একটি সম্পূর্ণ-পরিচালিত ক্লাউড-ভিত্তিক ক্যাশিং পরিষেবা। মেমোরিস্টোর একজোড়া জনপ্রিয় ওপেন সোর্স ক্যাশিং ইঞ্জিন, রেডিস এবং মেমক্যাচেড সমর্থন করে। এই মাইগ্রেশন মডিউলটি Redis-এর জন্য ক্লাউড মেমোরিস্টোর ব্যবহার করে। আপনি মেমোরিস্টোর এবং রেডিস ওভারভিউতে আরও শিখতে পারেন।
কারণ মেমোরিস্টোরের জন্য একটি চলমান সার্ভার প্রয়োজন, ক্লাউড ভিপিসিও প্রয়োজন। বিশেষত, একটি সার্ভারহীন ভিপিসি অ্যাক্সেস সংযোগকারী তৈরি করতে হবে যাতে অ্যাপ ইঞ্জিন অ্যাপটি তার ব্যক্তিগত আইপি ঠিকানার মাধ্যমে মেমোরিস্টোর উদাহরণের সাথে সংযোগ করতে পারে। আপনি যখন এই অনুশীলনটি সম্পূর্ণ করবেন, আপনি অ্যাপটিকে আপডেট করবেন যাতে এটি আগের মতো আচরণ করার সময়, ক্লাউড মেমোরিস্টোর ক্যাশিং পরিষেবা হবে, অ্যাপ ইঞ্জিনের মেমক্যাশ পরিষেবা প্রতিস্থাপন করবে।
এই টিউটোরিয়ালটি পাইথন 2-এর মডিউল 12 নমুনা অ্যাপ দিয়ে শুরু হয় এবং তারপরে পাইথন 3-তে একটি অতিরিক্ত, ঐচ্ছিক, ছোটখাট আপগ্রেড করা হয়। আপনি যদি পাইথন 3 অ্যাপ ইঞ্জিন SDK-এর মাধ্যমে পাইথন 3 থেকে অ্যাপ ইঞ্জিন বান্ডিল পরিষেবাগুলি অ্যাক্সেস করার সাথে ইতিমধ্যে পরিচিত হন, তাহলে আপনি এটি করতে পারেন। পরিবর্তে মডিউল 12 নমুনা অ্যাপের পাইথন 3 সংস্করণ দিয়ে শুরু করুন। এটি করার ফলে SDK-এর ব্যবহার অপসারণ করা হবে কারণ মেমোরিস্টোর একটি অ্যাপ ইঞ্জিন বান্ডিল পরিষেবা নয় । পাইথন 3 অ্যাপ ইঞ্জিন SDK কীভাবে ব্যবহার করবেন তা শেখা এই টিউটোরিয়ালের সুযোগের বাইরে।
এই টিউটোরিয়ালটি নিম্নলিখিত মূল পদক্ষেপগুলি বৈশিষ্ট্যযুক্ত:
- সেটআপ/প্রিওয়ার্ক
- ক্যাশিং পরিষেবা সেট আপ করুন
- কনফিগারেশন ফাইল আপডেট করুন
- প্রধান অ্যাপ্লিকেশন আপডেট করুন
3. সেটআপ/প্রিওয়ার্ক
ক্লাউড প্রকল্প প্রস্তুত করুন
আমরা মডিউল 12 কোডল্যাব সম্পূর্ণ করার জন্য আপনি যে প্রকল্পটি ব্যবহার করেছেন সেই একই প্রকল্পটি পুনরায় ব্যবহার করার পরামর্শ দিই। বিকল্পভাবে, আপনি একটি একেবারে নতুন প্রকল্প তৈরি করতে পারেন বা অন্য একটি বিদ্যমান প্রকল্প পুনরায় ব্যবহার করতে পারেন। এই সিরিজের প্রতিটি কোডল্যাবে একটি "স্টার্ট" (বেসলাইন কোড যেটি থেকে শুরু হবে) এবং একটি "FINISH" (মাইগ্রেট করা অ্যাপ) রয়েছে। ফিনিশ কোডটি প্রদান করা হয়েছে যাতে আপনার সমস্যা থাকলে আপনি আমাদের সমাধানগুলির সাথে তুলনা করতে পারেন। কিছু ভুল হলে আপনি সবসময় শুরু করতে রোলব্যাক করতে পারেন। এই চেকপয়েন্টগুলি আপনি কীভাবে মাইগ্রেশন করতে হয় তা শিখতে সফল হয়েছেন তা নিশ্চিত করার জন্য ডিজাইন করা হয়েছে।
আপনি যে ক্লাউড প্রজেক্ট ব্যবহার করেন না কেন, নিশ্চিত করুন যে এটির একটি সক্রিয় বিলিং অ্যাকাউন্ট আছে। এছাড়াও নিশ্চিত করুন যে অ্যাপ ইঞ্জিন সক্রিয় আছে । পর্যালোচনা করুন এবং নিশ্চিত হন যে আপনি এই টিউটোরিয়ালগুলি করার সাধারণ খরচের প্রভাবগুলি বুঝতে পেরেছেন৷ যদিও এই সিরিজের অন্যদের থেকে ভিন্ন, এই কোডল্যাবটি ক্লাউড রিসোর্স ব্যবহার করে যেগুলির একটি বিনামূল্যের স্তর নেই , তাই অনুশীলনটি সম্পূর্ণ করতে কিছু খরচ করা হবে। বিলিং চার্জ কমানোর জন্য রিসোর্স রিলিজ করার শেষে নির্দেশাবলী সহ, কম ব্যবহারের জন্য সুপারিশ সহ আরও নির্দিষ্ট খরচ তথ্য প্রদান করা হবে।
বেসলাইন নমুনা অ্যাপ্লিকেশন পান
বেসলাইন মডিউল 12 কোড থেকে আমরা শুরু করছি, এই কোডল্যাব আপনাকে ধাপে ধাপে মাইগ্রেশনের মাধ্যমে নিয়ে যাবে। সম্পূর্ণ হয়ে গেলে, আপনি একটি কার্যকরী মডিউল 13 অ্যাপে পৌঁছাবেন যা ফিনিশ ফোল্ডারগুলির একটিতে কোডটির সাথে ঘনিষ্ঠভাবে সাদৃশ্যপূর্ণ। এখানে সেই সম্পদগুলি রয়েছে:
- শুরু: মডিউল 12 পাইথন 2 (
mod12) বা পাইথন 3 (mod12b) অ্যাপ - ফিনিশ: মডিউল 13 পাইথন 2 (
mod13a) বা পাইথন 3 (mod13b) অ্যাপ - সম্পূর্ণ মাইগ্রেশন রেপো (ক্লোন বা জিপ ডাউনলোড করুন)
START ফোল্ডারে নিম্নলিখিত ফাইলগুলি থাকা উচিত:
$ ls README.md app.yaml main.py requirements.txt templates
আপনি যদি Python 2 সংস্করণ থেকে শুরু করেন, তাহলে সেখানে একটি appengine_config.py ফাইল এবং সম্ভবত একটি lib ফোল্ডার থাকবে যদি আপনি মডিউল 12 কোডল্যাবটি সম্পূর্ণ করেন।
(পুনঃ) মডিউল 12 অ্যাপ স্থাপন করুন
আপনার অবশিষ্ট কাজ পূর্ববর্তী পদক্ষেপ:
-
gcloudকমান্ড-লাইন টুলের সাথে নিজেকে পুনরায় পরিচিত করুন (যদি প্রয়োজন হয়) - (পুনরায়) অ্যাপ ইঞ্জিনে মডিউল 12 কোড স্থাপন করুন (যদি প্রয়োজন হয়)
Python 2 ব্যবহারকারীদের এই কমান্ডগুলির সাথে lib ফোল্ডারটি মুছে ফেলা এবং পুনরায় ইনস্টল করা উচিত:
rm -rf ./lib; pip install -t lib -r requirements.txt
এখন প্রত্যেকের (পাইথন 2 এবং 3 ব্যবহারকারীদের) এই কমান্ডের সাথে অ্যাপ ইঞ্জিনে কোড আপলোড করা উচিত:
gcloud app deploy
একবার সফলভাবে মোতায়েন হয়ে গেলে, মডিউল 12-এর অ্যাপের মতো অ্যাপের চেহারা এবং কার্যকারিতা নিশ্চিত করুন, একটি ওয়েব অ্যাপ যা ভিজিট ট্র্যাক করে, একই ব্যবহারকারীর জন্য এক ঘণ্টার জন্য ক্যাশ করে:

যেহেতু সাম্প্রতিক ভিজিটগুলি ক্যাশে করা হয়েছে, তাই পৃষ্ঠা রিফ্রেশগুলি মোটামুটি দ্রুত লোড হওয়া উচিত৷
4. ক্যাশিং পরিষেবা সেট আপ করুন৷
ক্লাউড মেমোরিস্টোর সার্ভারহীন নয় । একটি উদাহরণ প্রয়োজন; এই ক্ষেত্রে একটি চলমান Redis. Memcache থেকে ভিন্ন, Memorystore হল একটি স্বতন্ত্র ক্লাউড পণ্য এবং এটির একটি বিনামূল্যের স্তর নেই , তাই এগিয়ে যাওয়ার আগে Redis মূল্য সংক্রান্ত তথ্যের জন্য Memorystore চেক করতে ভুলবেন না। এই অনুশীলনের জন্য খরচ কমানোর জন্য, আমরা পরিচালনা করার জন্য সর্বনিম্ন সম্পদের সুপারিশ করি: একটি মৌলিক পরিষেবা স্তর এবং একটি 1 GB ক্ষমতা।
মেমোরিস্টোর ইনস্ট্যান্সটি আপনার অ্যাপ ইঞ্জিন অ্যাপের (দৃষ্টান্ত) থেকে আলাদা নেটওয়ার্কে রয়েছে এবং সেই কারণেই একটি সার্ভারহীন ভিপিসি অ্যাক্সেস সংযোগকারী তৈরি করতে হবে যাতে অ্যাপ ইঞ্জিন আপনার মেমোরিস্টোর সংস্থানগুলি অ্যাক্সেস করতে পারে। ভিপিসি খরচ কমাতে, ইনস্ট্যান্স টাইপ ( f1-micro ) এবং অনুরোধ করার জন্য সবচেয়ে কম সংখ্যক দৃষ্টান্ত বেছে নিন (আমরা সর্বনিম্ন 2 , সর্বোচ্চ 3 প্রস্তাব করি)। এছাড়াও VPC মূল্য তথ্য পৃষ্ঠাটি দেখুন।
প্রতিটি প্রয়োজনীয় সংস্থান তৈরি করার মাধ্যমে আমরা আপনাকে নেতৃত্ব দেওয়ার জন্য খরচ কমানোর জন্য এই সুপারিশগুলি পুনরাবৃত্তি করি। উপরন্তু, আপনি যখন ক্লাউড কনসোলে মেমোরিস্টোর এবং ভিপিসি রিসোর্স তৈরি করেন, আপনি উপরের-ডানদিকে কোণায় প্রতিটি পণ্যের জন্য মূল্য নির্ধারণের ক্যালকুলেটর দেখতে পাবেন, যা আপনাকে একটি মাসিক খরচের অনুমান দেয় (নীচের চিত্রটি দেখুন)। আপনি যদি আপনার বিকল্পগুলি পরিবর্তন করেন তবে সেই মানগুলি স্বয়ংক্রিয়ভাবে সামঞ্জস্য হয়। এটি মোটামুটি আপনার যা দেখার আশা করা উচিত:

উভয় সংস্থানই প্রয়োজন, এবং আপনি প্রথমে কোনটি তৈরি করেন তা বিবেচ্য নয়। আপনি যদি প্রথমে মেমোরিস্টোর ইনস্ট্যান্স তৈরি করেন, তাহলে আপনার অ্যাপ ইঞ্জিন অ্যাপ VPC সংযোগকারী ছাড়া এটিতে পৌঁছাতে পারবে না। একইভাবে, আপনি যদি প্রথমে VPC সংযোগকারী তৈরি করেন, আপনার অ্যাপ ইঞ্জিন অ্যাপের সাথে কথা বলার জন্য সেই VPC নেটওয়ার্কে কিছুই নেই৷ এই টিউটোরিয়ালটি আপনাকে প্রথমে VPC সংযোগকারী দ্বারা অনুসরণ করে মেমোরিস্টোর উদাহরণ তৈরি করেছে।
একবার উভয় সংস্থান অনলাইন হলে, আপনি app.yaml এ প্রাসঙ্গিক তথ্য যোগ করতে যাচ্ছেন যাতে আপনার অ্যাপ ক্যাশে অ্যাক্সেস করতে পারে। আপনি অফিসিয়াল ডকুমেন্টেশনে Python 2 বা Python 3 গাইডগুলি উল্লেখ করতে পারেন। ক্লাউড এনডিবি মাইগ্রেশন পৃষ্ঠায় ( পাইথন 2 বা পাইথন 3 ) ডেটা ক্যাশিং গাইডটিও উল্লেখ করার মতো।
একটি ক্লাউড মেমোরিস্টোর উদাহরণ তৈরি করুন
যেহেতু ক্লাউড মেমোরিস্টোরের কোনো বিনামূল্যের স্তর নেই, তাই আমরা কোডল্যাব সম্পূর্ণ করার জন্য ন্যূনতম পরিমাণ সম্পদ বরাদ্দ করার পরামর্শ দিই। আপনি এই সেটিংস ব্যবহার করে খরচ ন্যূনতম রাখতে পারেন:
- সর্বনিম্ন পরিষেবা স্তর নির্বাচন করুন: মৌলিক (কনসোল ডিফল্ট: "স্ট্যান্ডার্ড",
gcloudডিফল্ট: "বেসিক")। - সর্বনিম্ন পরিমাণ সঞ্চয়স্থান চয়ন করুন: 1 GB (কনসোল ডিফল্ট: 16 GB,
gcloudডিফল্ট: 1 GB)। - সাধারণত যেকোন সফ্টওয়্যারের নতুন সংস্করণের জন্য সর্বাধিক পরিমাণ সম্পদের প্রয়োজন হয়, তবে সবচেয়ে পুরানো সংস্করণ নির্বাচন করাও সম্ভবত সুপারিশ করা হয় না। দ্বিতীয় সর্বশেষ সংস্করণটি বর্তমানে Redis সংস্করণ 5.0 (কনসোল ডিফল্ট: 6.x)
সেই সেটিংসগুলি মাথায় রেখে, পরবর্তী বিভাগটি আপনাকে ক্লাউড কনসোল থেকে উদাহরণ তৈরি করার মাধ্যমে নেতৃত্ব দেবে। আপনি যদি কমান্ড-লাইন থেকে এটি করতে পছন্দ করেন তবে এড়িয়ে যান।
ক্লাউড কনসোল থেকে
ক্লাউড কনসোলে ক্লাউড মেমোরিস্টোর পৃষ্ঠাতে যান (আপনাকে বিলিং তথ্যের জন্য অনুরোধ করা হতে পারে)। আপনি যদি এখনও মেমোরিস্টোর সক্ষম না করে থাকেন তবে আপনাকে তা করতে বলা হবে:

একবার আপনি এটি সক্ষম করলে (এবং সম্ভবত বিলিং সহ), আপনি মেমোরিস্টোর ড্যাশবোর্ডে পৌঁছাবেন। এখানে আপনি আপনার প্রকল্পে তৈরি সমস্ত উদাহরণ দেখতে পারেন। নীচে দেখানো প্রজেক্টের কোনটি নেই, তাই আপনি দেখতে পাচ্ছেন, "প্রদর্শনের জন্য কোন সারি নেই"। একটি মেমোরিস্টোর ইনস্ট্যান্স তৈরি করতে, উপরে ইনস্ট্যান্স তৈরি করুন ক্লিক করুন:

এই পৃষ্ঠাটি মেমোরিস্টোর উদাহরণ তৈরি করতে আপনার পছন্দসই সেটিংসের সাথে সম্পূর্ণ করার জন্য একটি ফর্ম বৈশিষ্ট্যযুক্ত:

এই টিউটোরিয়াল এবং এর নমুনা অ্যাপের জন্য খরচ কম রাখতে, আগে কভার করা সুপারিশগুলি অনুসরণ করুন। আপনি আপনার নির্বাচন করার পরে, তৈরি করুন ক্লিক করুন। সৃষ্টি প্রক্রিয়া কয়েক মিনিট সময় নেয়। এটি শেষ হলে, app.yaml এ যোগ করতে উদাহরণের আইপি ঠিকানা এবং পোর্ট নম্বর কপি করুন।
কমান্ড লাইন থেকে
ক্লাউড কনসোল থেকে মেমোরিস্টোর দৃষ্টান্ত তৈরি করা দৃশ্যত তথ্যপূর্ণ হলেও, কেউ কেউ কমান্ড-লাইন পছন্দ করেন। এগিয়ে যাওয়ার আগে gcloud ইনস্টল এবং আরম্ভ করা নিশ্চিত করুন।
ক্লাউড কনসোলের মতো, রেডিসের জন্য ক্লাউড মেমোরিস্টোর অবশ্যই সক্রিয় থাকতে হবে। gcloud services enable redis.googleapis.com এবং এটি সম্পূর্ণ হওয়ার জন্য অপেক্ষা করুন, যেমন এই উদাহরণ:
$ gcloud services enable redis.googleapis.com Operation "operations/acat.p2-aaa-bbb-ccc-ddd-eee-ffffff" finished successfully.
যদি পরিষেবাটি ইতিমধ্যে সক্ষম করা থাকে, কমান্ডটি চালানোর (আবার) কোন (নেতিবাচক) পার্শ্ব প্রতিক্রিয়া নেই। পরিষেবাটি সক্ষম করে, আসুন একটি মেমোরিস্টোর উদাহরণ তৈরি করি। এই আদেশটি এইরকম দেখাচ্ছে:
gcloud redis instances create NAME --redis-version VERSION \
--region REGION --project PROJECT_ID
আপনার মেমোরিস্টোর উদাহরণের জন্য একটি নাম চয়ন করুন; এই ল্যাবটি " my-project " এর একটি প্রজেক্ট আইডি সহ নাম হিসাবে " demo-ms " ব্যবহার করে। এই নমুনা অ্যাপটির অঞ্চল হল us-central1 ( us-central এর মতো), কিন্তু লেটেন্সি একটি উদ্বেগের বিষয় হলে আপনি আপনার কাছাকাছি একটি ব্যবহার করতে পারেন। আপনাকে অবশ্যই আপনার অ্যাপ ইঞ্জিন অ্যাপের মতো একই অঞ্চল নির্বাচন করতে হবে। আপনি আপনার পছন্দের যেকোনো Redis সংস্করণ নির্বাচন করতে পারেন, কিন্তু আমরা পূর্বে প্রস্তাবিত সংস্করণ 5 ব্যবহার করছি। সেই সেটিংস দেওয়া হলে, আপনি যে কমান্ডটি জারি করবেন (সংশ্লিষ্ট আউটপুট সহ):
$ gcloud redis instances create demo-ms --region us-central1 \
--redis-version redis_5_0 --project my-project
Create request issued for: [demo-ms]
Waiting for operation [projects/my-project/locations/us-central1/operations/operation-xxxx] to complete...done.
Created instance [demo-ms].
ক্লাউড কনসোল ডিফল্টের বিপরীতে, gcloud ডিফল্ট ন্যূনতম সম্পদে। ফলাফল হল যে সেই কমান্ডে পরিষেবা স্তর বা সঞ্চয়ের পরিমাণের প্রয়োজন ছিল না। একটি মেমোরিস্টোর ইনস্ট্যান্স তৈরি করতে কয়েক মিনিট সময় লাগে এবং এটি হয়ে গেলে, ইনস্ট্যান্সের আইপি ঠিকানা এবং পোর্ট নম্বর নোট করুন কারণ সেগুলি শীঘ্রই app.yaml এ যোগ করা হবে।
দৃষ্টান্ত তৈরি নিশ্চিত করুন
ক্লাউড কনসোল বা কমান্ড-লাইন থেকে
আপনি ক্লাউড কনসোল বা কমান্ড-লাইন থেকে আপনার উদাহরণ তৈরি করেছেন কিনা, আপনি নিশ্চিত করতে পারেন যে এটি উপলব্ধ এবং এই কমান্ডের সাথে ব্যবহারের জন্য প্রস্তুত: gcloud redis instances list --region REGION
এখানে us-central1 অঞ্চলে দৃষ্টান্ত পরীক্ষা করার জন্য কমান্ডটি প্রত্যাশিত আউটপুট সহ আমরা এইমাত্র তৈরি করা উদাহরণটি দেখায়:
$ gcloud redis instances list --region us-central1 INSTANCE_NAME VERSION REGION TIER SIZE_GB HOST PORT NETWORK RESERVED_IP STATUS CREATE_TIME demo-ms REDIS_5_0 us-central1 BASIC 1 10.aa.bb.cc 6379 default 10.aa.bb.dd/29 READY 2022-01-28T09:24:45
উদাহরণের তথ্য বা আপনার অ্যাপ কনফিগার করার জন্য জিজ্ঞাসা করা হলে, HOST এবং PORT ব্যবহার করতে ভুলবেন না ( RESERVED_IP নয়)। ক্লাউড কনসোলের ক্লাউড মেমোরিস্টোর ড্যাশবোর্ডটি এখন সেই উদাহরণটি প্রদর্শন করা উচিত:

কম্পিউট ইঞ্জিন ভার্চুয়াল মেশিন থেকে
আপনার যদি একটি কম্পিউট ইঞ্জিন ভার্চুয়াল মেশিন (ভিএম) থাকে তবে আপনি এটি কাজ করছে কিনা তা নিশ্চিত করতে একটি VM থেকে আপনার মেমোরিস্টোর ইনস্ট্যান্স সরাসরি কমান্ড পাঠাতে পারেন। সচেতন থাকুন যে VM ব্যবহারে আপনি ইতিমধ্যে যে সংস্থানগুলি ব্যবহার করছেন তার থেকে স্বতন্ত্র খরচ যুক্ত হতে পারে।
সার্ভারহীন ভিপিসি অ্যাক্সেস সংযোগকারী তৈরি করুন
ক্লাউড মেমোরিস্টোরের মতো, আপনি ক্লাউড কনসোলে বা কমান্ড-লাইনে সার্ভারহীন ক্লাউড ভিপিসি সংযোগকারী তৈরি করতে পারেন। একইভাবে, ক্লাউড ভিপিসি-র কোনো বিনামূল্যের স্তর নেই, তাই আমরা সর্বনিম্ন খরচ রাখার স্বার্থে কোডল্যাব সম্পূর্ণ করার জন্য সর্বনিম্ন সম্পদ বরাদ্দ করার পরামর্শ দিই, এবং এটি এই সেটিংসের মাধ্যমে অর্জন করা যেতে পারে:
- সর্বনিম্ন সর্বাধিক সংখ্যক দৃষ্টান্ত নির্বাচন করুন: 3 (কনসোল এবং
gcloudডিফল্ট: 10) - সর্বনিম্ন-মূল্যের মেশিনের ধরন চয়ন করুন:
f1-micro(কনসোল ডিফল্ট:e2-micro, কোনোgcloudডিফল্ট নেই)
পরবর্তী বিভাগটি উপরের ক্লাউড ভিপিসি সেটিংস ব্যবহার করে ক্লাউড কনসোল থেকে সংযোগকারী তৈরির মাধ্যমে আপনাকে নেতৃত্ব দেবে। আপনি যদি কমান্ড-লাইন থেকে এটি করতে পছন্দ করেন তবে পরবর্তী বিভাগে যান।
ক্লাউড কনসোল থেকে
ক্লাউড কনসোলে ক্লাউড নেটওয়ার্কিং "সার্ভারলেস ভিপিসি অ্যাক্সেস" পৃষ্ঠাতে যান (আপনাকে বিলিং তথ্যের জন্য অনুরোধ করা হতে পারে)। আপনি যদি এখনও API সক্ষম না করে থাকেন তবে আপনাকে তা করতে বলা হবে:

একবার আপনি API (এবং সম্ভবত বিলিং সহ) সক্ষম করলে, আপনি তৈরি করা সমস্ত VPC সংযোগকারী প্রদর্শন করে ড্যাশবোর্ডে পৌঁছাবেন। নীচের স্ক্রিনশটটিতে ব্যবহৃত প্রজেক্টের কোনটি নেই, তাই এটি বলে, "প্রদর্শনের জন্য কোন সারি নেই"। আপনার কনসোলে, শীর্ষে সংযোগকারী তৈরি করুন ক্লিক করুন:

পছন্দসই সেটিংস সহ ফর্মটি পূরণ করুন:

আপনার নিজের অ্যাপ্লিকেশনের জন্য উপযুক্ত সেটিংস চয়ন করুন. এই টিউটোরিয়াল এবং ন্যূনতম প্রয়োজন সহ এর নমুনা অ্যাপের জন্য, খরচ কমিয়ে আনার জন্য এটি বোধগম্য, তাই আগে কভার করা সুপারিশগুলি অনুসরণ করুন। একবার আপনি আপনার নির্বাচন করা হয়ে গেলে, তৈরি করুন ক্লিক করুন। একটি VPC সংযোগকারীর অনুরোধ সম্পূর্ণ হতে কয়েক মিনিট সময় লাগবে৷
কমান্ড লাইন থেকে
একটি VPC সংযোগকারী তৈরি করার আগে, প্রথমে সার্ভারহীন VPC অ্যাক্সেস API সক্ষম করুন৷ নিম্নলিখিত কমান্ড জারি করার পরে আপনি অনুরূপ আউটপুট দেখতে হবে:
$ gcloud services enable vpcaccess.googleapis.com Operation "operations/acf.p2-aaa-bbb-ccc-ddd-eee-ffffff" finished successfully.
API সক্ষম হলে, একটি VPC সংযোগকারী একটি কমান্ড দিয়ে তৈরি করা হয় যা দেখতে এইরকম:
gcloud compute networks vpc-access connectors create CONNECTOR_NAME \
--range 10.8.0.0/28 --region REGION --project PROJECT_ID
আপনার সংযোগকারীর জন্য একটি নাম বাছুন সেইসাথে একটি অব্যবহৃত /28 CIDR ব্লক শুরুর IP ঠিকানা। এই টিউটোরিয়ালটি নিম্নলিখিত অনুমান করে:
- প্রজেক্ট আইডি :
my-project - ভিপিসি সংযোগকারীর নাম :
demo-vpc - সর্বনিম্ন দৃষ্টান্ত : 2 (ডিফল্ট) এবং সর্বাধিক দৃষ্টান্ত : 3
- উদাহরণ টাইপ :
f1-micro - অঞ্চল :
us-central1 - IPv4 CIDR ব্লক :
10.8.0.0/28(ক্লাউড কনসোলে প্রস্তাবিত)
আপনি যদি উপরের অনুমানগুলিকে মাথায় রেখে নিম্নলিখিত কমান্ডটি কার্যকর করেন তবে আপনি নীচে যা দেখছেন তার অনুরূপ আউটপুট আশা করুন:
$ gcloud compute networks vpc-access connectors create demo-vpc \
--max-instances 3 --range 10.8.0.0/28 --machine-type f1-micro \
--region us-central1 --project my-project
Create request issued for: [demo-vpc]
Waiting for operation [projects/my-project/locations/us-central1/operations/xxx] to complete...done.
Created connector [demo-vpc].
উপরের কমান্ডটি ডিফল্ট মানগুলিকে বাদ দেয়, যেমন 2-এর মিন ইনস্ট্যান্স এবং default নামে একটি নেটওয়ার্ক। একটি VPC সংযোগকারী তৈরি করা সম্পূর্ণ হতে কয়েক মিনিট সময় নেয়।
সংযোগকারী তৈরি করা নিশ্চিত করুন
প্রক্রিয়াটি শেষ হয়ে গেলে, এটি তৈরি করা হয়েছে এবং ব্যবহারের জন্য প্রস্তুত হয়েছে তা নিশ্চিত করতে, এটি us-central1 অঞ্চল বলে ধরে নিয়ে নিম্নলিখিত gcloud কমান্ডটি জারি করুন:
$ gcloud compute networks vpc-access connectors list --region us-central1 CONNECTOR_ID REGION NETWORK IP_CIDR_RANGE SUBNET SUBNET_PROJECT MIN_THROUGHPUT MAX_THROUGHPUT STATE demo-vpc us-central1 default 10.8.0.0/28 200 300 READY
একইভাবে, ড্যাশবোর্ডটি এখন আপনার তৈরি করা সংযোগকারীটি প্রদর্শন করবে:

ক্লাউড প্রকল্প আইডি, ভিপিসি সংযোগকারীর নাম এবং অঞ্চলটি নোট করুন।
এখন যেহেতু আপনি কমান্ড-লাইন বা কনসোলে প্রয়োজনীয় অতিরিক্ত ক্লাউড সংস্থান তৈরি করেছেন, তাদের ব্যবহার সমর্থন করার জন্য অ্যাপ্লিকেশন কনফিগারেশন আপডেট করার সময় এসেছে।
5. কনফিগারেশন ফাইল আপডেট করুন
প্রথম ধাপ হল কনফিগারেশন ফাইলের সমস্ত প্রয়োজনীয় আপডেট করা। পাইথন 2 ব্যবহারকারীদের মাইগ্রেট করতে সহায়তা করা এই কোডল্যাবের মূল লক্ষ্য, তবে এই বিষয়বস্তুটি সাধারণত নীচের প্রতিটি বিভাগে পাইথন 3-এ আরও পোর্ট করার তথ্য সহ অনুসরণ করা হয়।
requirements.txt
এই বিভাগে, আমরা ক্লাউড মেমোরিস্টোরের পাশাপাশি ক্লাউড এনডিবি সমর্থন করার জন্য প্যাকেজ যোগ করছি। রেডিস-এর জন্য ক্লাউড মেমোরিস্টোরের জন্য, পাইথন ( redis ) এর জন্য স্ট্যান্ডার্ড রেডিস ক্লায়েন্ট ব্যবহার করা যথেষ্ট কারণ এখানে কোনও ক্লাউড মেমোরিস্টোর ক্লায়েন্ট লাইব্রেরি নেই। redis এবং google-cloud-ndb উভয়ই requirements.txt এ যোগ করুন, মডিউল 12 থেকে flask যোগ দিন:
flask
redis
google-cloud-ndb
এই requirements.txt ফাইলে কোনো সংস্করণ সংখ্যা নেই, মানে সর্বশেষ সংস্করণ নির্বাচন করা হয়েছে। কোনো অসঙ্গতি দেখা দিলে, কার্যকারী সংস্করণে লক করার জন্য সংস্করণ নম্বর উল্লেখ করুন।
app.yaml
নতুন বিভাগ যোগ করতে
পাইথন 2 অ্যাপ ইঞ্জিন রানটাইমের জন্য ক্লাউড এপিআই যেমন ক্লাউড এনডিবি, যেমন grpcio এবং setuptools ব্যবহার করার সময় নির্দিষ্ট তৃতীয় পক্ষের প্যাকেজের প্রয়োজন হয়। Python 2 ব্যবহারকারীদের অবশ্যই app.yaml এ উপলব্ধ সংস্করণ সহ এই ধরনের অন্তর্নির্মিত লাইব্রেরি তালিকাভুক্ত করতে হবে। আপনার যদি এখনও একটি libraries বিভাগ না থাকে তবে একটি তৈরি করুন এবং নিম্নলিখিতগুলির মতো উভয় লাইব্রেরি যুক্ত করুন:
libraries:
- name: grpcio
version: latest
- name: setuptools
version: latest
আপনার অ্যাপ স্থানান্তর করার সময়, এটি ইতিমধ্যে একটি libraries বিভাগ থাকতে পারে। যদি এটি হয়, এবং হয় grpcio এবং setuptools অনুপস্থিত, শুধু আপনার বিদ্যমান libraries বিভাগে যোগ করুন।
এর পরে, আমাদের নমুনা অ্যাপটির ক্লাউড মেমোরিস্টোর ইনস্ট্যান্স এবং ভিপিসি সংযোগকারী তথ্য প্রয়োজন, তাই আপনি যে পাইথন রানটাইম ব্যবহার করছেন তা নির্বিশেষে app.yaml এ নিম্নলিখিত দুটি নতুন বিভাগ যোগ করুন:
env_variables:
REDIS_HOST: 'YOUR_REDIS_HOST'
REDIS_PORT: 'YOUR_REDIS_PORT'
vpc_access_connector:
name: projects/PROJECT_ID/locations/REGION/connectors/CONNECTOR
এটা যতদূর প্রয়োজনীয় আপডেট যেতে. আপনার আপডেট করা app.yaml এখন এইরকম হওয়া উচিত:
runtime: python27
threadsafe: yes
api_version: 1
handlers:
- url: /.*
script: main.app
libraries:
- name: grpcio
version: 1.0.0
- name: setuptools
version: 36.6.0
env_variables:
REDIS_HOST: 'YOUR_REDIS_HOST'
REDIS_PORT: 'YOUR_REDIS_PORT'
vpc_access_connector:
name: projects/PROJECT_ID/locations/REGION/connectors/CONNECTOR
নীচে একটি "আগে এবং পরে" আপডেটগুলিকে চিত্রিত করে যা আপনাকে app.yaml এ আবেদন করতে হবে:

*পাইথন 3 পার্থক্য
এই বিভাগটি ঐচ্ছিক এবং শুধুমাত্র যদি আপনি Python 3 এ পোর্ট করছেন। এটি করার জন্য, আপনার Python 2 কনফিগারেশনে অনেক পরিবর্তন করতে হবে। আপনি যদি এই সময়ে আপগ্রেড না করেন তবে এই বিভাগটি এড়িয়ে যান৷
Python 3 রানটাইমের জন্য threadsafe বা api_version উভয়ই ব্যবহার করা হয় না, তাই এই দুটি সেটিংস মুছে দিন। সর্বশেষ অ্যাপ ইঞ্জিন রানটাইম বিল্ট-ইন থার্ড-পার্টি লাইব্রেরি বা নন -বিল্ট-ইন লাইব্রেরিগুলির অনুলিপি সমর্থন করে না। থার্ড-পার্টি প্যাকেজগুলির জন্য একমাত্র প্রয়োজনীয়তা হল সেগুলিকে requirements.txt এ তালিকাভুক্ত করা। ফলস্বরূপ, app.yaml এর সম্পূর্ণ libraries বিভাগটি মুছে ফেলা যেতে পারে।
এর পরে, Python 3 রানটাইমের জন্য ওয়েব ফ্রেমওয়ার্ক ব্যবহার করা প্রয়োজন যা তাদের নিজস্ব রাউটিং করে, তাই কেন আমরা ডেভেলপারদের দেখিয়েছি কিভাবে webp2 থেকে ফ্লাস্কে মডিউল 1-এ স্থানান্তর করা যায় । ফলস্বরূপ, সমস্ত স্ক্রিপ্ট হ্যান্ডলারকে auto পরিবর্তন করতে হবে। যেহেতু এই অ্যাপটি কোনো স্ট্যাটিক ফাইল পরিবেশন করে না, তাই হ্যান্ডলারদের তালিকাভুক্ত করা "অর্থহীন" (যেহেতু তারা সবই auto ), তাই পুরো handlers বিভাগটিও সরানো যেতে পারে। ফলস্বরূপ, পাইথন 3-এর জন্য আপনার নতুন, সংক্ষিপ্ত app.yaml টুইক করা এইরকম দেখতে ছোট করা উচিত:
runtime: python39
env_variables:
REDIS_HOST: 'YOUR_REDIS_HOST'
REDIS_PORT: 'YOUR_REDIS_PORT'
vpc_access_connector:
name: projects/PROJECT_ID/locations/REGION/connectors/CONNECTOR
Python 3 এ পোর্ট করার সময় app.yaml এর মধ্যে পার্থক্যের সংক্ষিপ্ত বিবরণ:
-
threadsafeএবংapi_versionসেটিংস মুছুন -
librariesবিভাগ মুছুন -
handlersবিভাগ মুছুন (বা শুধুমাত্রscriptহ্যান্ডলার যদি আপনার অ্যাপ স্ট্যাটিক ফাইল পরিবেশন করে)
মান প্রতিস্থাপন
মেমোরিস্টোর এবং ভিপিসি সংযোগকারীর জন্য নতুন বিভাগে মানগুলি কেবল স্থানধারক। সেই বড়িকৃত মানগুলি ( YOUR_REDIS_HOST, YOUR_REDIS_PORT, PROJECT_ID, REGION, CONNECTOR_NAME ) প্রতিস্থাপন করুন যখন আপনি সেই সংস্থানগুলি আগে তৈরি করেছিলেন তখন থেকে সংরক্ষিত মানগুলি দিয়ে৷ আপনার মেমোরিস্টোর ইনস্ট্যান্সের ক্ষেত্রে, HOST ( RESERVED_IP নয়) এবং PORT ব্যবহার করতে ভুলবেন না। HOST এবং PORT পাওয়ার জন্য এখানে একটি দ্রুত কমান্ড-লাইন উপায় রয়েছে যা demo-ms একটি উদাহরণের নাম ধরে নেয় এবং REGION হল us-central1 :
$ gcloud redis instances describe demo-ms --region us-central1 \
--format "value(host,port)"
10.251.161.51 6379
যদি আমাদের উদাহরণ Redis ইনস্ট্যান্স আইপি ঠিকানাটি পোর্ট 6379 ব্যবহার করে 10.10.10.10 হয় আমাদের প্রজেক্ট my-project এ অবস্থিত অঞ্চল us-central1 demo-vpc এর একটি VPC সংযোগকারী নামের সাথে, app.yaml এর এই বিভাগগুলি এইরকম দেখাবে:
env_variables:
REDIS_HOST: '10.10.10.10'
REDIS_PORT: '6379'
vpc_access_connector:
name: projects/my-project/locations/us-central1/connectors/demo-vpc
appengine_config.py তৈরি বা আপডেট করুন
অন্তর্নির্মিত তৃতীয় পক্ষের লাইব্রেরির জন্য সমর্থন যোগ করুন
ঠিক যেমন আমরা আগে app.yaml দিয়ে করেছি, grpcio এবং setuptools লাইব্রেরির ব্যবহার যোগ করুন। বিল্ট-ইন থার্ড-পার্টি লাইব্রেরি সমর্থন করতে appengine_config.py পরিবর্তন করুন। যদি এটি পরিচিত বলে মনে হয়, এর কারণ হল App Engine ndb থেকে Cloud NDB-তে স্থানান্তরিত করার সময় মডিউল 2-এও এটির প্রয়োজন ছিল৷ সঠিক পরিবর্তনের প্রয়োজন হল lib ফোল্ডারটিকে setuptools.pkg_resources ওয়ার্কিং সেটে যুক্ত করা:

*পাইথন 3 পার্থক্য
এই বিভাগটি ঐচ্ছিক এবং শুধুমাত্র যদি আপনি Python 3-এ পোর্ট করছেন। স্বাগত অ্যাপ ইঞ্জিনের দ্বিতীয় প্রজন্মের পরিবর্তনগুলির মধ্যে একটি হল যে (কখনও কখনও "ভেন্ডরিং" বলা হয়) (নন-বিল্ট-ইন) থার্ড-পার্টি প্যাকেজগুলির অনুলিপি করা এবং বিল্ট-এর উল্লেখ করা। app.yaml এ থার্ড-পার্টি প্যাকেজগুলির আর প্রয়োজন নেই, মানে আপনি সম্পূর্ণ appengine_config.py ফাইলটি মুছে ফেলতে পারেন।
6. অ্যাপ্লিকেশন ফাইল আপডেট করুন
শুধুমাত্র একটি অ্যাপ্লিকেশন ফাইল আছে, main.py , তাই এই বিভাগে সমস্ত পরিবর্তন শুধুমাত্র সেই ফাইলটিকে প্রভাবিত করে। এই অ্যাপ্লিকেশনটিকে ক্লাউড মেমোরিস্টোরে স্থানান্তর করতে আমরা যে পরিবর্তনগুলি করতে যাচ্ছি তার একটি সচিত্র উপস্থাপনা প্রদান করেছি৷ এটি শুধুমাত্র দৃষ্টান্তমূলক উদ্দেশ্যে এবং আপনার ঘনিষ্ঠভাবে বিশ্লেষণ করার জন্য নয়। সমস্ত কাজ আমরা কোডে যে পরিবর্তনগুলি করি তার মধ্যে রয়েছে।

শীর্ষ থেকে শুরু করে, এক সময়ে এই একটি বিভাগ মোকাবেলা করা যাক।
আমদানি আপডেট করুন
মডিউল 12-এর জন্য main.py এ আমদানি বিভাগটি ক্লাউড এনডিবি এবং ক্লাউড টাস্ক ব্যবহার করে; এখানে তাদের আমদানি আছে:
আগে:
from flask import Flask, render_template, request
from google.appengine.api import memcache
from google.appengine.ext import ndb
মেমোরিস্টোরে স্যুইচ করার জন্য এনভায়রনমেন্ট ভেরিয়েবল পড়তে হবে, যার অর্থ আমাদের পাইথন os মডিউলের পাশাপাশি redis , Python Redis ক্লায়েন্ট প্রয়োজন। যেহেতু রেডিস পাইথন অবজেক্টকে ক্যাশে করতে পারে না, তাই pickle ব্যবহার করে সাম্প্রতিক ভিজিট তালিকাটি মার্শাল করুন, তাই এটিও আমদানি করুন। মেমক্যাশের একটি সুবিধা হল যে অবজেক্ট সিরিয়ালাইজেশন স্বয়ংক্রিয়ভাবে ঘটে যেখানে মেমোরিস্টোর একটু বেশি "DIY"। অবশেষে, google.appengine.ext.ndb google.cloud.ndb দিয়ে প্রতিস্থাপন করে App Engine ndb থেকে Cloud NDB-তে আপগ্রেড করুন। এই পরিবর্তনের পরে, আপনার আমদানি এখন নিম্নরূপ হওয়া উচিত:
পরে:
import os
import pickle
from flask import Flask, render_template, request
from google.cloud import ndb
import redis
সূচনা আপডেট করুন
মডিউল 12 ইনিশিয়ালাইজেশনের মধ্যে রয়েছে ফ্লাস্ক অ্যাপ্লিকেশন অবজেক্ট app ইনস্ট্যান্টিয়েটিং করা এবং এক ঘন্টার ক্যাশিংয়ের জন্য একটি ধ্রুবক সেট করা:
আগে :
app = Flask(__name__)
HOUR = 3600
ক্লাউড এপিআই ব্যবহার করার জন্য একটি ক্লায়েন্ট প্রয়োজন, তাই ফ্লাস্কের ঠিক পরে একটি ক্লাউড এনডিবি ক্লায়েন্ট ইনস্ট্যান্টিয়েট করুন। এরপরে, app.yaml এ আপনার সেট করা এনভায়রনমেন্ট ভেরিয়েবল থেকে মেমোরিস্টোর ইনস্ট্যান্সের জন্য IP ঠিকানা এবং পোর্ট নম্বর পান। যে তথ্য দিয়ে সশস্ত্র, একটি Redis ক্লায়েন্ট ইনস্ট্যান্ট. এই আপডেটগুলির পরে আপনার কোডটি কেমন দেখায় তা এখানে:
পরে:
app = Flask(__name__)
ds_client = ndb.Client()
HOUR = 3600
REDIS_HOST = os.environ.get('REDIS_HOST', 'localhost')
REDIS_PORT = os.environ.get('REDIS_PORT', '6379')
REDIS = redis.Redis(host=REDIS_HOST, port=REDIS_PORT)
*পাইথন 3 মাইগ্রেশন
এই বিভাগটি ঐচ্ছিক এবং আপনি যদি মডিউল 12 অ্যাপের পাইথন 3 সংস্করণ থেকে শুরু করেন। যদি তাই হয়, আমদানি এবং সূচনা সম্পর্কিত বেশ কিছু প্রয়োজনীয় পরিবর্তন রয়েছে।
প্রথমত, যেহেতু মেমক্যাশে একটি অ্যাপ ইঞ্জিন বান্ডেলড পরিষেবা, পাইথন 3 অ্যাপে এটির ব্যবহারের জন্য অ্যাপ ইঞ্জিন SDK প্রয়োজন, বিশেষভাবে WSGI অ্যাপ্লিকেশন (পাশাপাশি অন্যান্য প্রয়োজনীয় কনফিগারেশন ) মোড়ানো:
আগে:
from flask import Flask, render_template, request
from google.appengine.api import memcache, wrap_wsgi_app
from google.appengine.ext import ndb
app = Flask(__name__)
app.wsgi_app = wrap_wsgi_app(app.wsgi_app)
HOUR = 3600
যেহেতু আমরা ক্লাউড মেমোরিস্টোরে স্থানান্তরিত করছি (মেমক্যাশের মতো একটি অ্যাপ ইঞ্জিন বান্ডিল পরিষেবা নয়), SDK ব্যবহার অবশ্যই মুছে ফেলতে হবে৷ এটি সোজা কারণ আপনি কেবল সেই পুরো লাইনটি মুছে ফেলবেন যা memcache এবং wrap_wsgi_app উভয়ই আমদানি করে। এছাড়াও wrap_wsgi_app() কলিং লাইনটি মুছে দিন। এই আপডেটগুলি অ্যাপের এই অংশটিকে (আসলে, পুরো অ্যাপটি) পাইথন 2 সংস্করণের অনুরূপ ছেড়ে দেয়।
পরে:
import os
import pickle
from flask import Flask, render_template, request
from google.cloud import ndb
import redis
app = Flask(__name__)
ds_client = ndb.Client()
HOUR = 3600
REDIS_HOST = os.environ.get('REDIS_HOST', 'localhost')
REDIS_PORT = os.environ.get('REDIS_PORT', '6379')
REDIS = redis.Redis(host=REDIS_HOST, port=REDIS_PORT)
অবশেষে, app.yaml (লাইনটি মুছুন: app_engine_apis: true ) এবং requirements.txt (লাইনটি মুছুন: appengine-python-standard ) থেকে SDK-এর ব্যবহার সরিয়ে দিন।
ক্লাউড মেমোরিস্টোরে (এবং ক্লাউড এনডিবি) মাইগ্রেট করুন
ক্লাউড এনডিবি-এর ডেটা মডেলটি অ্যাপ ইঞ্জিন ndb এর সাথে সামঞ্জস্যপূর্ণ হওয়ার উদ্দেশ্যে তৈরি করা হয়েছে, যার অর্থ Visit অবজেক্টের সংজ্ঞা একই থাকে৷ ক্লাউড NDB-তে মডিউল 2 মাইগ্রেশনের অনুকরণ করে, store_visit() এবং fetch_visits() এ সমস্ত ডেটাস্টোর কলগুলিকে ব্লক with একটি নতুন এম্বেড করা হয়েছে (ক্লাউড NDB কনটেক্সট ম্যানেজার ব্যবহার করা প্রয়োজন)। এখানে সেই পরিবর্তনের আগে সেই কলগুলি রয়েছে:
আগে:
def store_visit(remote_addr, user_agent):
'create new Visit entity in Datastore'
Visit(visitor='{}: {}'.format(remote_addr, user_agent)).put()
def fetch_visits(limit):
'get most recent visits'
return Visit.query().order(-Visit.timestamp).fetch(limit)
উভয় ফাংশনে with ds_client.context() ব্লক যুক্ত করুন এবং ডেটাস্টোর কলগুলি ভিতরে রাখুন (এবং ইন্ডেন্টেড)। এই ক্ষেত্রে, কলগুলির জন্য কোনও পরিবর্তনের প্রয়োজন নেই:
পরে:
def store_visit(remote_addr, user_agent):
'create new Visit entity in Datastore'
with ds_client.context():
Visit(visitor='{}: {}'.format(remote_addr, user_agent)).put()
def fetch_visits(limit):
'get most recent visits'
with ds_client.context():
return Visit.query().order(-Visit.timestamp).fetch(limit)
এর পরে, ক্যাশে পরিবর্তনগুলি দেখুন। এখানে মডিউল 12 থেকে main() ফাংশন রয়েছে:
আগে:
@app.route('/')
def root():
'main application (GET) handler'
# check for (hour-)cached visits
ip_addr, usr_agt = request.remote_addr, request.user_agent
visitor = '{}: {}'.format(ip_addr, usr_agt)
visits = memcache.get('visits')
# register visit & run DB query if cache empty or new visitor
if not visits or visits[0].visitor != visitor:
store_visit(ip_addr, usr_agt)
visits = list(fetch_visits(10))
memcache.set('visits', visits, HOUR) # set() not add()
return render_template('index.html', visits=visits)
মেমক্যাশের মতোই রেডিসের "গেট" এবং "সেট" কল রয়েছে। আমরা যা করি তা হল নিজ নিজ ক্লায়েন্ট লাইব্রেরিগুলিকে অদলবদল করা, তাই না? প্রায়। আগেই উল্লেখ করা হয়েছে, আমরা Redis-এর সাথে পাইথন তালিকা ক্যাশে করতে পারি না (কারণ এটি প্রথমে সিরিয়াল করা দরকার, মেমক্যাচে স্বয়ংক্রিয়ভাবে কিছু যত্ন নেয়), তাই set() কলে, ভিজিটগুলিকে pickle.dumps() । একইভাবে, ক্যাশে থেকে ভিজিট পুনরুদ্ধার করার সময়, আপনাকে get() ঠিক পরে pickle.loads() দিয়ে এটিকে আনপিকল করতে হবে। এই পরিবর্তনগুলি বাস্তবায়ন করার পরে এখানে প্রধান হ্যান্ডলার রয়েছে:
পরে:
@app.route('/')
def root():
'main application (GET) handler'
# check for (hour-)cached visits
ip_addr, usr_agt = request.remote_addr, request.user_agent
visitor = '{}: {}'.format(ip_addr, usr_agt)
rsp = REDIS.get('visits')
visits = pickle.loads(rsp) if rsp else None
# register visit & run DB query if cache empty or new visitor
if not visits or visits[0].visitor != visitor:
store_visit(ip_addr, usr_agt)
visits = list(fetch_visits(10))
REDIS.set('visits', pickle.dumps(visits), ex=HOUR)
return render_template('index.html', visits=visits)
এটি মেমক্যাশের নমুনা অ্যাপের ব্যবহারকে ক্লাউড মেমোরিস্টোরে রূপান্তর করার জন্য main.py এ প্রয়োজনীয় পরিবর্তনগুলি শেষ করে৷ এইচটিএমএল টেমপ্লেট এবং পাইথন 3 এ পোর্টিং সম্পর্কে কি?
পাইথন 3 এ এইচটিএমএল টেমপ্লেট ফাইল এবং পোর্ট আপডেট করবেন?
আশ্চর্য! এখানে কিছু করার নেই কারণ অ্যাপ্লিকেশনটি কোন কোড পরিবর্তন বা সামঞ্জস্যপূর্ণ লাইব্রেরি ছাড়াই পাইথন 2 এবং 3 উভয় ক্ষেত্রে চালানোর জন্য ডিজাইন করা হয়েছিল। আপনি main.py খুঁজে পাবেন। mod13a (2.x) এবং mod13b (3.x) "FINISH" ফোল্ডার জুড়ে অভিন্ন৷ সংস্করণ সংখ্যার (যদি ব্যবহার করা হয়) কোনো পার্থক্য বাদ দিয়ে, requirements.txt এর ক্ষেত্রেও একই কথা। যেহেতু ইউজার ইন্টারফেস অপরিবর্তিত থাকে, তাই templates/index.html এ কোন আপডেট নেই।
Python 3 অ্যাপ ইঞ্জিনে এই অ্যাপটি চালানোর জন্য প্রয়োজনীয় সবকিছু কনফিগারেশনের আগে সম্পন্ন করা হয়েছিল: app.yaml থেকে অপ্রয়োজনীয় নির্দেশাবলী সরানো হয়েছিল এবং appengine_config.py এবং lib ফোল্ডার উভয়ই মুছে ফেলা হয়েছিল কারণ সেগুলি Python 3-এ অব্যবহৃত ছিল।
7. সারাংশ/পরিষ্কার
এই বিভাগটি এই কোডল্যাবটিকে অ্যাপ স্থাপন করে, যাচাই করে এটিকে উদ্দেশ্য করে এবং যে কোনো প্রতিফলিত আউটপুটে কাজ করে। অ্যাপ্লিকেশান যাচাইকরণের পরে, যেকোনো পরিষ্কার-পরিচ্ছন্নতা সঞ্চালন করুন এবং পরবর্তী পদক্ষেপগুলি বিবেচনা করুন৷
প্রয়োগ এবং আবেদন যাচাই
শেষ চেক সবসময় নমুনা অ্যাপ্লিকেশন স্থাপন করা হয়. পাইথন 2 বিকাশকারী: নীচের কমান্ডগুলি দিয়ে lib মুছুন এবং পুনরায় ইনস্টল করুন। (যদি আপনার সিস্টেমে Python 2 এবং 3 উভয়ই ইনস্টল করা থাকে, তাহলে আপনাকে এর পরিবর্তে স্পষ্টভাবে pip2 চালানোর প্রয়োজন হতে পারে।)
rm -rf ./lib pip install -t lib -r requirements.txt
Python 2 এবং 3 উভয় ডেভেলপারেরই এখন তাদের অ্যাপস এর সাথে স্থাপন করা উচিত:
gcloud app deploy
যেহেতু আপনি সম্পূর্ণ ভিন্ন ক্যাশিং পরিষেবার জন্য হুডের নীচে জিনিসগুলিকে নতুন করে তৈরি করেছেন, অ্যাপটি নিজেই আপনার মডিউল 12 অ্যাপের সাথে অভিন্নভাবে কাজ করবে:

এই ধাপ কোডল্যাব সম্পূর্ণ করে। আমরা আপনাকে আপনার আপডেট করা নমুনা অ্যাপটিকে মডিউল 13 ফোল্ডার, mod13a (পাইথন 2) বা mod13b (পাইথন 3) এর সাথে তুলনা করার জন্য আমন্ত্রণ জানাচ্ছি।
পরিষ্কার করুন
সাধারণ
আপনি যদি আপাতত কাজ শেষ করে থাকেন, তাহলে বিলিং এড়াতে আমরা আপনাকে আপনার অ্যাপ ইঞ্জিন অ্যাপটি নিষ্ক্রিয় করার পরামর্শ দিই। তবে আপনি যদি আরও কিছু পরীক্ষা বা পরীক্ষা করতে চান, অ্যাপ ইঞ্জিন প্ল্যাটফর্মের একটি বিনামূল্যের কোটা রয়েছে, এবং যতক্ষণ না আপনি সেই ব্যবহারের স্তরটি অতিক্রম না করেন, আপনাকে চার্জ করা উচিত নয়। এটি গণনার জন্য, তবে প্রাসঙ্গিক অ্যাপ ইঞ্জিন পরিষেবাগুলির জন্যও চার্জ হতে পারে, তাই আরও তথ্যের জন্য এর মূল্য পৃষ্ঠাটি দেখুন৷ যদি এই স্থানান্তরের সাথে অন্যান্য ক্লাউড পরিষেবা জড়িত থাকে, তবে সেগুলি আলাদাভাবে বিল করা হবে৷ উভয় ক্ষেত্রে, প্রযোজ্য হলে, নীচের "এই কোডল্যাবের জন্য নির্দিষ্ট" বিভাগটি দেখুন।
সম্পূর্ণ প্রকাশের জন্য, অ্যাপ ইঞ্জিনের মতো একটি Google ক্লাউড সার্ভারবিহীন গণনা প্ল্যাটফর্মে স্থাপন করা সামান্য বিল্ড এবং স্টোরেজ খরচ বহন করে। ক্লাউড স্টোরেজের মতো ক্লাউড বিল্ডের নিজস্ব ফ্রি কোটা রয়েছে। সেই ছবির সঞ্চয়স্থান সেই কোটার কিছু ব্যবহার করে। যাইহোক, আপনি এমন একটি অঞ্চলে বাস করতে পারেন যেখানে এই ধরনের বিনামূল্যের স্তর নেই, তাই সম্ভাব্য খরচ কমাতে আপনার স্টোরেজ ব্যবহার সম্পর্কে সচেতন থাকুন। নির্দিষ্ট ক্লাউড স্টোরেজ "ফোল্ডার" আপনার পর্যালোচনা করা উচিত:
-
console.cloud.google.com/storage/browser/LOC.artifacts.PROJECT_ID.appspot.com/containers/images -
console.cloud.google.com/storage/browser/staging.PROJECT_ID.appspot.com - উপরের সঞ্চয়স্থানের লিঙ্কগুলি আপনার
PROJECT_IDএবং *LOC*করণের উপর নির্ভর করে, উদাহরণস্বরূপ, "us" যদি আপনার অ্যাপটি USA তে হোস্ট করা হয়৷
অন্যদিকে, আপনি যদি এই অ্যাপ্লিকেশন বা অন্যান্য সম্পর্কিত মাইগ্রেশন কোডল্যাবগুলি চালিয়ে যেতে না চান এবং সবকিছু সম্পূর্ণরূপে মুছে ফেলতে চান, তাহলে আপনার প্রকল্পটি বন্ধ করুন ৷
এই কোডল্যাবের জন্য নির্দিষ্ট
নীচে তালিকাভুক্ত পরিষেবাগুলি এই কোডল্যাবের জন্য অনন্য৷ আরও তথ্যের জন্য প্রতিটি পণ্যের ডকুমেন্টেশন পড়ুন:
- ক্লাউড মেমোরিস্টোরের জন্য দৃষ্টান্ত প্রয়োজন এবং একটি বিনামূল্যে স্তর নেই; ব্যবহারের খরচ সম্পর্কে আরও জানতে, এর মূল্য পৃষ্ঠা দেখুন।
- ক্লাউড সার্ভারলেস ভিপিসি অ্যাক্সেস সংযোগকারীর জন্য দৃষ্টান্ত প্রয়োজন এবং একটি বিনামূল্যে স্তর নেই; ব্যবহারের খরচ সম্পর্কে আরও জানতে, ক্লাউড ভিপিসি মূল্য পৃষ্ঠায় এর বিভাগটি দেখুন।
- ক্লাউড ডেটাস্টোর (ডেটাস্টোর মোডে ক্লাউড ফায়ারস্টোর) একটি বিনামূল্যের স্তর রয়েছে; আরো তথ্যের জন্য এর মূল্য পৃষ্ঠা দেখুন।
এই টিউটোরিয়ালটি চারটি ক্লাউড পণ্যের ব্যবহার জড়িত:
- অ্যাপ ইঞ্জিন
- ক্লাউড ডেটাস্টোর
- ক্লাউড মেমোরিস্টোর
- ক্লাউড ভিপিসি
নীচে এই সংস্থানগুলি প্রকাশ করার এবং বিলিং চার্জ এড়াতে/কমানোর জন্য নির্দেশাবলী রয়েছে৷
শাটডাউন মেমোরিস্টোর ইনস্ট্যান্স এবং ভিপিসি সংযোগকারী
এগুলি একটি বিনামূল্যের স্তরবিহীন পণ্য, তাই আপনি এখনই বিলিং খরচ করছেন৷ আপনি যদি আপনার ক্লাউড প্রজেক্ট বন্ধ না করেন (পরবর্তী বিভাগটি দেখুন), বিলিং বন্ধ করতে আপনাকে অবশ্যই আপনার মেমোরিস্টোর ইনস্ট্যান্সের পাশাপাশি VPC সংযোগকারী উভয়ই মুছে ফেলতে হবে। আপনি যখন এই সংস্থানগুলি তৈরি করেছিলেন তখন একইভাবে, আপনি সেগুলিকে ক্লাউড কনসোল বা কমান্ড-লাইন থেকেও মুক্তি দিতে পারেন।
ক্লাউড কনসোল থেকে
মেমোরিস্টোর ইনস্ট্যান্স মুছতে, মেমোরিস্টোর ড্যাশবোর্ডে ফিরে যান এবং ইনস্ট্যান্স আইডিতে ক্লিক করুন:

একবার সেই উদাহরণের বিশদ পৃষ্ঠায়, "মুছুন" এ ক্লিক করুন এবং নিশ্চিত করুন:
VPC সংযোগকারী মুছে ফেলতে, এর ড্যাশবোর্ডে যান এবং আপনি যে সংযোগকারীটি মুছতে চান তার পাশের চেকবক্সটি নির্বাচন করুন, তারপর "মুছুন" এ ক্লিক করুন এবং নিশ্চিত করুন:

কমান্ড লাইন থেকে
নিম্নলিখিত জোড়া gcloud কমান্ড যথাক্রমে Memorystore ইনস্ট্যান্স এবং VPC সংযোগকারী উভয় মুছে দেয়:
-
gcloud redis instances delete INSTANCE --region REGION -
gcloud compute networks vpc-access connectors delete CONNECTOR --region REGION
আপনি যদি gcloud config set project সাথে আপনার প্রকল্প আইডি সেট না করে থাকেন, তাহলে আপনাকে --project PROJECT_ID প্রদান করতে হতে পারে। যদি আপনার মেমোরিস্টোর ইনস্ট্যান্সকে demo-ms বলা হয় এবং ভিপিসি কানেক্টরকে demo-vpc বলা হয়, এবং উভয়ই us-central1 অঞ্চলে থাকে, তাহলে নিম্নলিখিত জোড়া কমান্ড জারি করুন এবং নিশ্চিত করুন:
$ gcloud redis instances delete demo-ms --region us-central1 You are about to delete instance [demo-ms] in [us-central1]. Any associated data will be lost. Do you want to continue (Y/n)? Delete request issued for: [demo-ms] Waiting for operation [projects/PROJECT/locations/REGION/operations/operation-aaaaa-bbbbb-ccccc-ddddd] to complete...done. Deleted instance [demo-ms]. $ $ gcloud compute networks vpc-access connectors delete demo-vpc --region us-central1 You are about to delete connector [demo-vpc] in [us-central1]. Any associated data will be lost. Do you want to continue (Y/n)? Delete request issued for: [demo-vpc] Waiting for operation [projects/PROJECT/locations/REGION/operations/aaaaa-bbbb-cccc-dddd-eeeee] to complete...done. Deleted connector [demo-vpc].
প্রতিটি অনুরোধ চালানোর জন্য কয়েক মিনিট সময় নেয়। এই পদক্ষেপগুলি ঐচ্ছিক যদি আপনি আগে বর্ণিত হিসাবে আপনার সম্পূর্ণ ক্লাউড প্রকল্প বন্ধ করতে চান, তবে শাট ডাউন প্রক্রিয়া সম্পূর্ণ না হওয়া পর্যন্ত আপনি এখনও বিলিং বহন করবেন৷
পরবর্তী পদক্ষেপ
এই টিউটোরিয়ালের বাইরে, অন্যান্য মাইগ্রেশন মডিউল যা বিবেচনা করার জন্য লিগ্যাসি বান্ডিল পরিষেবাগুলি থেকে দূরে সরে যাওয়ার উপর ফোকাস করে:
- মডিউল 2 : App Engine
ndbথেকে Cloud NDB-তে স্থানান্তর করুন - মডিউল 7-9 : অ্যাপ ইঞ্জিন টাস্ক কিউ পুশ টাস্কগুলি থেকে ক্লাউড টাস্কে স্থানান্তর করুন
- মডিউল 12-13 : অ্যাপ ইঞ্জিন মেমক্যাশ থেকে ক্লাউড মেমোরিস্টোরে স্থানান্তর করুন
- মডিউল 15-16 : অ্যাপ ইঞ্জিন ব্লবস্টোর থেকে ক্লাউড স্টোরেজে স্থানান্তর করুন
- মডিউল 18-19 : অ্যাপ ইঞ্জিন টাস্ক কিউ (টাস্ক টাস্ক) থেকে ক্লাউড পাব/সাব-এ স্থানান্তর করুন
অ্যাপ ইঞ্জিন আর Google ক্লাউডে একমাত্র সার্ভারহীন প্ল্যাটফর্ম নয়। আপনার যদি একটি ছোট অ্যাপ ইঞ্জিন অ্যাপ থাকে বা যেটির কার্যকারিতা সীমিত থাকে এবং এটিকে একটি স্বতন্ত্র মাইক্রোসার্ভিসে পরিণত করতে চান, অথবা আপনি একাধিক পুনঃব্যবহারযোগ্য উপাদানে একটি মনোলিথিক অ্যাপকে বিচ্ছিন্ন করতে চান, তাহলে ক্লাউড ফাংশনে যাওয়ার বিষয়টি বিবেচনা করার জন্য এটি ভাল কারণ। কন্টেইনারাইজেশন যদি আপনার অ্যাপ্লিকেশন ডেভেলপমেন্ট ওয়ার্কফ্লো-এর অংশ হয়ে থাকে, বিশেষ করে যদি এটি একটি CI/CD (একটানা ইন্টিগ্রেশন/কন্টিনিউয়াস ডেলিভারি বা ডিপ্লয়মেন্ট) পাইপলাইন নিয়ে থাকে, তাহলে ক্লাউড রানে মাইগ্রেট করার কথা বিবেচনা করুন। এই পরিস্থিতিতে নিম্নলিখিত মডিউল দ্বারা আচ্ছাদিত করা হয়:
- অ্যাপ ইঞ্জিন থেকে ক্লাউড ফাংশনে স্থানান্তর করুন: মডিউল 11 দেখুন
- অ্যাপ ইঞ্জিন থেকে ক্লাউড রানে স্থানান্তরিত করুন: আপনার অ্যাপটিকে ডকারের সাথে কনটেইনারাইজ করতে মডিউল 4 দেখুন, অথবা কন্টেইনার, ডকার জ্ঞান, বা
Dockerfileছাড়াই এটি করতে মডিউল 5 দেখুন
অন্য সার্ভারহীন প্ল্যাটফর্মে স্যুইচ করা ঐচ্ছিক, এবং আমরা কোনো পরিবর্তন করার আগে আপনার অ্যাপ এবং ব্যবহারের ক্ষেত্রে সেরা বিকল্পগুলি বিবেচনা করার পরামর্শ দিই।
আপনি পরবর্তীতে যে মাইগ্রেশন মডিউলটি বিবেচনা করুন না কেন, সমস্ত সার্ভারলেস মাইগ্রেশন স্টেশন সামগ্রী (কোডল্যাব, ভিডিও, সোর্স কোড [যখন উপলব্ধ]) এর ওপেন সোর্স রেপোতে অ্যাক্সেস করা যেতে পারে। রেপোর README কোন মাইগ্রেশন বিবেচনা করতে হবে এবং মাইগ্রেশন মডিউলের কোন প্রাসঙ্গিক "অর্ডার" তার নির্দেশিকাও প্রদান করে।
8. অতিরিক্ত সম্পদ
এই বা সম্পর্কিত মাইগ্রেশন মডিউল এবং সেইসাথে সম্পর্কিত পণ্যগুলি আরও অন্বেষণকারী বিকাশকারীদের জন্য নীচে তালিকাভুক্ত অতিরিক্ত সংস্থান রয়েছে৷ এর মধ্যে এই বিষয়বস্তুতে প্রতিক্রিয়া প্রদানের স্থান, কোডের লিঙ্ক এবং বিভিন্ন ডকুমেন্টেশন রয়েছে যা আপনার কাজে লাগতে পারে।
কোডল্যাব সমস্যা/প্রতিক্রিয়া
আপনি যদি এই কোডল্যাবের সাথে কোনো সমস্যা খুঁজে পান, অনুগ্রহ করে ফাইল করার আগে প্রথমে আপনার সমস্যাটি অনুসন্ধান করুন। অনুসন্ধান এবং নতুন সমস্যা তৈরি করার লিঙ্ক:
মাইগ্রেশন সম্পদ
মডিউল 12 (স্টার্ট) এবং মডিউল 13 (ফিনিশ) এর জন্য রেপো ফোল্ডারগুলির লিঙ্কগুলি নীচের টেবিলে পাওয়া যাবে। এগুলি সমস্ত অ্যাপ ইঞ্জিন কোডল্যাব মাইগ্রেশনের জন্য রেপো থেকে অ্যাক্সেস করা যেতে পারে যা আপনি একটি জিপ ফাইল ক্লোন বা ডাউনলোড করতে পারেন।
কোডল্যাব | পাইথন 2 | পাইথন 3 |
মডিউল 13 (এই কোডল্যাব) |
অনলাইন রেফারেন্স
নীচে অনলাইন সংস্থান রয়েছে যা এই টিউটোরিয়ালের জন্য প্রাসঙ্গিক হতে পারে:
অ্যাপ ইঞ্জিন
- অ্যাপ ইঞ্জিন ডকুমেন্টেশন
- পাইথন 2 অ্যাপ ইঞ্জিন (স্ট্যান্ডার্ড এনভায়রনমেন্ট) রানটাইম
- পাইথন 2 অ্যাপ ইঞ্জিনে অ্যাপ ইঞ্জিন বিল্ট-ইন লাইব্রেরি ব্যবহার করা
- Python 3 অ্যাপ ইঞ্জিন (স্ট্যান্ডার্ড এনভায়রনমেন্ট) রানটাইম
- পাইথন 2 এবং 3 অ্যাপ ইঞ্জিন (স্ট্যান্ডার্ড এনভায়রনমেন্ট) রানটাইমের মধ্যে পার্থক্য
- পাইথন 2 থেকে 3 অ্যাপ ইঞ্জিন (স্ট্যান্ডার্ড এনভায়রনমেন্ট) মাইগ্রেশন গাইড
- অ্যাপ ইঞ্জিন মূল্য এবং কোটা তথ্য
অ্যাপ ইঞ্জিন এনডিবি এবং ক্লাউড এনডিবি
- অ্যাপ ইঞ্জিন এনডিবি ওভারভিউ
- অ্যাপ ইঞ্জিন এনডিবি ডেটাস্টোর ব্যবহার
- Google Cloud NDB ডক্স
- গুগল ক্লাউড এনডিবি রেপো
- ক্লাউড ডেটাস্টোর মূল্যের তথ্য
অ্যাপ ইঞ্জিন মেমক্যাশ এবং ক্লাউড মেমোরিস্টোর
- অ্যাপ ইঞ্জিন মেমক্যাশে ওভারভিউ
- পাইথন 2 অ্যাপ ইঞ্জিন
memcacheরেফারেন্স - পাইথন 3 অ্যাপ ইঞ্জিন
memcacheরেফারেন্স - অ্যাপ ইঞ্জিন
memcacheক্লাউড মেমোরিস্টোর মাইগ্রেশন গাইড - ক্লাউড মেমোরিস্টোর ডকুমেন্টেশন
- রেডিস ডকুমেন্টেশনের জন্য ক্লাউড মেমোরিস্টোর
- Redis মূল্য তথ্যের জন্য ক্লাউড মেমোরিস্টোর
- ক্লাউড মেমোরিস্টোর সমর্থিত রেডিস সংস্করণ
- ক্লাউড মেমোরিস্টোর হোম পেজ
- ক্লাউড কনসোলে নতুন মেমোরিস্টোর উদাহরণ তৈরি করুন
- পাইথন রেডিস ক্লায়েন্ট হোম পেজ
- পাইথন রেডিস ক্লায়েন্ট লাইব্রেরি ডকুমেন্টেশন
ক্লাউড ভিপিসি
- গুগল ক্লাউড ভিপিসি ডক্স
- গুগল ক্লাউড ভিপিসি হোম পেজ
- ক্লাউড ভিপিসি মূল্যের তথ্য
- ক্লাউড কনসোলে নতুন সার্ভারহীন ভিপিসি অ্যাক্সেস সংযোগকারী তৈরি করুন
অন্যান্য ক্লাউড তথ্য
- গুগল ক্লাউড প্ল্যাটফর্মে পাইথন
- গুগল ক্লাউড পাইথন ক্লায়েন্ট লাইব্রেরি
- Google ক্লাউড "সর্বদা বিনামূল্যে" স্তর
- গুগল ক্লাউড SDK (
gcloudকমান্ড লাইন টুল) - সমস্ত Google ক্লাউড ডকুমেন্টেশন
লাইসেন্স
এই কাজটি ক্রিয়েটিভ কমন্স অ্যাট্রিবিউশন 2.0 জেনেরিক লাইসেন্সের অধীনে লাইসেন্সপ্রাপ্ত।
