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

তুমি কী তৈরি করবে
কমিউনিটি উদ্বৃত্ত ভাগাভাগির জন্য একটি উচ্চ-কার্যক্ষমতাসম্পন্ন "সোয়াইপ-টু-ম্যাচ" ওয়েব অ্যাপ্লিকেশন।
তুমি কি শিখবে
- এক-ক্লিক প্রভিশনিং: এআই ওয়ার্কলোডের জন্য ডিজাইন করা একটি ক্লাউড এসকিউএল এবং ইনস্ট্যান্স কীভাবে সেট আপ করবেন।
- ইন-ডাটাবেস এম্বেডিং: INSERT স্টেটমেন্টের মধ্যে সরাসরি টেক্সট-এমবেডিং-005 ভেক্টর তৈরি করা।
- মাল্টিমোডাল রিজনিং: জেমিনি 3.0 ফ্ল্যাশ ব্যবহার করে আইটেমগুলি "দেখতে" এবং স্বয়ংক্রিয়ভাবে মজাদার, ডেটিং-স্টাইলের জীবনী তৈরি করা।
- শব্দার্থিক আবিষ্কার: ai.if() ফাংশন ব্যবহার করে SQL কোয়েরির ভেতরে লজিক-ভিত্তিক "ভাইব চেক" করা, যা কেবল গণিতের উপর নয়, বরং প্রসঙ্গের উপর ভিত্তি করে ফলাফল ফিল্টার করে।
স্থাপত্য
নেইবার লুপ ঐতিহ্যবাহী অ্যাপ্লিকেশন-স্তরের বাধাগুলিকে এড়িয়ে যায়। প্রক্রিয়াকরণের জন্য ডেটা বের করার পরিবর্তে, আমরা ব্যবহার করি:
- ক্লাউড SQL + ML ইন্টিগ্রেশন: রিয়েল-টাইমে ভেক্টর তৈরি এবং সংরক্ষণ করা।
- গুগল ক্লাউড স্টোরেজ: ছবি সংরক্ষণ করতে
- জেমিনি ৩.০ ফ্ল্যাশ: SQL এর মাধ্যমে সরাসরি ছবি এবং টেক্সট ডেটার উপর সাব-সেকেন্ড রিজনিং সম্পাদন করা।
- ক্লাউড রান: একটি হালকা, একক-ফাইল ফ্লাস্ক ব্যাকএন্ড হোস্ট করার জন্য।
আবশ্যকতা
- একটি ব্রাউজার, যেমন ক্রোম বা ফায়ারফক্স ।
- বিলিং সক্ষম করা একটি Google ক্লাউড প্রকল্প।
- SQL এবং Python এর সাথে প্রাথমিক পরিচিতি।
2. শুরু করার আগে
একটি প্রকল্প তৈরি করুন
- গুগল ক্লাউড কনসোলে , প্রজেক্ট সিলেক্টর পৃষ্ঠায়, একটি গুগল ক্লাউড প্রজেক্ট নির্বাচন করুন বা তৈরি করুন।
- আপনার ক্লাউড প্রোজেক্টের জন্য বিলিং সক্ষম আছে কিনা তা নিশ্চিত করুন। কোনও প্রোজেক্টে বিলিং সক্ষম আছে কিনা তা কীভাবে পরীক্ষা করবেন তা শিখুন ।
- আপনি ক্লাউড শেল ব্যবহার করবেন, যা গুগল ক্লাউডে চলমান একটি কমান্ড-লাইন পরিবেশ। গুগল ক্লাউড কনসোলের শীর্ষে অ্যাক্টিভেট ক্লাউড শেল ক্লিক করুন।

