1. ভূমিকা
একটি ক্লাউড স্প্যানার ব্যাকএন্ডের সাথে Magento সংহত করা
Magento হল একটি ব্যাপক জনপ্রিয় PHP ভিত্তিক ওপেন সোর্স ইকমার্স প্ল্যাটফর্ম যা MySQL-এ ডেটা সঞ্চয় করে।
এই কোডল্যাবটি ক্যাটালগ মডিউলের জন্য MySQL এর পরিবর্তে ক্লাউড স্প্যানার ব্যবহার করার ধারণার একটি প্রমাণ। স্প্যানারের সাথে Magento, বা অন্যান্য PHP অ্যাপ্লিকেশনগুলিকে একীভূত করতে, পরীক্ষা করতে এবং স্থাপন করতে আগ্রহী যে কারো জন্য এটি কার্যকর।
স্প্যানার হল Google ক্লাউডের সম্পূর্ণরূপে পরিচালিত, এন্টারপ্রাইজ-গ্রেড, বিতরণ করা এবং সামঞ্জস্যপূর্ণ ডাটাবেস যা রিলেশনাল ডাটাবেস মডেলের সুবিধাগুলিকে সম্পর্কহীন অনুভূমিক স্কেলেবিলিটির সাথে একত্রিত করে। এটি গ্লোবাল অনলাইন লেনদেন প্রক্রিয়াকরণ স্থাপনা, SQL শব্দার্থবিদ্যা, অত্যন্ত উপলব্ধ অনুভূমিক স্কেলিং এবং লেনদেনের সামঞ্জস্যকে সমর্থন করার জন্য ডিজাইন করা হয়েছে। স্প্যানার বিপুল পরিমাণ ডেটা পরিচালনা করতে সক্ষম। এটির ব্যবহার বড় আকারের অ্যাপ্লিকেশনের মধ্যে সীমাবদ্ধ নয় তবে এটি RDBMS-এর প্রয়োজনীয় সমস্ত কাজের চাপের জন্য একটি একক ডাটাবেস ইঞ্জিনের প্রমিতকরণের অনুমতি দেয়। স্প্যানার পরিকল্পিত রক্ষণাবেক্ষণ বা অঞ্চলের ব্যর্থতার জন্য শূন্য-ডাউনটাইম প্রদান করে, যার প্রাপ্যতা SLA 99.999% । এটি উচ্চ প্রাপ্যতা এবং মাপযোগ্যতা প্রদান করে আধুনিক অ্যাপ্লিকেশনগুলিকে সমর্থন করে।
আপনি কি শিখবেন
- কিভাবে GCE এ Magento ইনস্টল করবেন
- কিভাবে স্প্যানার এমুলেটর সেট আপ করবেন
- HarbourBridge ব্যবহার করে একটি বিদ্যমান MySQL স্কিমা কিভাবে স্প্যানারে স্থানান্তর করা যায়
- স্প্যানারের সাথে কাজ করার জন্য ডাটাবেস ব্যাকএন্ডের জন্য মাইএসকিউএল ব্যবহার করে ম্যাজেন্টোর মতো পিএইচপি অ্যাপ্লিকেশনগুলিকে সংহত করতে আপনাকে কী পরিবর্তন করতে হবে
আপনি কি নির্মাণ করবেন
এই কোডল্যাবটি ম্যাজেন্টোকে স্প্যানারের সাথে একীভূত করার উপর দৃষ্টি নিবদ্ধ করে। কোড ব্লক এবং সেটআপ নির্দেশাবলী অনুলিপি এবং পেস্ট করার জন্য আপনাকে প্রদান করা হয়েছে, কিন্তু বিস্তারিতভাবে আলোচনা করা হয়নি।
এই কোডল্যাবে, আপনি স্প্যানারের সাথে Magento একীভূত করা শুরু করতে যাচ্ছেন। আপনি করবেন:
- Magento ইনস্টল করে একটি GCE দৃষ্টান্ত সেট আপ করুন
- স্প্যানার এমুলেটর ইনস্টল করুন
- MySQL থেকে স্প্যানারে ডেটা স্থানান্তরের জন্য HarbourBridge টুল ইনস্টল করুন
- স্প্যানার থেকে পণ্য ক্যাটালগ লোড করতে Magento সংগ্রহগুলি পরিবর্তন করুন৷
আপনি কি প্রয়োজন হবে
- একটি Google ক্লাউড প্রকল্প যা একটি বিলিং অ্যাকাউন্টের সাথে সংযুক্ত৷
- পিএইচপি, লিনাক্স এবং অ্যাপাচি কনফিগারেশনের জ্ঞান একটি প্লাস।
- Magento অভিজ্ঞতা সহায়ক হবে, কিন্তু প্রয়োজন নেই.
2. GCE দৃষ্টান্ত প্রস্তুত করা হচ্ছে
GCE উদাহরণ তৈরি করুন
এখানে উল্লিখিত পদক্ষেপগুলি অনুসরণ করে Google ক্লাউড প্ল্যাটফর্মে একটি কম্পিউট ইঞ্জিন উদাহরণ তৈরি করুন।
GCE ইন্সট্যান্স তৈরি করার সময়, ইন্সট্যান্স টাইপ পরিবর্তন করুন e2-standard-2 এবং বুট ডিস্কের আকার 20GB করুন। আপনি ডিফল্ট হিসাবে সবকিছু ছেড়ে দিতে পারেন, তবে "HTTP ট্র্যাফিকের অনুমতি দিন" এবং "HTTPs ট্র্যাফিকের অনুমতি দিন" নির্বাচন করতে ভুলবেন না, যেহেতু আমরা Magento-এর ওয়েব ইন্টারফেসের সুবিধা দেব।
এর ফলে ই2-স্ট্যান্ডার্ড-2- এর একটি মেশিন-টাইপ হয় যা শেয়ার্ড কোর ইন্সট্যান্স নয় এবং এতে 2vCPU, 8GB RAM এবং 20GB ডিস্ক স্পেস রয়েছে।
অপারেটিং সিস্টেম হল ডেবিয়ান 10। ইনস্ট্যান্স তৈরি হতে এক বা দুই মিনিট সময় লাগতে পারে।
এটি তৈরি হয়ে গেলে, এগিয়ে যান এবং ক্লাউড কনসোলে 'SSH' ক্লিক করে লগ ইন করুন:
এটি একটি নতুন ব্রাউজার উইন্ডো খুলবে এবং আপনাকে একটি টার্মিনালে রাখবে।
পূর্বশর্ত সফ্টওয়্যার ইনস্টল করুন
আমরা Magento চালানোর আগে Magento-এর কিছু পূর্বশর্ত সফ্টওয়্যার ইনস্টল করতে হবে। বিশেষ করে, আপনি PHP, ইলাস্টিক, মাইএসকিউএল এবং অ্যাপাচি ইন্সটল করবেন নিচের বিস্তারিতভাবে।
- কিছু প্রয়োজনীয় প্যাকেজ ইনস্টল করুন।
sudo apt update sudo apt -y install lsb-release apt-transport-https ca-certificates wget git screen composer google-cloud-sdk-spanner-emulator gcc
- Magento এর জন্য প্রয়োজনীয় PHP মডিউল ইনস্টল করুন।
sudo wget -O /etc/apt/trusted.gpg.d/php.gpg https://packages.sury.org/php/apt.gpg echo "deb https://packages.sury.org/php/ $(lsb_release -sc) main" | sudo tee /etc/apt/sources.list.d/php.list sudo apt update sudo apt -y install php7.4-fpm php7.4-common php7.4-mysql php7.4-gmp php7.4-curl php7.4-intl php7.4-mbstring php7.4-xmlrpc php7.4-gd php7.4-xml php7.4-cli php7.4-zip php7.4-bcmath php7.4-soap php7.4-grpc
- ইলাস্টিকসার্চ ইনস্টল করুন এবং পরিষেবা শুরু করুন
wget -qO - https://artifacts.elastic.co/GPG-KEY-elasticsearch | sudo apt-key add - echo "deb https://artifacts.elastic.co/packages/7.x/apt stable main" | sudo tee /etc/apt/sources.list.d/elastic-7.x.list sudo apt update && sudo apt -y install elasticsearch echo "-Xms1g -Xmx1g" | sudo tee /etc/elasticsearch/jvm.options.d/jvm.options sudo systemctl start elasticsearch.service
- মাইএসকিউএল ইনস্টল করুন
আপনি ডিফল্ট Magento স্কিমা ইনস্টল করার জন্য MySQL ইনস্টল করছেন। পরে, আপনি HarbourBridge ব্যবহার করে স্কিমাটি স্প্যানারে স্থানান্তর করবেন।
wget https://dev.mysql.com/get/mysql-apt-config_0.8.13-1_all.deb sudo dpkg -i mysql-apt-config*
উপরের dpkg কমান্ডটি MySQL 5.7 সার্ভার ইনস্টল করার জন্য একটি ইন্টারেক্টিভ প্রম্পট আনবে। বিকল্পগুলি নির্বাচন করুন:
- মাইএসকিউএল সার্ভার এবং ক্লাস্টার
- mysql-5.7
- ঠিক আছে
sudo apt update && sudo apt -y install mysql-server # You will be prompted to enter a root password
- Apache2 ইনস্টল করুন
sudo apt -y install apache2 sudo a2enmod proxy_fcgi rewrite
Magento2 ইনস্টল এবং কনফিগার করুন
Magento কমার্স ক্লাউড প্রকল্পে Magento সাইট এবং স্টোরে সম্পূর্ণরূপে অ্যাক্সেস করার জন্য একটি ডাটাবেস স্কিমা এবং পরিষেবা অন্তর্ভুক্ত রয়েছে।
এটি ইনস্টল এবং চালানোর সবচেয়ে সহজ উপায় হল কম্পোজার ব্যবহার করে ইনস্টল করার জন্য Magento নির্দেশাবলী অনুসরণ করা:
- কম্পোজার ব্যবহার করে Magento সংস্করণ 2.4.2 ইনস্টল করুন। Magento 2 এর জন্য কম্পোজার 1.x সংস্করণ প্রয়োজন। আপনি এই সংস্করণের জন্য সমর্থন সম্পর্কে কিছু সতর্কতা অবমূল্যায়ন দেখতে দেখতে পারেন৷
composer create-project --repository-url=https://repo.magento.com/ magento/project-community-edition=2.4.2 magento2
- ফোল্ডার অনুমতি সেট করুন
cd magento2 find var generated vendor pub/static pub/media app/etc -type f -exec chmod g+w {} + find var generated vendor pub/static pub/media app/etc -type d -exec chmod g+ws {} +
- নিচের বিষয়বস্তু সহ /etc/apache2/sites-available/magento.conf তৈরি করে Magento ভার্চুয়াল হোস্ট কনফিগার করুন।
sudo nano /etc/apache2/sites-available/magento.conf <VirtualHost *:80> ServerAdmin admin@local-magento.com DocumentRoot /var/www/html/magento/ <Directory /var/www/html/magento/> Options Indexes FollowSymlinks MultiViews AllowOverride All Order allow,deny allow from all </Directory> <FilesMatch \.php$> SetHandler "proxy:unix:/run/php/php7.4-fpm.sock|fcgi://localhost" </FilesMatch> ErrorLog ${APACHE_LOG_DIR}/error.log CustomLog ${APACHE_LOG_DIR}/access.log combined </VirtualHost>
- সিমলিংক তৈরি করুন এবং apache2 পুনরায় চালু করুন।
cd ~/magento2 sudo ln -s $(pwd) /var/www/html/magento sudo ln -s /etc/apache2/sites-available/magento.conf /etc/apache2/sites-enabled/magento.conf sudo rm /etc/apache2/sites-enabled/000-default.conf sudo systemctl restart apache2
- MySQL-এ Magento-এর জন্য ডাটাবেস এবং ব্যবহারকারী তৈরি করুন
export ROOT_PASSWORD="<root password from installation>" export GCE_INSTANCE_IP="<GCE instance IP>" mysql -uroot -p$ROOT_PASSWORD -e "create database magento" bin/magento sampledata:deploy bin/magento setup:install --base-url=http://$GCE_INSTANCE_IP/ --db-host=localhost \ --db-name=magento --db-user=root --db-password=$ROOT_PASSWORD --admin-firstname=admin \ --admin-lastname=demo --admin-email=good@example.com --admin-user=admin \ --admin-password=magento123 --language=en_US --currency=USD --timezone=America/Chicago \ --use-rewrites=1 sudo chown -R :www-data ~/magento2/.
- আপনার স্থানীয় ওয়ার্কস্পেস যাচাই করুন স্থানীয় পরিবেশ সার্ভার হোস্ট করছে তা যাচাই করতে, আপনি ইনস্টল কমান্ডে পাস করা বেস ইউআরএল ব্যবহার করে স্টোরটি অ্যাক্সেস করুন। এই উদাহরণের জন্য, আপনি নিম্নলিখিত URL ফর্ম্যাটগুলি ব্যবহার করে স্থানীয় Magento স্টোর অ্যাক্সেস করতে পারেন:
- http://<GCEexternalIP>/
- http://<GCEexternalIP>/<adminuri>
GCEexternalIP ক্লাউড কনসোলে পাওয়া যাবে:
অ্যাডমিন প্যানেলের জন্য URI পরিবর্তন করতে, এটি সনাক্ত করতে এই কমান্ডটি ব্যবহার করুন:
php bin/magento info:adminuri
- সম্পূর্ণ পৃষ্ঠার ক্যাশে নিষ্ক্রিয় করুন উন্নয়নের উদ্দেশ্যে, আপনি Magento2 এর সম্পূর্ণ পৃষ্ঠা ক্যাশে নিষ্ক্রিয় করতে পারেন৷ এটি আপনাকে স্প্যানারে ডেটা পরিবর্তন করতে এবং ক্যাশে করা মান দ্বারা প্রভাবিত না হয়ে এটিকে ওয়েবসাইটে প্রতিফলিত করার অনুমতি দেবে।
php bin/magento cache:disable full_page
স্প্যানার সেটআপ করুন
স্প্যানার এমুলেটর ইনস্টল করুন
ক্লাউড SDK একটি স্থানীয়, ইন-মেমরি এমুলেটর প্রদান করে, যা আপনি একটি GCP প্রকল্প বা একটি বিলিং অ্যাকাউন্ট তৈরি না করে বিনামূল্যে আপনার অ্যাপ্লিকেশনগুলি বিকাশ এবং পরীক্ষা করতে ব্যবহার করতে পারেন৷ যেহেতু এমুলেটর শুধুমাত্র মেমরিতে ডেটা সঞ্চয় করে, রিস্টার্ট করার সময় ডেটা, স্কিমা এবং কনফিগারেশন সহ সমস্ত স্টেট নষ্ট হয়ে যায়। এমুলেটরটি স্প্যানার প্রোডাকশন সার্ভিসের মতো একই API অফার করে এবং এটি স্থানীয় উন্নয়ন এবং পরীক্ষার জন্য, উৎপাদন স্থাপনার জন্য নয়।
এমুলেটর ইনস্টলেশন, ব্যবহার এবং স্থাপনার জন্য আরও উল্লেখ করতে অনুগ্রহ করে নীচের লিঙ্কটি ব্যবহার করুন:
# Set up a new configuration to use the emulator gcloud config configurations create emulator gcloud config set auth/disable_credentials true gcloud config set project magento gcloud config set api_endpoint_overrides/spanner http://localhost:9020/ # Start emulator in a screen session screen -S magento gcloud emulators spanner start & gcloud spanner instances create magento-instance --config=emulator-config --description='Magento Instance' --nodes=1 # Detach from screen ctrl+a+d export SPANNER_EMULATOR_HOST=localhost:9010
Magento MySQL স্প্যানারে স্থানান্তর করুন
আমরা স্প্যানারকে সংহত করার আগে, আমরা MySQL ডাটাবেসকে রূপান্তর করতে HarbourBridge নামক একটি টুল ব্যবহার করব যা উপরে আমাদের Magento ইনস্টলেশনের অংশ হিসাবে তৈরি করা হয়েছিল স্প্যানারে।
এর মূলে, HarbourBridge একটি বিদ্যমান MySQL বা PostgreSQL ডাটাবেসের বিষয়বস্তু স্প্যানারে লোড করার জন্য একটি স্বয়ংক্রিয় কর্মপ্রবাহ প্রদান করে। এটির জন্য শূন্য কনফিগারেশন প্রয়োজন - লেখার জন্য কোনও ম্যানিফেস্ট বা ডেটা ম্যাপ নেই৷ পরিবর্তে, এটি উৎস ডাটাবেস আমদানি করে, একটি স্প্যানার স্কিমা তৈরি করে, উৎস ডাটাবেস থেকে ডেটা দিয়ে একটি নতুন স্প্যানার ডাটাবেস তৈরি করে এবং একটি বিস্তারিত মূল্যায়ন প্রতিবেদন তৈরি করে। হারবারব্রিজ মূল্যায়নের উদ্দেশ্যে কয়েক গিগাবাইট পর্যন্ত ডাটাবেস লোড করার উদ্দেশ্যে তৈরি করা হয়েছে, সম্পূর্ণ-স্কেল মাইগ্রেশন নয়।
HarbourBridge বুটস্ট্র্যাপ প্রাথমিক পর্যায়ে স্প্যানারে স্থানান্তরিত করে একটি বিদ্যমান MySQL বা PostgreSQL সোর্স ডাটাবেস ব্যবহার করে দ্রুত আপনাকে স্প্যানারে চালু করতে এবং চালু করতে। এটি স্প্যানারের জন্য সামগ্রিক মাইগ্রেশন-ফিটনেস স্কোর, টাইপ ম্যাপিংগুলির একটি টেবিল-বাই-টেবিল বিশ্লেষণ এবং সোর্স ডাটাবেসে ব্যবহৃত বৈশিষ্ট্যগুলির একটি তালিকা সহ একটি মূল্যায়ন প্রতিবেদন তৈরি করে যা স্প্যানার দ্বারা সমর্থিত নয়।
হারবারব্রিজ স্প্যানার এমুলেটরের সাথে বা সরাসরি একটি স্প্যানার উদাহরণের সাথে ব্যবহার করা যেতে পারে।
HarbourBridge README একটি স্প্যানার উদাহরণ সহ টুলটি ব্যবহার করার জন্য একটি ধাপে ধাপে দ্রুত-সূচনা নির্দেশিকা রয়েছে৷
হারবারব্রিজ ইনস্টল করুন
আপনার মেশিনে টুলটি ডাউনলোড করুন এবং এটি ইনস্টল করুন। এটি কাজ করার জন্য গোলং ইনস্টল করা প্রয়োজন। গো পূর্বে সেট আপ না করে একটি নতুন উদাহরণে সমস্ত প্রয়োজনীয় মডিউল ইনস্টল করতে কিছু সময় লাগতে পারে।
# Install golang cd ~ wget https://golang.org/dl/go1.17.2.linux-amd64.tar.gz sudo tar -zxvf go1.17.2.linux-amd64.tar.gz -C /usr/local rm go1.17.2.linux-amd64.tar.gz echo 'export GOROOT=/usr/local/go' | sudo tee -a /etc/profile echo 'export PATH=/usr/local/go/bin:$HOME/go/bin:$PATH' | sudo tee -a /etc/profile source /etc/profile # Install harbourbridge git clone https://github.com/cloudspannerecosystem/harbourbridge cd harbourbridge go run github.com/cloudspannerecosystem/harbourbridge help
ডেটা মাইগ্রেট করুন
Magento ডাটাবেসকে স্প্যানারে স্থানান্তর করতে নিম্নলিখিত কমান্ডটি ব্যবহার করুন:
mysqldump --user='root' --password=$ROOT_PASSWORD magento | go run github.com/cloudspannerecosystem/harbourbridge -driver=mysqldump -dbname=magento
স্প্যানার-ক্লাই টুল সেট আপ করুন
go install github.com/cloudspannerecosystem/spanner-cli@latest
3. Spanner এর সাথে কাজ করতে Magento রূপান্তর করুন
এখন যেহেতু আমাদের কাছে Magento চলছে, এবং Magento ডাটাবেস স্থানান্তরিত হওয়ার সাথে তৈরি স্প্যানার উদাহরণ, আমরা স্প্যানারে সঞ্চিত ডেটার সাথে কাজ করার জন্য Magento সংশোধন করার কাজ করব।
Magento ইনস্টলেশন রূপান্তর করতে নিম্নলিখিত পদক্ষেপগুলি সম্পাদন করা হবে:
- ম্যাজেন্টো-স্প্যানার-পোর্ট প্রকল্প ক্লোন করুন
- স্প্যানারে সংযোগ পরিবর্তন করুন
- যাচাই করুন যে ক্যাটালগের বিশদগুলি স্প্যানার থেকে পপুলেট করা হয়েছে৷
Magento প্রকল্পের কাঁটা ক্লোন করুন
Magento-এর জন্য PHP অ্যাপ্লিকেশন কোড ক্লোন করুন যাতে নীচে উল্লিখিত Git url থেকে ক্যাটালগ, উইশলিস্ট এবং কার্ট মডিউলগুলির পরিবর্তনগুলি রয়েছে৷
cd ~ git clone https://github.com/searceinc/magento-spanner-port
আপনার হোম ডিরেক্টরিটি এইরকম দেখতে হবে:
$ ls go harbourbridge magento-spanner-port magento2
যেখানে magento2 হল কোডবেস আমরা magento-spanner-port থেকে কোড ব্যবহার করে পরিবর্তন করব।
স্প্যানারে সংযোগ পরিবর্তন করুন
কোড পরিবর্তনগুলি UI-তে প্রতিফলিত হয় কিনা তা পরীক্ষা করতে, আমরা নীচের পদক্ষেপগুলি অনুসরণ করতে পারি -
নমুনা বাস্তবায়নের জন্য Github লিঙ্ক https://github.com/searceinc/magento-spanner-port দেখুন।
- google/cloud-spanner PHP ক্লায়েন্ট লাইব্রেরি প্রয়োজন
- স্প্যানারে সংযোগ তৈরি করার জন্য স্প্যানার অ্যাডাপ্টার যোগ করুন।
- স্প্যানার ইনস্ট্যান্স এবং সার্ভারের তথ্য কনফিগার করুন।
- স্প্যানার সংযোগ বাস্তবায়ন করতে অ্যাডাপ্টারে স্প্যানার ইন্টারফেস এবং স্প্যানার যোগ করুন।
প্রথমে, আমাদের কম্পোজার ব্যবহার করে ক্লাউড-স্প্যানার পিএইচপি লাইব্রেরি ইনস্টল করতে হবে। Magento2 ডিরেক্টরিতে, এই কমান্ডটি চালান:
cd ~/magento2 composer require google/cloud-spanner
তারপরে আমরা ম্যাজেন্টো-স্প্যানার-পোর্ট থেকে স্প্যানার অ্যাডাপ্টার ফাইলগুলি আমাদের ম্যাজেন্টো 2 কোডবেসে যুক্ত করি:
~/magento2$ cp -r ../magento-spanner-port/lib/internal/Magento/Framework/DB/Adapter/Spanner vendor/magento/framework/DB/Adapter/. ~/magento2$ ls -l vendor/magento/framework/DB/Adapter/Spanner total 16 -rw-r--r-- 1 derekdowney derekdowney 10378 Nov 9 21:03 Spanner.php -rw-r--r-- 1 derekdowney derekdowney 2948 Nov 9 21:03 SpannerInterface.php
এখন, $project_id, $instance, এবং $database- এর জন্য স্প্যানার সংযোগ তথ্য ইনপুট করতে DB/Adapter/Spanner/Spanner.php ফাইলটি পরিবর্তন করুন:
$ nano vendor/magento/framework/DB/Adapter/Spanner/Spanner.php class Spanner implements SpannerInterface { /** * Google cloud project id * @var string */ private $project_id = 'magento'; /** * Google cloud instance name * @var string */ private $instance = 'magento-instance'; /** * Cloud Spanner database name * @var string */ private $database = 'magento'; /** * Is Cloud Spanner emulator * @var bool */ private $is_emulator = true; ... /** * Set database connection adapter * * @param \Magento\Framework\DB\Adapter\AdapterInterface $conn * @return $this * @throws \Magento\Framework\Exception\LocalizedException */ public function setConnection(\Magento\Framework\DB\Adapter\AdapterInterface $conn) { $this->_conn = $conn; $this->_select = $this->_conn->select(); $this->_isOrdersRendered = false; return $this; } /** * Set Cloud Spanner database connection adapter * * @return void * @throws \Magento\Framework\Exception\LocalizedException */ private function setSpannerConnection() { $this->_spanner_conn = new Spanner(); }
স্প্যানার অ্যাডাপ্টারের মধ্যে নতুন তৈরি সংযোগ ফাংশন ব্যবহার করে এখন স্প্যানারের সাথে সংযোগ করতে Magento-এর মধ্যে AbstractDB ক্লাসটি পরিবর্তন করুন। ফাইলে সাদা লাইনের পরে সবুজ লাইন যোগ করুন। বিক্রেতা/magento/framework/Data/Collection/AbstractDb.php দেখুন
$ nano vendor/magento/framework/Data/Collection/AbstractDb.php ... use Psr\Log\LoggerInterface as Logger; use Magento\Framework\DB\Adapter\Spanner\Spanner; ... protected $_conn; /** * Cloud Spanner connection * * @var \Magento\Framework\DB\Adapter\Spanner\SpannerAdapterInterface */ protected $_spanner_conn; ... if ($connection !== null) { $this->setConnection($connection); } $this->setSpannerConnection(); $this->_logger = $logger; ... /** * Retrieve connection object * * @return AdapterInterface */ public function getConnection() { return $this->_conn; } /** * Retrieve connection object * * @return SpannerAdapterInterface */ public function getSpannerConnection() { return $this->_spanner_conn; } ...
সংযোগ স্থাপন হয়ে গেলে আমাদের MySQL অ্যাডাপ্টার থেকে স্প্যানার অ্যাডাপ্টারে ডেটা আনার পদ্ধতি পরিবর্তন করতে হবে। Spanner এর সাথে সংযোগ করতে এবং Spanner থেকে ডেটা আনতে AbstractCollection-এ _loadAttributes পদ্ধতি পরিবর্তন করুন। সবুজ রেখার সাথে লাল রেখাটি প্রতিস্থাপন করুন।
/app/code/Magento/Eav/Model/Entity/Collection/AbstractCollection.php দেখুন
$ nano ./vendor/magento/module-eav/Model/Entity/Collection/AbstractCollection.php use Magento\Framework\Exception\LocalizedException; use Google\Cloud\Spanner\SpannerClient; ... try { if (is_array($selects)) { $select = implode(' UNION ALL ', $selects); } else { $select = $selects; } $values = $this->getConnection()->fetchAll($select); $con = $this->getSpannerConnection(); /** * Cloud Spanner follows strict type so cast the columns in common type */ $select = $con->addCast($select, "`t_d`.`value`", 'string'); $select = $con->addCast($select, "`t_s`.`value`", 'string'); $select = $con->addCast($select, "IF(t_s.value_id IS NULL, t_d.value, t_s.value)", 'string'); $values = $con->fetchAll($select); ...
যাচাই করুন যে ক্যাটালগের বিশদগুলি স্প্যানার থেকে পপুলেট করা হয়েছে৷
তাই তো! এখন, আপনি ব্রাউজারে আপনার Magento ইনস্টলে যেতে পারেন এবং ডেটা লোড হচ্ছে কিনা তা পরীক্ষা করতে পারেন।
উদাহরণস্বরূপ, এইগুলি ঘড়ির জন্য ক্যাটালগ এন্ট্রি:
পণ্যগুলির একটির জন্য টার্মিনালের মাধ্যমে স্প্যানার ডেটা পরিবর্তন করুন এবং স্প্যানারে পরিবর্তন নিশ্চিত করতে টার্মিনালের মাধ্যমে ডেটা অনুসন্ধান করুন৷
$ spanner-cli -pmagento -i magento-instance -d magento spanner> SELECT * FROM catalog_product_entity_varchar WHERE value LIKE "Aim Analog%"; +----------+--------------+----------+-----------+--------------------+ | value_id | attribute_id | store_id | entity_id | value | +----------+--------------+----------+-----------+--------------------+ | 390 | 73 | 0 | 36 | Aim Analog Watch | +----------+--------------+----------+-----------+--------------------+ 1 rows in set (80.711542ms) spanner> UPDATE catalog_product_entity_varchar SET value = "Aim Analog Spanner" WHERE value_id=390; Query OK, 1 rows affected (0.19 sec) spanner> SELECT * FROM catalog_product_entity_varchar WHERE value_id=390; +----------+--------------+----------+-----------+--------------------+ | value_id | attribute_id | store_id | entity_id | value | +----------+--------------+----------+-----------+--------------------+ | 390 | 73 | 0 | 36 | Aim Analog Spanner | +----------+--------------+----------+-----------+--------------------+ 1 rows in set (80.711542ms)
এখন, স্প্যানার টার্মিনালের মাধ্যমে আপডেট হওয়া হিসাবে ঘড়িটির নাম এখন "Aim Analog Spanner" এ পরিবর্তিত হয়েছে তা নিশ্চিত করতে স্ক্রীনটি পুনরায় লোড করুন৷
4. অভিনন্দন
অভিনন্দন, আপনি Spanner-এর সাথে কাজ করার জন্য Magento-এর ক্যাটালগ মডিউল সফলভাবে সংযুক্ত করেছেন! এটি একটি সম্পূর্ণ ইন্টিগ্রেশন নয়, তবে আপনি এখন ম্যাজেন্টোর মতো একটি পিএইচপি অ্যাপ্লিকেশন পেতে উপাদানগুলি জানেন যা একটি স্প্যানার উদাহরণের সাথে সংযুক্ত।
পরিষ্কার করা হচ্ছে
POC সেটআপ এবং বৈধতা সম্পন্ন হলে, আপনি প্রক্রিয়া চলাকালীন তৈরি করা GCP সংস্থানগুলি মুছতে চাইতে পারেন। এতে কম্পিউট ইঞ্জিন ভার্চুয়াল মেশিন, সেইসাথে একটি ক্লাউড স্প্যানার উদাহরণ অন্তর্ভুক্ত থাকবে যদি আপনি এমুলেটরের পরিবর্তে একটি ব্যবহার করার সিদ্ধান্ত নেন।
এরপর কি?
এটি একটি স্প্যানার POC এর জন্য একটি প্রোটোটাইপ মডেল।
আপনি যদি স্প্যানার এবং এই কোডল্যাবে আমরা যে প্রযুক্তিগুলি ব্যবহার করেছি তার সাথে কাজ করার বিষয়ে আরও জানতে চান, এখানে কিছু অতিরিক্ত সংস্থান রয়েছে: