Microsoft Technologies Azure Services (Blob Storage, Functions, SQL Database) Integration গাইড ও নোট

266

Microsoft Azure একটি ক্লাউড প্ল্যাটফর্ম যা বিভিন্ন ধরনের সার্ভিস এবং টুল সরবরাহ করে, যার মাধ্যমে আপনি আপনার অ্যাপ্লিকেশনকে স্কেলেবল, রিলায়েবল এবং সিকিউর করতে পারেন। এর মধ্যে তিনটি গুরুত্বপূর্ণ সার্ভিস হল Azure Blob Storage, Azure Functions, এবং Azure SQL Database। এই সার্ভিসগুলির মাধ্যমে আপনি আপনার অ্যাপ্লিকেশন থেকে ডেটা স্টোরেজ, কম্পিউটেশনাল ফাংশনালিটি এবং ডেটাবেস ম্যানেজমেন্ট কার্যকরভাবে পরিচালনা করতে পারেন।

এই টিউটোরিয়ালে আমরা আলোচনা করব কিভাবে Blob Storage, Azure Functions, এবং Azure SQL Database কে একত্রে ব্যবহার করে অ্যাপ্লিকেশন তৈরি করা যায়।


১. Azure Blob Storage Integration

Azure Blob Storage একটি অবজেক্ট স্টোরেজ সার্ভিস, যা বড় আকারের আনস্ট্রাকচারড ডেটা (যেমন ইমেজ, ভিডিও, টেক্সট, ডকুমেন্ট ইত্যাদি) সংরক্ষণের জন্য ব্যবহৃত হয়। এটি আপনাকে ডেটা ক্লাউডে সংরক্ষণ এবং এক্সেস করার সুবিধা দেয়।

Blob Storage এর বৈশিষ্ট্য:

  • Scalable: বড় আকারের ডেটা সঞ্চয় করতে পারা।
  • Accessible via HTTP/HTTPS: ওয়েব অ্যাপ্লিকেশন বা API-এর মাধ্যমে এক্সেস করা যায়।
  • Cost-effective: অল্প খরচে বড় ডেটা সংরক্ষণ।

Blob Storage এ ডেটা আপলোড করা

Azure Blob Storage-এ ফাইল আপলোড করার জন্য Azure.Storage.Blobs প্যাকেজ ব্যবহার করা হয়।

প্রথমে NuGet প্যাকেজ ইনস্টল করুন:

Install-Package Azure.Storage.Blobs

C# Code for Uploading Blob:

using Azure.Storage.Blobs;
using System;
using System.IO;
using System.Threading.Tasks;

class Program
{
    static async Task Main(string[] args)
    {
        string connectionString = "<Your-Blob-Storage-Connection-String>";
        string containerName = "my-container";
        string filePath = "path-to-your-file";
        string blobName = "my-blob";

        BlobServiceClient blobServiceClient = new BlobServiceClient(connectionString);
        BlobContainerClient containerClient = blobServiceClient.GetBlobContainerClient(containerName);
        BlobClient blobClient = containerClient.GetBlobClient(blobName);

        // Upload file to Blob Storage
        await blobClient.UploadAsync(filePath, overwrite: true);
        Console.WriteLine("File uploaded successfully.");
    }
}

২. Azure Functions Integration

Azure Functions হল একটি serverless compute service যা আপনাকে কোড চালানোর জন্য কোন সার্ভার ম্যানেজ করার প্রয়োজন নেই। এটি আপনাকে ট্রিগার বা ইভেন্টের ভিত্তিতে কোড চালানোর সুবিধা দেয়।

Azure Functions এর বৈশিষ্ট্য:

  • Serverless: সার্ভার ম্যানেজমেন্ট প্রয়োজন হয় না।
  • Scalable: কোড স্বয়ংক্রিয়ভাবে স্কেল হয় ট্রাফিক বা লোডের উপর নির্ভর করে।
  • Event-Driven: বিভিন্ন ইভেন্ট যেমন HTTP request, Blob storage ইভেন্ট, টিম ইন্টিগ্রেশন, etc. এর মাধ্যমে ট্রিগার করা যায়।

Creating an Azure Function:

  1. Azure Functions App তৈরি করুন Azure Portal এ।
  2. Function App তৈরি করার পর Function তৈরি করুন এবং ট্রিগার নির্বাচন করুন (যেমন HTTP Trigger বা Timer Trigger)।

C# Code for HTTP Triggered Azure Function:

using Microsoft.AspNetCore.Http;
using Microsoft.Azure.WebJobs;
using Microsoft.Extensions.Logging;
using System.IO;
using System.Threading.Tasks;

public static class Function1
{
    [FunctionName("UploadBlobTrigger")]
    public static async Task Run(
        [BlobTrigger("my-container/{name}", Connection = "AzureWebJobsStorage")]Stream myBlob,
        string name,
        ILogger log)
    {
        log.LogInformation($"C# Blob trigger function processed blob\n Name:{name} \n Size: {myBlob.Length} Bytes");

        // Process the blob
        // For example, call other services or store the result somewhere
    }
}

এই ফাংশনটি Blob Trigger ব্যবহার করে যখন একটি নতুন Blob আপলোড করা হবে, তখন এটি অটোমেটিক্যালি ট্রিগার হবে এবং আপনি প্রক্রিয়া করতে পারবেন।


৩. Azure SQL Database Integration

Azure SQL Database হল একটি ক্লাউড-ভিত্তিক রিলেশনাল ডেটাবেস সার্ভিস যা SQL Server এর উপর ভিত্তি করে। এটি অ্যাপ্লিকেশনগুলির জন্য স্কেলেবল এবং ম্যানেজড ডেটাবেস সলিউশন প্রদান করে।

Azure SQL Database এর বৈশিষ্ট্য:

  • Fully Managed: SQL Server-এর মত ডেটাবেস পরিচালিত হয়, কোনও সার্ভার ম্যানেজমেন্ট প্রয়োজন নেই।
  • Scalable: সহজেই স্কেল করা যায়।
  • Secure: অটোমেটিক ব্যাকআপ এবং নিরাপত্তা প্রদান করা হয়।

Azure SQL Database এ ডেটা ইনসার্ট করা

NuGet প্যাকেজ ইনস্টল করুন:

Install-Package Microsoft.Data.SqlClient

C# Code for Inserting Data into Azure SQL Database:

using System;
using System.Data.SqlClient;
using System.Threading.Tasks;

class Program
{
    static async Task Main(string[] args)
    {
        string connectionString = "<Your-Azure-SQL-Connection-String>";
        string query = "INSERT INTO Users (UserName, Email) VALUES (@UserName, @Email)";

        using (SqlConnection connection = new SqlConnection(connectionString))
        {
            await connection.OpenAsync();
            using (SqlCommand command = new SqlCommand(query, connection))
            {
                command.Parameters.AddWithValue("@UserName", "JohnDoe");
                command.Parameters.AddWithValue("@Email", "johndoe@example.com");

                int result = await command.ExecuteNonQueryAsync();

                if (result > 0)
                {
                    Console.WriteLine("Data inserted successfully.");
                }
                else
                {
                    Console.WriteLine("Data insertion failed.");
                }
            }
        }
    }
}

Complete Integration Example

একটি অ্যাপ্লিকেশনে Azure Blob Storage, Azure Functions, এবং Azure SQL Database একত্রিত করার মাধ্যমে আপনি ডেটা আপলোড, প্রক্রিয়া এবং ডেটাবেসে সংরক্ষণ করতে পারবেন।

Workflow:

  1. ব্যবহারকারী একটি ফাইল Blob Storage-এ আপলোড করবে।
  2. Azure Function Blob এর পরিবর্তন শুনবে এবং ফাইল প্রক্রিয়া করবে।
  3. প্রক্রিয়াকৃত ডেটা SQL Database-এ সংরক্ষণ করবে।

Workflow Example:

  1. ফাইল Blob Storage-এ আপলোড করা হলে এটি Azure Function দ্বারা প্রক্রিয়া হবে।
  2. এরপর সেই ডেটা Azure SQL Database-এ সংরক্ষিত হবে।

Conclusion

Azure Blob Storage, Azure Functions, এবং Azure SQL Database একত্রিত করলে আপনি একটি শক্তিশালী, স্কেলেবল এবং এফফিসিয়েন্ট ক্লাউড সলিউশন তৈরি করতে পারবেন। Blob Storage ডেটা সংরক্ষণ এবং প্রসেসিংয়ের জন্য, Functions স্ক্যালেবল কোড এক্সিকিউশন এবং SQL Database ডেটাবেস ম্যানেজমেন্টের জন্য ব্যবহৃত হয়। এই তিনটি সেবা একত্রিত করলে একটি শক্তিশালী এবং স্বয়ংক্রিয় অ্যাপ্লিকেশন তৈরি করা সম্ভব যা ক্লাউডের সকল সুবিধা ব্যবহার করে।

Content added By
Promotion

Are you sure to start over?

Loading...