- ক্লাউড শেলের সাথে সংযুক্ত হয়ে গেলে, আপনি নিম্নলিখিত কমান্ড ব্যবহার করে পরীক্ষা করতে পারবেন যে আপনি ইতিমধ্যেই প্রমাণীকরণপ্রাপ্ত এবং প্রকল্পটি আপনার প্রকল্প আইডিতে সেট করা আছে কিনা:
gcloud auth list
- gcloud কমান্ড আপনার প্রকল্প সম্পর্কে জানে কিনা তা নিশ্চিত করতে ক্লাউড শেলে নিম্নলিখিত কমান্ডটি চালান।
gcloud config list project
- যদি আপনার প্রকল্পটি সেট না করা থাকে, তাহলে এটি সেট করতে নিম্নলিখিত কমান্ডটি ব্যবহার করুন:
gcloud config set project <YOUR_PROJECT_ID>
- প্রয়োজনীয় API গুলি সক্ষম করুন: লিঙ্কটি অনুসরণ করুন এবং API গুলি সক্ষম করুন।
অন্যথায়, আপনি এর জন্য gcloud কমান্ড ব্যবহার করতে পারেন। gcloud কমান্ড এবং ব্যবহারের জন্য ডকুমেন্টেশন দেখুন।
সমস্যা সমাধান এবং সমস্যা সমাধান
"ঘোস্ট প্রজেক্ট" সিন্ড্রোম | আপনি |
বিলিং ব্যারিকেড | আপনি প্রকল্পটি সক্ষম করেছেন, কিন্তু বিলিং অ্যাকাউন্টটি ভুলে গেছেন। বিলিং খালি থাকলে ক্লাউড SQL শুরু হবে না। |
এপিআই প্রচার ল্যাগ | তুমি "এনিমেল এপিআই" ক্লিক করেছো, কিন্তু কমান্ড লাইনে এখনও |
৩. ডাটাবেস সেটআপ
এই ল্যাবে আমরা পরীক্ষার তথ্যের জন্য ডাটাবেস হিসেবে PostgreSQL-এর জন্য Cloud SQL ব্যবহার করব।
চলুন একটি ক্লাউড SQL ইনস্ট্যান্স তৈরি করি যেখানে পরীক্ষার ডেটাসেট লোড করা হবে।
- বোতামে ক্লিক করুন অথবা নীচের লিঙ্কটি আপনার ব্রাউজারে কপি করুন যেখানে আপনার Google Cloud Console ব্যবহারকারী লগ ইন করেছেন।
- এই ধাপটি সম্পন্ন হলে রেপোটি আপনার স্থানীয় ক্লাউড শেল এডিটরে ক্লোন করা হবে এবং আপনি প্রজেক্ট ফোল্ডার থেকে নীচের কমান্ডটি চালাতে সক্ষম হবেন (আপনি প্রজেক্ট ডিরেক্টরিতে আছেন তা নিশ্চিত করা গুরুত্বপূর্ণ):
sh run.sh
- এখন UI ব্যবহার করুন (টার্মিনালে লিঙ্কে ক্লিক করে অথবা টার্মিনালে "প্রিভিউ অন ওয়েব" লিঙ্কে ক্লিক করে)।
- শুরু করার জন্য প্রকল্পের আইডি এবং উদাহরণের নামের জন্য আপনার বিবরণ লিখুন।
- লগগুলি স্ক্রোল করার সময় কফি খেয়ে নাও এবং পর্দার আড়ালে এটি কীভাবে এটি করছে তা আপনি এখানে পড়তে পারেন।
সমস্যা সমাধান এবং সমস্যা সমাধান
অঞ্চলের মিল নেই | যদি আপনি |
ক্লাউড শেল টাইমআউট | যদি আপনার কফি ব্রেক ৩০ মিনিটের হয়, তাহলে ক্লাউড শেল স্লিপ মোডে যেতে পারে এবং |
৪. স্কিমা প্রভিশনিং
আপনার ক্লাউড এসকিউএল ইনস্ট্যান্স চালু হয়ে গেলে, এআই এক্সটেনশনগুলি সক্ষম করতে এবং স্কিমাটি সরবরাহ করতে ক্লাউড এসকিউএল স্টুডিও এসকিউএল এডিটরে যান।

আপনার ইনস্ট্যান্স তৈরি শেষ হওয়ার জন্য আপনাকে অপেক্ষা করতে হতে পারে। একবার এটি হয়ে গেলে, ক্লাউড SQL ইনস্ট্যান্স তৈরি করার সময় আপনার তৈরি করা শংসাপত্রগুলি ব্যবহার করে সাইন ইন করুন। PostgreSQL-এ প্রমাণীকরণের জন্য নিম্নলিখিত ডেটা ব্যবহার করুন:
- ব্যবহারকারীর নাম: "
postgres" - ডাটাবেস: "
postgres" - পাসওয়ার্ড: "
cloudsql" (অথবা তৈরির সময় আপনি যা সেট করেছেন)
ক্লাউড এসকিউএল স্টুডিওতে সফলভাবে প্রমাণীকরণ করার পরে, এসকিউএল কমান্ডগুলি এডিটরে প্রবেশ করানো হয়। আপনি শেষ উইন্ডোর ডানদিকে প্লাস ব্যবহার করে একাধিক এডিটর উইন্ডো যুক্ত করতে পারেন।

আপনি এডিটর উইন্ডোতে ক্লাউড SQL-এর জন্য কমান্ড লিখবেন, প্রয়োজনে রান, ফর্ম্যাট এবং ক্লিয়ার বিকল্পগুলি ব্যবহার করে।
এক্সটেনশনগুলি সক্ষম করুন
এই অ্যাপটি তৈরির জন্য, আমরা pgvector এবং google_ml_integration এক্সটেনশনগুলি ব্যবহার করব। pgvector এক্সটেনশন আপনাকে ভেক্টর এম্বেডিংগুলি সংরক্ষণ এবং অনুসন্ধান করতে দেয়। google_ml_integration এক্সটেনশনটি SQL-এ ভবিষ্যদ্বাণী পেতে Vertex AI ভবিষ্যদ্বাণী এন্ডপয়েন্টগুলি অ্যাক্সেস করার জন্য আপনি যে ফাংশনগুলি ব্যবহার করেন তা প্রদান করে। নিম্নলিখিত DDLগুলি চালিয়ে এই এক্সটেনশনগুলি সক্ষম করুন :
CREATE EXTENSION IF NOT EXISTS google_ml_integration CASCADE;
CREATE EXTENSION IF NOT EXISTS vector;
একটি টেবিল তৈরি করুন
ক্লাউড এসকিউএল স্টুডিওতে নিচের DDL স্টেটমেন্টটি ব্যবহার করে আপনি একটি টেবিল তৈরি করতে পারেন:
-- Items Table (The "Profile" you swipe on)
CREATE TABLE items (
item_id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
owner_id UUID,
provider_name TEXT,
provider_phone TEXT,
title TEXT,
bio TEXT,
category TEXT,
image_url TEXT,
item_vector VECTOR(768),
status TEXT DEFAULT 'available',
created_at TIMESTAMP DEFAULT NOW()
);
-- Swipes Table (The Interaction)
CREATE TABLE swipes (
swipe_id SERIAL PRIMARY KEY,
swiper_id UUID,
item_id UUID REFERENCES items(item_id),
direction TEXT CHECK (direction IN ('left', 'right')),
is_match BOOLEAN DEFAULT FALSE,
created_at TIMESTAMP DEFAULT NOW()
);
item_vector কলামটি টেক্সটের ভেক্টর মান সংরক্ষণের অনুমতি দেবে।
অনুমতি দিন
"এমবেডিং" ফাংশনে এক্সিকিউট করার জন্য নিচের স্টেটমেন্টটি রান করুন:
GRANT EXECUTE ON FUNCTION embedding TO postgres;
এমএল ইন্টিগ্রেশন সক্ষম করুন
আপনার ডাটাবেসের মধ্যে সরাসরি মেশিন লার্নিং বৈশিষ্ট্যগুলি ব্যবহার করতে, আপনাকে ML ইন্টিগ্রেশন ফ্ল্যাগ সক্ষম করতে হবে।
আপনি ক্লাউড শেল টার্মিনাল থেকে নিচের কমান্ডটি চালাতে পারেন:
INSTANCE_NAME="<<The name of your Cloud SQL Instance>>"
gcloud sql instances patch $INSTANCE_NAME --tier=db-custom-1-3840
gcloud sql instances patch $INSTANCE_NAME \
--database-flags=cloudsql.enable_google_ml_integration=on
gcloud sql instances patch $INSTANCE_NAME --enable-google-ml-integration
ক্লাউড SQL পরিষেবা অ্যাকাউন্টে Vertex AI ব্যবহারকারীর ভূমিকা প্রদান করুন
গুগল ক্লাউড আইএএম কনসোল থেকে, ক্লাউড এসকিউএল সার্ভিস অ্যাকাউন্টকে (যা দেখতে এরকম: service-<<PROJECT_NUMBER>>@cp-sa-cloud-sql.iam.gserviceaccount.com) "Vertex AI User" ভূমিকায় অ্যাক্সেস দিন। PROJECT_NUMBER-এ আপনার প্রকল্প নম্বর থাকবে।
বিকল্পভাবে আপনি ক্লাউড শেল টার্মিনাল থেকে নীচের কমান্ডটি চালাতে পারেন:
INSTANCE_NAME="<<The name of your Cloud SQL Instance>>"
PROJECT_ID=$(gcloud config get-value project)
SA_EMAIL=$(gcloud sql instances describe $INSTANCE_NAME --format='value(serviceAccountEmailAddress)')
gcloud projects add-iam-policy-binding $PROJECT_ID \
--member="serviceAccount:$SA_EMAIL" \
--role="roles/aiplatform.user"
ক্লাউড SQL-এ জেমিনি 3 ফ্ল্যাশ মডেল নিবন্ধন করুন
ক্লাউড এসকিউএল কোয়েরি এডিটর থেকে নিচের এসকিউএল স্টেটমেন্টটি চালান।
CALL google_ml.create_model(
model_id => 'gemini-3-flash-preview',
model_request_url => 'https://aiplatform.googleapis.com/v1/projects/<<YOUR_PROJECT_ID>>/locations/global/publishers/google/models/gemini-3-flash-preview:generateContent',
model_qualified_name => 'gemini-3-flash-preview',
model_provider => 'google',
model_type => 'generic',
model_auth_type => 'cloudsql_service_agent_iam'
);
--replace <<YOUR_PROJECT_ID>> with your project id.
সমস্যা সমাধান এবং সমস্যা সমাধান
"পাসওয়ার্ড অ্যামনেসিয়া" লুপ | যদি আপনি "One Click" সেটআপ ব্যবহার করে থাকেন এবং আপনার পাসওয়ার্ড মনে না রাখেন, তাহলে কনসোলের Instance বেসিক তথ্য পৃষ্ঠায় যান এবং |
"এক্সটেনশন পাওয়া যায়নি" ত্রুটি | যদি |
আইএএম প্রচারের ব্যবধান | আপনি |
ভেক্টরের মাত্রা অমিল | |
প্রকল্প আইডি টাইপো | |
ভার্টেক্স এআই ইন্টিগ্রেশন অক্ষম করা আছে | |
৫. ইমেজ স্টোরেজ (গুগল ক্লাউড স্টোরেজ)
আমাদের উদ্বৃত্ত জিনিসপত্রের ছবি সংরক্ষণ করার জন্য, আমরা একটি GCS বাকেট ব্যবহার করি। এই ডেমো অ্যাপের উদ্দেশ্যে, আমরা চাই ছবিগুলি সর্বজনীনভাবে অ্যাক্সেসযোগ্য হোক যাতে সেগুলি আমাদের সোয়াইপ কার্ডগুলিতে তাৎক্ষণিকভাবে রেন্ডার হয়।
- একটি বাকেট তৈরি করুন: আপনার GCP প্রকল্পে (যেমন, neighborloop-images) একটি নতুন বাকেট তৈরি করুন , বিশেষ করে আপনার ডাটাবেস এবং অ্যাপ্লিকেশনের মতো একই অঞ্চলে।
- পাবলিক অ্যাক্সেস কনফিগার করুন: * বাকেটের অনুমতি ট্যাবে নেভিগেট করুন।
- allUsers প্রিন্সিপাল যোগ করুন।
- স্টোরেজ অবজেক্ট ভিউয়ারের ভূমিকা (যাতে সবাই ছবি দেখতে পারে) এবং স্টোরেজ অবজেক্ট ক্রিয়েটরের ভূমিকা (ডেমো আপলোডের উদ্দেশ্যে) নির্ধারণ করুন।
বিকল্প (পরিষেবা অ্যাকাউন্ট): যদি আপনি সর্বজনীন অ্যাক্সেস ব্যবহার না করতে চান, তাহলে নিশ্চিত করুন যে আপনার অ্যাপ্লিকেশনের পরিষেবা অ্যাকাউন্টে ক্লাউড SQL এবং বস্তুগুলি নিরাপদে পরিচালনা করার জন্য প্রয়োজনীয় স্টোরেজ ভূমিকাগুলিতে সম্পূর্ণ অ্যাক্সেস দেওয়া হয়েছে।
যদি আপনি কমান্ডটি চালাতে চান এবং পাবলিক অ্যাক্সেস দিতে চান, তাহলে ক্লাউড শেল টার্মিনালে নিচের কমান্ডগুলি চালান:
BUCKET_NAME="<<your-bucket-name>>"
gcloud storage buckets add-iam-policy-binding gs://$BUCKET_NAME \
--member="allUsers" \
--role="roles/storage.objectViewer"
সমস্যা সমাধান এবং সমস্যা সমাধান
অঞ্চল টানা | যদি আপনার ডাটাবেস |
বালতির নামের অনন্যতা | বাকেটের নাম হল একটি বিশ্বব্যাপী নেমস্পেস। যদি আপনি আপনার বাকেটের নাম |
"স্রষ্টা" বনাম "দর্শক" মিশ্রণ | "ক্রিয়েটর" বনাম "ভিউয়ার" মিশ্রণ: যদি আপনি শুধুমাত্র "ভিউয়ার" যোগ করেন, তাহলে আপনার অ্যাপটি ক্র্যাশ করবে যখন কোনও ব্যবহারকারী একটি নতুন আইটেম তালিকাভুক্ত করার চেষ্টা করবে কারণ ফাইলটি লেখার অনুমতি তাদের নেই। এই নির্দিষ্ট ডেমো সেটআপের জন্য আপনার উভয়েরই প্রয়োজন। |
৬. আসুন অ্যাপ্লিকেশনটি তৈরি করি
আপনার প্রকল্পে এই রেপোটি ক্লোন করুন এবং আসুন এটি দেখে নেওয়া যাক।
- এটি ক্লোন করতে, আপনার ক্লাউড শেল টার্মিনাল থেকে (রুট ডিরেক্টরিতে অথবা আপনি যেখান থেকে এই প্রকল্পটি তৈরি করতে চান) নিম্নলিখিত কমান্ডগুলি একের পর এক চালান:
git clone https://github.com/flazer99/neighbor-loop-cloud-sql
cd neighbor-loop-cloud-sql/
এটি প্রকল্পটি তৈরি করবে এবং আপনি ক্লাউড শেল এডিটরে এটি যাচাই করতে পারবেন।

- আপনার জেমিনি এপিআই কী কীভাবে পাবেন
- গুগল এআই স্টুডিওতে যান: aistudio.google.com এ যান।
- সাইন ইন: আপনার গুগল ক্লাউড প্রোজেক্টের জন্য যে গুগল অ্যাকাউন্টটি ব্যবহার করছেন সেই একই অ্যাকাউন্ট ব্যবহার করুন।
- API কী তৈরি করুন:
- বাম দিকের সাইডবারে, "API কী পান" এ ক্লিক করুন।
- "নতুন প্রকল্পে API কী তৈরি করুন" বোতামে ক্লিক করুন।
- কীটি কপি করুন: কীটি তৈরি হয়ে গেলে, কপি আইকনে ক্লিক করুন।
- এখন .env ফাইলে পরিবেশ ভেরিয়েবল সেট করুন।
GEMINI_API_KEY=<<YOUR_GEMINI_API_KEY>>
DATABASE_URL=postgresql+pg8000://postgres:<<YOUR_PASSWORD>>@<<HOST_IP>>:<<PORT>>/postgres
GCS_BUCKET_NAME=<<YOUR_GCS_BUCKET>>
<<YOUR_GEMINI_API_KEY>>, <<YOUR_PASSWORD>, <<HOST_IP>>, <<PORT>> and <<YOUR_GCS_BUCKET>>.
সমস্যা সমাধান এবং সমস্যা সমাধান
একাধিক অ্যাকাউন্টের বিভ্রান্তি | যদি আপনি একাধিক গুগল অ্যাকাউন্টে লগইন করে থাকেন (ব্যক্তিগত বনাম কর্মক্ষেত্র), তাহলে AI স্টুডিও ডিফল্টভাবে ভুল অ্যাকাউন্টে লগইন করতে পারে। উপরের ডানদিকে কোণায় অবতারটি পরীক্ষা করে দেখুন যাতে এটি আপনার GCP প্রজেক্ট অ্যাকাউন্টের সাথে মেলে। |
"ফ্রি টিয়ার" কোটার আঘাত | যদি আপনি ফ্রি অফ চার্জ টিয়ার ব্যবহার করেন, তাহলে রেট লিমিট (RPM - প্রতি মিনিটে অনুরোধ) আছে। যদি আপনি Neighbor Loop-এ খুব দ্রুত "সোয়াইপ" করেন, তাহলে আপনি |
উন্মুক্ত কী সুরক্ষা | যদি আপনি ভুলবশত আপনার |
৭. কোডটি পরীক্ষা করা যাক
আপনার জিনিসপত্রের জন্য "ডেটিং প্রোফাইল"

