Firebase ব্যবহারকারীর শংসাপত্রগুলি ভাগ না করে পরিষেবাগুলি পরিচালনা এবং পরিচালনা করতে Google Cloud পরিষেবা অ্যাকাউন্টগুলি ব্যবহার করে৷ আপনি যখন Cloud Storage ব্যবহার করে এমন একটি ফায়ারবেস প্রকল্প তৈরি করেন, তখন আপনি লক্ষ্য করতে পারেন যে আপনার প্রকল্পে একটি সংশ্লিষ্ট পরিষেবা অ্যাকাউন্ট ইতিমধ্যেই উপলব্ধ রয়েছে: service-<project number>@gcp-sa-firebasestorage.iam.gserviceaccount.com
। আরও তথ্যের জন্য এই Firebase সমর্থন নির্দেশিকা দেখুন।
হুডের নিচে, Cloud Storage জন্য Firebase SDK App Engine নো-কস্ট টিয়ারে ডিফল্ট বালতি ব্যবহার করে। এটি আপনাকে ক্রেডিট কার্ড না রেখে বা Cloud Billing অ্যাকাউন্ট সক্ষম না করেই Cloud Storage সাথে দ্রুত উঠতে এবং চালানোর অনুমতি দেয়৷ এটি আপনাকে Firebase এবং একটি Google Cloud প্রকল্পের মধ্যে সহজেই ডেটা ভাগ করতে দেয়৷
বিদ্যমান Cloud Storage বালতি আমদানি সহ Google Cloud সাথে একীভূত করার জন্য, ব্লেজ প্ল্যানে একটি ফায়ারবেস প্রকল্পের প্রয়োজন৷ আমাদের মূল্য পৃষ্ঠায় পরিকল্পনা সম্পর্কে আরও জানুন।
Google Cloud Storage
আপনি Cloud Storage জন্য Firebase SDK-এর মাধ্যমে আপলোড করা ফাইলগুলি অ্যাক্সেস করতে Google Cloud Storage API ব্যবহার করতে পারেন, বিশেষ করে আরও জটিল ক্রিয়াকলাপ সম্পাদন করতে, যেমন একটি ফাইল অনুলিপি করা বা সরানো, বা একটি রেফারেন্সে উপলব্ধ সমস্ত ফাইল তালিকাভুক্ত করা৷
এটা মনে রাখা গুরুত্বপূর্ণ যে এই অনুরোধগুলি Firebase Authentication এবং Cloud Storage Security Rules পরিবর্তে Google Cloud Storage অ্যাক্সেস নিয়ন্ত্রণ বিকল্পগুলি ব্যবহার করে৷
এপিআই
Cloud Storage জন্য Firebase SDK ছাড়াও, আপনি কী করতে চান তার উপর নির্ভর করে আপনার Cloud Storage বালতিতে সংরক্ষিত ডেটা অ্যাক্সেস করার আরও অনেক উপায় রয়েছে। আপনি যদি কোনো সার্ভারে ডেটা অ্যাক্সেস করেন, আমরা সার্ভার সাইড লাইব্রেরি, সেইসাথে একটি JSON
এবং S3 সামঞ্জস্যপূর্ণ XML
RESTful API অফার করি, অথবা যদি আপনার স্ক্রিপ্ট পরিবর্তন বা অন্যান্য প্রশাসনিক কাজ সম্পাদন করার প্রয়োজন হয়, আমরা একটি কমান্ড লাইন টুল পেয়েছি যা কাজে আসবে।
Google Cloud সার্ভার SDKs
Google Cloud Cloud Storage সহ বেশ কয়েকটি ক্লাউড পণ্যের জন্য উচ্চ-মানের সার্ভার SDK অফার করে। এই লাইব্রেরিগুলো Node.js , Java , go , Python , PHP , এবং Ruby তে পাওয়া যায়।
ইনস্টলেশন নির্দেশাবলী, প্রমাণীকরণ এবং সমস্যা সমাধান সহ আরও তথ্যের জন্য, উপরে লিঙ্ক করা প্ল্যাটফর্ম-নির্দিষ্ট ডকুমেন্টেশন দেখুন।
Google Cloud Storage SDK-এর ব্যবহারের উদাহরণ নীচে দেখানো হয়েছে:
Node.js
// Require gcloud
var gcloud = require('google-cloud');
// Enable Cloud Storage
var gcs = gcloud.storage({
projectId: 'grape-spaceship-123',
keyFilename: '/path/to/keyfile.json'
});
// Reference an existing bucket.
var bucket = gcs.bucket('my-existing-bucket');
// Upload a local file to a new file to be created in your bucket.
bucket.upload('/photos/zoo/zebra.jpg', function(err, file) {
if (!err) {
// "zebra.jpg" is now in your bucket.
}
});
// Download a file from your bucket.
bucket.file('giraffe.jpg').download({
destination: '/photos/zoo/giraffe.jpg'
}, function(err) {});
জাভা
// Enable Cloud Storage
Storage storage = StorageOptions.builder()
.authCredentials(AuthCredentials.createForJson(new FileInputStream("/path/to/my/key.json"))
.build()
.service();
// Upload a local file to a new file to be created in your bucket.
InputStream uploadContent = ...
BlobId blobId = BlobId.of("my-existing-bucket", "zebra.jpg");
BlobInfo blobInfo = BlobInfo.builder(blobId).contentType("text/plain").build();
Blob zebraBlob = storage.create(blobInfo, content);
// Download a file from your bucket.
Blob giraffeBlob = storage.get("my-existing-bucket", "giraffe.jpg", null);
InputStream downloadContent = giraffeBlob.getInputStream();
যাও
// Enable Cloud Storage
client, err := storage.NewClient(ctx, option.WithServiceAccountFile("path/to/keyfile.json"))
if err != nil {
log.Fatal(err)
}
// Download a file from your bucket.
rc, err := client.Bucket("my-existing-bucket").Object("giraffe.jpg").NewReader(ctx)
if err != nil {
log.Fatal(err)
}
defer rc.Close()
body, err := ioutil.ReadAll(rc)
if err != nil {
log.Fatal(err)
}
পাইথন
# Import gcloud
from google.cloud import storage
# Enable Cloud Storage
client = storage.Client()
# Reference an existing bucket.
bucket = client.get_bucket('my-existing-bucket')
# Upload a local file to a new file to be created in your bucket.
zebraBlob = bucket.get_blob('zebra.jpg')
zebraBlob.upload_from_filename(filename='/photos/zoo/zebra.jpg')
# Download a file from your bucket.
giraffeBlob = bucket.get_blob('giraffe.jpg')
giraffeBlob.download_as_string()
পিএইচপি
// Require gcloud
require 'vendor/autoload.php';
use Google\Cloud\Storage\StorageClient;
// Enable Cloud Storage
$storage = new StorageClient([
'projectId' => 'grape-spaceship-123'
]);
// Reference an existing bucket.
$bucket = $storage->bucket('my-existing-bucket');
// Upload a file to the bucket.
$bucket->upload(
fopen('/photos/zoo/zebra.jpg', 'r')
);
// Download a file from your bucket.
$object = $bucket->object('giraffe.jpg');
$object->downloadToFile('/photos/zoo/giraffe.jpg');
রুবি
# Require gcloud
require "google/cloud"
# Enable Cloud Storage
gcloud = Google::Cloud.new "grape-spaceship-123", "/path/to/keyfile.json"
storage = gcloud.storage
# Reference an existing bucket.
bucket = storage.bucket "my-existing-bucket"
# Upload a file to the bucket.
bucket.create_file "/photos/zoo/zebra.jpg", "zebra.jpg"
# Download a file from your bucket.
file = bucket.file "giraffe.jpg"
file.download "/photos/zoo/#{file.name}"
REST API
আপনি যদি ক্লায়েন্ট লাইব্রেরি ছাড়াই কোনো ভাষা ব্যবহার করেন, এমন কিছু করতে চান যা ক্লায়েন্ট লাইব্রেরিগুলি করে না, বা শুধুমাত্র একটি প্রিয় HTTP ক্লায়েন্ট থাকে যা আপনি ব্যবহার করতে পছন্দ করেন, Google Cloud Storage JSON এবং XML উভয়ের জন্য API অফার করে .
এই স্টোরেজ ডেটা অ্যাক্সেস APIগুলি ছাড়াও, Firebase প্রকল্পগুলিতে ব্যবহারের জন্য ক্লাউড স্টোরেজ বালতিগুলি পরিচালনা করতে, আপনি Firebase API-এর জন্য ক্লাউড স্টোরেজ ব্যবহার করতে পারেন।
gsutil
gsutil
হল একটি কমান্ড লাইন টুল যা আপনাকে Cloud Storage সরাসরি অ্যাক্সেস দেয়। আপনি বালতি এবং অবজেক্ট ম্যানেজমেন্টের বিস্তৃত কাজ করতে gsutil
ব্যবহার করতে পারেন, যার মধ্যে রয়েছে:
- বস্তু আপলোড করা, ডাউনলোড করা এবং মুছে ফেলা।
- বালতি এবং বস্তুর তালিকা করা।
- বস্তু সরানো, অনুলিপি করা এবং নাম পরিবর্তন করা।
- বস্তু এবং বালতি ACL সম্পাদনা করা হচ্ছে।
gsutil
অন্যান্য উন্নত ক্রিয়াকলাপগুলির জন্য অনুমতি দেয়, যেমন একটি ডিরেক্টরি থেকে অন্য ডিরেক্টরিতে ফাইল সরানো, বা একটি নির্দিষ্ট অবস্থানের নীচের সমস্ত ফাইল মুছে ফেলা।
সমস্ত ফাইল এক রেফারেন্স থেকে অন্য রেফারেন্সে সরানো যতটা সহজ:
gsutil mv gs://bucket/old/reference gs://bucket/new/reference
একটি রেফারেন্সের নীচে সমস্ত ফাইল মুছে ফেলা ব্যাচ একইভাবে স্বজ্ঞাত:
# Delete all files under a path gsutil rm -r gs://bucket/reference/to/delete# Delete all the files in a bucket but not the bucket gsutil rm -r gs://bucket/**
# Delete all the files AND the bucket # Removing the default bucket will break the Firebase SDKs for Cloud Storage and is strongly discouraged gsutil rm -r gs://bucket
অনুরোধ হার
Google Cloud Storage হল একটি অত্যন্ত মাপযোগ্য পরিষেবা যা খুব উচ্চ অনুরোধের হার অর্জন করতে স্বয়ংক্রিয়-স্কেলিং প্রযুক্তি ব্যবহার করে।
Google Cloud Storage হল একটি মাল্টি-টেন্যান্ট পরিষেবা, যার অর্থ ব্যবহারকারীরা অন্তর্নিহিত সংস্থানগুলির একই সেট ভাগ করে। এই ভাগ করা সম্পদগুলির সর্বোত্তম ব্যবহার করার জন্য, বালতিগুলির একটি প্রাথমিক IO ক্ষমতা রয়েছে।
আপনি যখন আপনার অ্যাপে Cloud Storage for Firebase একীভূত করার পরিকল্পনা করছেন, তখন ভাল পারফরম্যান্সের জন্য আপনার অ্যাপের প্রয়োজনীয় ন্যূনতম অনুরোধের হার এবং দক্ষতার সাথে অনুরোধ করার বিষয়ে চিন্তা করুন। অনুরোধের হার সম্পর্কে নির্দেশিকা পর্যালোচনা করুন, এবং বিশেষ করে অনুরোধের হার বাড়ান ।
অবজেক্ট সংস্করণ
আপনি কি কখনও দুর্ঘটনাক্রমে কিছু মুছে ফেলেছেন এবং ব্যাকআপ নেননি? Google Cloud Storage অবজেক্ট সংস্করণ সমর্থন করে, যা আপনার ডেটা ব্যাক আপ করার এবং সেই ব্যাকআপগুলি থেকে পুনরুদ্ধার করার একটি স্বয়ংক্রিয় উপায় প্রদান করে৷ আপনি gsutil
versioning set
কমান্ড ব্যবহার করে অবজেক্ট সংস্করণ সক্ষম করতে পারেন:
gsutil versioning set on gs://<your-cloud-storage-bucket>
Cloud Storage সর্বদা সাম্প্রতিকতম সংস্করণটি তুলে নেয়, তাই আপনি যদি একটি বস্তু পুনরুদ্ধার করতে চান তবে আপনাকে পছন্দসই বস্তুটিকে সাম্প্রতিকতম হিসাবে সেট করতে উপরের অন্য API বা সরঞ্জামগুলির একটি ব্যবহার করতে হবে।
অবজেক্ট লাইফসাইকেল ম্যানেজমেন্ট
পুরানো ফাইলগুলি স্বয়ংক্রিয়ভাবে সংরক্ষণাগার বা মুছে ফেলার ক্ষমতা থাকা অনেক অ্যাপ্লিকেশনের জন্য একটি দরকারী বৈশিষ্ট্য। সৌভাগ্যবশত, Google Cloud Storage লাইফসাইকেল ম্যানেজমেন্ট প্রদান করে, যা আপনাকে নির্দিষ্ট সময়ের পর বস্তু মুছে ফেলতে বা আর্কাইভ করতে দেয়।
একটি ফটো শেয়ারিং অ্যাপ্লিকেশন বিবেচনা করুন যেটি আপনি চান যে সমস্ত ফটো একদিনের মধ্যে মুছে ফেলা হোক। আপনি নিম্নলিখিত হিসাবে একটি অবজেক্ট লাইফসাইকেল নীতি সেট আপ করতে পারেন:
// lifecycle.json { "lifecycle": { "rule": [ { "action": {"type": "Delete"}, "condition": {"age": 1} } ] } }
এবং gsutil
lifecycle set
কমান্ড ব্যবহার করে এটি স্থাপন করুন:
gsutil lifecycle set lifecycle.json gs://<your-cloud-storage-bucket>
মনে রাখবেন যে এটি বালতিতে থাকা সমস্ত ফাইলের ক্ষেত্রে প্রযোজ্য, তাই যদি আপনি গুরুত্বপূর্ণ ব্যবহারকারীর ব্যাকআপগুলি সংরক্ষণ করেন যা আপনি দীর্ঘ সময়ের জন্য সঞ্চয় করতে চান পাশের ফটোগুলি যা আপনি প্রতিদিন মুছতে চান, আপনি দুটি পৃথক বালতি ব্যবহার করতে বা ম্যানুয়ালি মুছে ফেলার কাজ করতে চাইতে পারেন gsutil
বা আপনার নিজের সার্ভারের সাথে।
App Engine
App Engine হল একটি "পরিষেবা হিসাবে প্ল্যাটফর্ম" যা স্বয়ংক্রিয়ভাবে প্রাপ্ত ট্রাফিকের পরিমাণের প্রতিক্রিয়া হিসাবে ব্যাকএন্ড লজিক স্কেল করে। শুধু আপনার ব্যাকএন্ড কোড আপলোড করুন এবং Google আপনার অ্যাপের উপলব্ধতা পরিচালনা করবে; আপনার বিধান বা বজায় রাখার জন্য কোন সার্ভার নেই। App Engine হল আপনার ফায়ারবেস অ্যাপ্লিকেশনে অতিরিক্ত প্রসেসিং পাওয়ার বা বিশ্বস্ত এক্সিকিউশন যোগ করার একটি দ্রুত এবং সহজ উপায়।
Cloud Storage জন্য Firebase SDK App Engine ডিফল্ট বালতি ব্যবহার করে, যার মানে হল আপনি যদি একটি App Engine অ্যাপ তৈরি করেন, তাহলে আপনি Firebase এবং App Engine মধ্যে ডেটা ভাগ করতে বিল্ট-ইন App Engine API ব্যবহার করতে পারেন। এটি অডিও এনকোডিং, ভিডিও ট্রান্সকোডিং এবং ইমেজ ট্রান্সফর্মেশনের পাশাপাশি অন্যান্য গণনা নিবিড় পটভূমি প্রক্রিয়াকরণের জন্য দরকারী।
App Engine জাভা, পাইথন এবং গো স্ট্যান্ডার্ড পরিবেশে App Engine ইমেজ API ( Java , Python , যা একটি চিত্রের আকার পরিবর্তন করতে, ঘোরাতে, ফ্লিপ করতে এবং ক্রপ করতে পারে, সেইসাথে একটি চিত্র পরিবেশনকারী URL প্রদান করতে পারে যা ক্লায়েন্ট সাইড রূপান্তরের জন্য অনুমতি দেয়। , Cloudinary এবং Imgix অনুরূপ।
ফায়ারবেসে একটি বিদ্যমান Google Cloud প্রজেক্ট আমদানি করার সময়, আপনি যদি ফায়ারবেসে বিদ্যমান কোনো App Engine অবজেক্টকে উপলব্ধ করতে চান, তাহলে আপনাকে আপনার অবজেক্টে ডিফল্ট অ্যাক্সেস কন্ট্রোল সেট করতে হবে যাতে ফায়ারবেসকে gsutil
ব্যবহার করে নিম্নলিখিত কমান্ডটি চালিয়ে সেগুলি অ্যাক্সেস করতে দেয় :
gsutil -m acl ch -r -u service-<project number;gt@gcp-sa-firebasestorage.iam.gserviceaccount.com gs://<your-cloud-storage-bucket>
পরিচিত সমস্যা
দুটি পরিচিত কেস আছে যেখানে আপনি আপনার App Engine অ্যাপ আমদানি করতে পারবেন না:
- প্রকল্পটিতে একটি প্রাক্তন App Engine Datastore মাস্টার/স্লেভ অ্যাপ রয়েছে।
- প্রকল্পটির একটি ডোমেন প্রিফিক্সড প্রজেক্ট আইডি রয়েছে, উদাহরণস্বরূপ:
domain.com:project-1234
।
এই দুটি ক্ষেত্রেই, প্রকল্পটি Cloud Storage for Firebase সমর্থন করবে না এবং Cloud Storage ব্যবহার করার জন্য আপনাকে একটি নতুন ফায়ারবেস প্রকল্প তৈরি করতে হবে। সহায়তার সাথে যোগাযোগ করুন যাতে আমরা আপনাকে সাহায্য করতে পারি।
Google ক্লাউড ফাংশন (বিটা)
Google ক্লাউড ফাংশন হল একটি হালকা ওজনের, ইভেন্ট-ভিত্তিক, অ্যাসিঙ্ক্রোনাস কম্পিউট সমাধান যা আপনাকে ছোট, একক-উদ্দেশ্য ফাংশন তৈরি করতে দেয় যা সার্ভার বা রানটাইম পরিবেশ পরিচালনার প্রয়োজন ছাড়াই ইভেন্টগুলিতে প্রতিক্রিয়া জানায়। এই ফাংশনগুলি ভিডিও ট্রান্সকোডিং, মেশিন লার্নিং ব্যবহার করে ছবি শ্রেণীবদ্ধ করার জন্য বা Firebase Realtime Database সাথে মেটাডেটা সিঙ্ক করার জন্য ব্যবহার করা যেতে পারে। App Engine থেকেও কম ওভারহেড সহ, ক্লাউড ফাংশন হল Cloud Storage পরিবর্তনগুলিতে প্রতিক্রিয়া জানানোর দ্রুততম উপায়৷
গুগল ক্লাউড ভিশন API
Google ক্লাউড ভিশন API ব্যবহার করা সহজ API-এ শক্তিশালী মেশিন লার্নিং মডেলগুলিকে এনক্যাপসুলেট করে একটি ছবির বিষয়বস্তু বুঝতে বিকাশকারীদের সক্ষম করে৷ এটি দ্রুত চিত্রগুলিকে হাজার হাজার বিভাগে শ্রেণীবদ্ধ করে, চিত্রগুলির মধ্যে পৃথক বস্তু এবং মুখগুলি সনাক্ত করে, চিত্রগুলির মধ্যে থাকা মুদ্রিত শব্দগুলি খুঁজে পায় এবং পড়ে, আপত্তিকর বিষয়বস্তু সনাক্ত করে এবং এমনকি চিত্রের অনুভূতি বিশ্লেষণও প্রদান করে৷
গুগল ক্লাউড স্পিচ API
ভিশন API-এর মতো, Google ক্লাউড স্পিচ API ডেভেলপারদের Cloud Storage সঞ্চিত একটি অডিও ফাইল থেকে পাঠ্য বের করতে সক্ষম করে। API আপনার বিশ্বব্যাপী ব্যবহারকারী বেস সমর্থন করতে 80 টিরও বেশি ভাষা এবং রূপগুলিকে স্বীকৃতি দেয়৷ Google ক্লাউড ন্যাচারাল ল্যাঙ্গুয়েজ API-এর সাথে একত্রিত হলে, বিকাশকারীরা উভয়ই কাঁচা পাঠ্যটি বের করতে পারে এবং সেই পাঠ্যটির অর্থ অনুমান করতে পারে। এবং যদি একটি বিশ্বব্যাপী দর্শকের প্রয়োজন হয়, 90+ ভাষায় পাঠ্য অনুবাদ করতে Google অনুবাদ API এর সাথে এটিকে সংযুক্ত করুন৷