MinIO is a high-performance, cloud-native object store that runs anywhere (public cloud, private cloud, colo, onprem).
The code in this story is for educational purposes. The readers are solely responsible for whatever they build with it.
Walkthroughs, tutorials, guides, and tips. This story will teach you how to do something new or how to do something better.
মধ্যে
এই টিউটোরিয়ালটি সম্পূর্ণ করতে, আপনাকে কিছু সফ্টওয়্যার দিয়ে সেট আপ করতে হবে। আপনার যা প্রয়োজন তা এখানে একটি ব্রেকডাউন রয়েছে:
ইনস্টলেশন: আপনি যদি তাজা শুরু করছেন, তাহলে
একবার আপনি ডকার ডেস্কটপ বা ডকার এবং ডকার কম্পোজের সংমিশ্রণ ইনস্টল করার পরে, আপনি আপনার টার্মিনালে নিম্নলিখিত কমান্ডটি চালিয়ে তাদের উপস্থিতি যাচাই করতে পারেন:
docker-compose --version
আপনার একটি SingleStore লাইসেন্সেরও প্রয়োজন হবে, যা আপনি পেতে পারেন
আপনার লাইসেন্স কী এবং আপনার রুট পাসওয়ার্ড উভয়ই নোট রাখুন। আপনার অ্যাকাউন্টে একটি এলোমেলো রুট পাসওয়ার্ড বরাদ্দ করা হবে, কিন্তু আপনি SingleStore UI ব্যবহার করে আপনার রুট পাসওয়ার্ড পরিবর্তন করতে সক্ষম হবেন।
এই টিউটোরিয়াল নির্ভর করে
এই রেপোর সবচেয়ে গুরুত্বপূর্ণ ফাইলটি হল docker-compose.yaml
যা একটি SingleStore ডাটাবেস ( singlestore
), একটি MinIO উদাহরণ ( minio
) এবং একটি mc
কন্টেইনার সহ একটি ডকার পরিবেশ বর্ণনা করে যা MinIO পরিষেবার উপর নির্ভর করে।
mc কন্টেইনারে একটি entrypoint
স্ক্রিপ্ট রয়েছে যা প্রথমে MinIO অ্যাক্সেসযোগ্য না হওয়া পর্যন্ত অপেক্ষা করে, একটি হোস্ট হিসাবে MinIO যোগ করে, classic-books
বাকেট তৈরি করে, বইয়ের ডেটা সম্বলিত books.txt
ফাইল আপলোড করে, বালতি নীতি সর্বজনীনভাবে সেট করে এবং তারপরে প্রস্থান করে।
version: '3.7' services: singlestore: image: 'singlestore/cluster-in-a-box' ports: - "3306:3306" - "8080:8080" environment: LICENSE_KEY: "" ROOT_PASSWORD: "" START_AFTER_INIT: 'Y' minio: image: minio/minio:latest ports: - "9000:9000" - "9001:9001" volumes: - data1-1:/data1 - data1-2:/data2 environment: MINIO_ROOT_USER: minioadmin MINIO_ROOT_PASSWORD: minioadmin command: ["server", "/data1", "/data2", "--console-address", ":9001"] mc: image: minio/mc:latest depends_on: - minio entrypoint: > /bin/sh -c " until (/usr/bin/mc config host add --quiet --api s3v4 local http://minio:9000 minioadmin minioadmin) do echo '...waiting...' && sleep 1; done; echo 'Title,Author,Year' > books.txt; echo 'The Catcher in the Rye,JD Salinger,1945' >> books.txt; echo 'Pride and Prejudice,Jane Austen,1813' >> books.txt; echo 'Of Mice and Men,John Steinbeck,1937' >> books.txt; echo 'Frankenstein,Mary Shelley,1818' >> books.txt; /usr/bin/mc cp books.txt local/classic-books/books.txt; /usr/bin/mc policy set public local/classic-books; exit 0; " volumes: data1-1: data1-2:
একটি নথি সম্পাদক ব্যবহার করে, আপনার লাইসেন্স কী এবং রুট পাসওয়ার্ড দিয়ে স্থানধারকগুলিকে প্রতিস্থাপন করুন৷
একটি টার্মিনাল উইন্ডোতে, যেখানে আপনি রেপো ক্লোন করেছেন সেখানে নেভিগেট করুন এবং সমস্ত কন্টেইনার চালু করতে নিম্নলিখিত কমান্ডটি চালান:
docker-compose up
একটি ব্রাউজার উইন্ডো খুলুন নেভিগেট করুন
নেভিগেট করুনminioadmin:minioadmin
এর জন্য ব্যবহারকারীর নাম এবং পাসওয়ার্ড দিয়ে লগইন করুন। আপনি দেখতে পাবেন যে mc কন্টেইনারটি classic-books
নামে একটি বালতি তৈরি করেছে এবং বালতিতে একটি বস্তু রয়েছে।
SingleStore এ, SQL এডিটরে নেভিগেট করুন এবং নিম্নলিখিতটি চালান
-- Create a new database named 'books' CREATE DATABASE books; -- Switch to the 'books' database USE books; -- Create a table named 'classic_books' to store information about classic books CREATE TABLE classic_books ( title VARCHAR(255), author VARCHAR(255), date VARCHAR(255) ); -- Define a pipeline named 'minio' to load data from an S3 bucket called 'classic-books' -- The pipeline loads data into the 'classic_books' table CREATE PIPELINE IF NOT EXISTS minio AS LOAD DATA S3 'classic-books' CONFIG '{"region": "us-east-1", "endpoint_url":"http://minio:9000/"}' CREDENTIALS '{"aws_access_key_id": "minioadmin", "aws_secret_access_key": "minioadmin"}' INTO TABLE classic_books FIELDS TERMINATED BY ','; -- Start the 'minio' pipeline to initiate data loading START PIPELINE minio; -- Retrieve and display all records from the 'classic_books' table SELECT * FROM classic_books; -- Drop the 'minio' pipeline to stop data loading DROP PIPELINE minio; -- Drop the 'classic_books' table to remove it from the database DROP TABLE classic_books; -- Drop the 'books' database to remove it entirely DROP DATABASE books;
এই SQL স্ক্রিপ্ট ক্লাসিক বই সম্পর্কিত ডেটা পরিচালনা করার জন্য কর্মের একটি ক্রম শুরু করে। এটি books
নামে একটি নতুন ডাটাবেস প্রতিষ্ঠার মাধ্যমে শুরু হয়। এই ডাটাবেসের মধ্যে, classic_books
নামে একটি টেবিল তৈরি করা হয়েছে, যা শিরোনাম, লেখক এবং প্রকাশের তারিখের মতো বিবরণ রাখার জন্য ডিজাইন করা হয়েছে।
এটি অনুসরণ করে, classic-books
লেবেলযুক্ত একটি S3 বাকেট থেকে ডেটা বের করতে এবং classic_books
টেবিলে লোড করার জন্য minio
নামে একটি পাইপলাইন সেট আপ করা হয়েছে। এই পাইপলাইনের জন্য কনফিগারেশন পরামিতি, অঞ্চল, এন্ডপয়েন্ট URL, এবং প্রমাণীকরণ শংসাপত্র সহ, সংজ্ঞায়িত করা হয়েছে।
পরবর্তীকালে, তথ্য পুনরুদ্ধার এবং জনসংখ্যার প্রক্রিয়া শুরু করতে 'মিনিও' পাইপলাইন সক্রিয় করা হয়। একবার টেবিলে ডেটা সফলভাবে লোড হয়ে গেলে, একটি SELECT ক্যোয়ারী classic_books
সংরক্ষিত সমস্ত রেকর্ড পুনরুদ্ধার করে এবং প্রদর্শন করে।
ডেটা নিষ্কাশন এবং দেখার সমাপ্তির পরে, minio
পাইপলাইনটি থামানো হয় এবং সরানো হয়, classic_books
টেবিলটি books
ডাটাবেস থেকে বাদ দেওয়া হয় এবং books
ডাটাবেসটি নিজেই সরানো হয়, একটি পরিষ্কার স্লেট নিশ্চিত করে এবং ডেটা পরিচালনার ক্রিয়াকলাপগুলি সমাপ্ত করে৷ এই স্ক্রিপ্টটি আপনাকে SingleStore-এ MinIO-তে ডেটা নিয়ে খেলা শুরু করা উচিত।
এই টিউটোরিয়ালটি দ্রুত একটি শক্তিশালী ডেটা স্ট্যাক সেট আপ করে যা অবজেক্ট স্টোরেজে ডেটা সংরক্ষণ, প্রক্রিয়াকরণ এবং অনুসন্ধানের সাথে পরীক্ষা করার অনুমতি দেয়। SingleStore-এর ইন্টিগ্রেশন, একটি ক্লাউড-নেটিভ ডাটাবেস যা তার গতি এবং বহুমুখীতার জন্য পরিচিত, MinIO এর সাথে আধুনিক ডেটালেক স্ট্যাকের একটি গুরুত্বপূর্ণ ইট তৈরি করে।
যেহেতু শিল্পের প্রবণতা স্টোরেজ এবং গণনার বিচ্ছিন্নতার দিকে ঝুঁকছে, এই সেটআপটি ডেভেলপারদের উদ্ভাবনী ডেটা পরিচালনার কৌশলগুলি অন্বেষণ করার ক্ষমতা দেয়। আপনি ডেটা-ইনটেনসিভ অ্যাপ্লিকেশন তৈরি করতে, উন্নত অ্যানালিটিক্স প্রয়োগ করতে বা AI ওয়ার্কলোড নিয়ে পরীক্ষা করতে আগ্রহী হন না কেন, এই টিউটোরিয়ালটি একটি লঞ্চিং প্যাড হিসাবে কাজ করে।
আমরা আপনাকে এই ডেটা স্ট্যাক তৈরি করতে, বিভিন্ন ডেটাসেট এবং কনফিগারেশন নিয়ে পরীক্ষা করার জন্য এবং আপনার ডেটা-চালিত অ্যাপ্লিকেশনগুলির সম্পূর্ণ সম্ভাবনা উন্মোচন করার জন্য আমন্ত্রণ জানাচ্ছি। কোনো প্রশ্ন বা ধারণার জন্য, নির্দ্বিধায় আমাদের সাথে hello@min.io এ পৌঁছান বা আমাদের সাথে যোগ দিন