যখন একজন ব্যবহারকারী কোনও জিনিসের ছবি আপলোড করেন, তখন তাদের দীর্ঘ বিবরণ লিখতে হয় না। আমি আইটেমটি "দেখতে" এবং তাদের জন্য তালিকা লিখতে জেমিনি 3 ফ্ল্যাশ ব্যবহার করি।
ব্যাকএন্ডে, ব্যবহারকারী কেবল একটি শিরোনাম এবং একটি ছবি প্রদান করে। বাকিটা জেমিনি পরিচালনা করে:
prompt = """
You are a witty community manager for NeighborLoop.
Analyze this surplus item and return JSON:
{
"bio": "First-person witty dating-style profile bio for the product, not longer than 2 lines",
"category": "One-word category",
"tags": ["tag1", "tag2"]
}
"""
response = genai_client.models.generate_content(
model="gemini-3-flash-preview",
contents=[types.Part.from_bytes(data=image_bytes, mime_type="image/jpeg"), prompt],
config=types.GenerateContentConfig(response_mime_type="application/json")
)

রিয়েল-টাইম ইন-ডাটাবেস এম্বেডিং

ক্লাউড এসকিউএল-এর সবচেয়ে আকর্ষণীয় বৈশিষ্ট্যগুলির মধ্যে একটি হল এসকিউএল কনটেক্সট ছাড়াই এম্বেডিং তৈরি করার ক্ষমতা। পাইথনে একটি এম্বেডিং মডেল কল করে ভেক্টরটিকে ডিবিতে ফেরত পাঠানোর পরিবর্তে, আমি এম্বেডিং() ফাংশন ব্যবহার করে একটি INSERT স্টেটমেন্টে সবকিছু করি:
INSERT INTO items (owner_id, provider_name, provider_phone, title, bio, category, image_url, status, item_vector)
VALUES (
:owner, :name, :phone, :title, :bio, :cat, :url, 'available',
embedding('text-embedding-005', :title || ' ' || :bio)::vector
)
এটি নিশ্চিত করে যে প্রতিটি আইটেম পোস্ট করার সাথে সাথেই তার অর্থ অনুসারে "অনুসন্ধানযোগ্য"। এবং মনে রাখবেন যে এটি সেই অংশ যা Neighbour Loop অ্যাপের "পণ্য তালিকাভুক্ত করা" বৈশিষ্ট্যটি কভার করে।

জেমিনি ৩.০ এর সাথে উন্নত ভেক্টর অনুসন্ধান এবং স্মার্ট ফিল্টারিং
স্ট্যান্ডার্ড কীওয়ার্ড অনুসন্ধান সীমিত। যদি আপনি "something to fix my chair" অনুসন্ধান করেন, তাহলে একটি ঐতিহ্যবাহী ডাটাবেস শিরোনামে "chear" শব্দটি না থাকলে কিছুই ফেরত নাও দিতে পারে। Neighbor Loop ক্লাউড SQL AI এর উন্নত ভেক্টর অনুসন্ধানের মাধ্যমে এই সমস্যার সমাধান করে।
pgvector এক্সটেনশন এবং ক্লাউড SQL-এর অপ্টিমাইজড স্টোরেজ ব্যবহার করে, আমরা অত্যন্ত দ্রুত সাদৃশ্য অনুসন্ধান করতে পারি। কিন্তু আসল "জাদু" তখনই ঘটে যখন আমরা ভেক্টর প্রক্সিমিটির সাথে LLM-ভিত্তিক লজিককে একত্রিত করি।
SELECT item_id, title, bio, category, image_url,
1 - (item_vector <=> embedding('text-embedding-005', :query)::vector) as score
FROM items
WHERE status = 'available'
AND item_vector IS NOT NULL
ORDER BY score DESC
LIMIT 5
এই কোয়েরিটি একটি বড় স্থাপত্য পরিবর্তনের প্রতিনিধিত্ব করে: আমরা যুক্তিকে ডেটাতে স্থানান্তর করছি। হাজার হাজার ফলাফলকে অ্যাপ্লিকেশন কোডে ফিল্টার করার পরিবর্তে, জেমিনি 3 ফ্ল্যাশ ডাটাবেস ইঞ্জিনের ভিতরে একটি "ভাইব চেক" সম্পাদন করে। এটি ল্যাটেন্সি হ্রাস করে, বহির্গমন খরচ কমায় এবং নিশ্চিত করে যে ফলাফলগুলি কেবল গাণিতিকভাবে একই রকম নয়, বরং প্রাসঙ্গিকভাবে প্রাসঙ্গিক।

"সোয়াইপ টু ম্যাচ" লুপ
ইউআই হলো কার্ডের একটি ক্লাসিক ডেক।
বাম দিকে সোয়াইপ করুন: বাতিল করুন।
ডানদিকে সোয়াইপ করুন: এটি একটি ম্যাচ!

যখন আপনি ডানদিকে সোয়াইপ করেন, তখন ব্যাকএন্ড আমাদের সোয়াইপ টেবিলে ইন্টারঅ্যাকশন রেকর্ড করে এবং আইটেমটিকে মিলে যাওয়া হিসেবে চিহ্নিত করে। ফ্রন্টএন্ড তাৎক্ষণিকভাবে একটি মডেল ট্রিগার করে যেখানে প্রদানকারীর যোগাযোগের তথ্য দেখানো হয় যাতে আপনি পিকআপের ব্যবস্থা করতে পারেন।
৮. আসুন এটি ক্লাউড রানে স্থাপন করি
- ক্লাউড শেল টার্মিনাল থেকে যেখানে প্রকল্পটি ক্লোন করা হয়েছে, নিম্নলিখিত কমান্ডটি চালিয়ে ক্লাউড রানে এটি স্থাপন করুন এবং নিশ্চিত করুন যে আপনি প্রকল্পের রুট ফোল্ডারের ভিতরে আছেন ।
আপনার ক্লাউড শেল টার্মিনালে এটি চালান:
gcloud run deploy neighbor-loop-cloud-sql \
--source . \
--region=us-central1 \
--allow-unauthenticated \
--network=easy-cloudsql-vpc \
--subnet=easy-cloudsql-subnet \
--vpc-egress=private-ranges-only \
--set-env-vars GEMINI_API_KEY=<<YOUR_GEMINI_API_KEY>>,DATABASE_URL=postgresql+pg8000://postgres:<<YOUR_PASSWORD>>@<<PRIVATE_IP_HOST>>:5432/postgres,GCS_BUCKET_NAME=<<YOUR_GCS_BUCKET>>
<<YOUR_GEMINI_API_KEY>>, <<YOUR_PASSWORD>, <<PRIVATE_IP_HOST>>, <<PORT>> and <<YOUR_GCS_BUCKET>> এর জন্য মানগুলি প্রতিস্থাপন করুন
কমান্ডটি শেষ হয়ে গেলে, এটি একটি পরিষেবা URL বের করবে। এটি অনুলিপি করুন।
এখন পরিষেবা URL (আপনি আগে কপি করা ক্লাউড রান এন্ডপয়েন্ট) ব্যবহার করুন এবং অ্যাপটি পরীক্ষা করুন। সেই পুরানো পাওয়ার টুলের একটি ছবি আপলোড করুন, এবং বাকিটা জেমিনিকে করতে দিন!
সমস্যা সমাধান এবং সমস্যা সমাধান
"সংশোধন ব্যর্থ" লুপ | যদি ডিপ্লয়মেন্ট শেষ হয় কিন্তু URL |
৯. উচ্চ স্তরের সমস্যা সমাধান

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