Lambda Function Deployment এবং Configuration

এডাব্লিউএস ল্যাম্বডা (AWS Lambda) - Web Development

296

AWS Lambda ফাংশন তৈরি করার পর, সেটি ডিপ্লয় এবং কনফিগার করা অত্যন্ত গুরুত্বপূর্ণ, যাতে তা সঠিকভাবে কাজ করে এবং আপনার প্রয়োজন অনুযায়ী স্কেল করতে পারে। এই গাইডে আমরা Lambda ফাংশন ডিপ্লয় এবং কনফিগার করার মৌলিক ধাপগুলো আলোচনা করব।


Lambda Function Deployment

Lambda ফাংশন ডিপ্লয় করা মানে হলো, একবার ফাংশন তৈরি হলে, সেটি AWS ইকোসিস্টেমে ব্যবহারযোগ্য ও কার্যকরী করা। AWS Lambda ফাংশন ডিপ্লয় করার জন্য কিছু পদক্ষেপ অনুসরণ করতে হবে।

Step 1: কোড লিখুন এবং সংরক্ষণ করুন

Lambda ফাংশন তৈরি করার প্রথম ধাপ হলো কোড লেখা। আপনি AWS Management Console থেকে সরাসরি কোড লিখতে পারেন অথবা একটি .zip ফাইল বা কনটেইনার ইমেজ আপলোড করতে পারেন।

  1. Console Editor: আপনি AWS Console এর মাধ্যমে সরাসরি কোড লিখে সেটি সংরক্ষণ করতে পারেন।
  2. .zip ফাইল আপলোড: আপনি কোড এবং এর ডিপেনডেন্সিসহ একটি .zip ফাইল তৈরি করে Lambda কনসোলে আপলোড করতে পারেন।
  3. Container Image: আপনি একটি কনটেইনার ইমেজও ব্যবহার করতে পারেন, তবে এটি সাধারণত উন্নত ব্যবহারকারীদের জন্য।

Step 2: Lambda ফাংশনটি টেস্ট করুন

Lambda ফাংশন ডিপ্লয় করার পর, আপনাকে এটি টেস্ট করতে হবে। AWS Lambda Console থেকে আপনি Test অপশন ব্যবহার করে ফাংশনটি টেস্ট করতে পারবেন। এর মাধ্যমে আপনি নিশ্চিত হতে পারেন যে ফাংশনটি সঠিকভাবে কাজ করছে এবং প্রত্যাশিত আউটপুট প্রদান করছে।

  1. Test Event তৈরি করুন: Lambda ফাংশনের ইনপুট হিসেবে একটি ইভেন্ট (যেমন JSON ডেটা) প্রদান করুন।
  2. Test: Test বাটনে ক্লিক করুন এবং আউটপুট পরীক্ষা করুন। আপনি রিটার্ন স্ট্যাটাস এবং ফলাফল দেখতে পারবেন।

Step 3: Deployment (ডিপ্লয়মেন্ট)

Lambda ফাংশনটি সঠিকভাবে টেস্ট করার পর, আপনি এটি ডিপ্লয় করতে পারেন। Deploy বাটনে ক্লিক করার মাধ্যমে Lambda ফাংশনটি রিয়েল-টাইম প্রোডাকশন পরিবেশে ব্যবহারযোগ্য হয়ে উঠবে।


Lambda Function Configuration

Lambda ফাংশন কনফিগার করা অনেক গুরুত্বপূর্ণ, কারণ এটি ফাংশনের কার্যকারিতা এবং কর্মক্ষমতা নির্ধারণ করে। বিভিন্ন কনফিগারেশন সেটিংস রয়েছে, যেগুলি ফাংশনের কাজকে আরো কাস্টমাইজ করতে সাহায্য করে।

Function Configuration

  1. Function Name: ফাংশনের একটি ইউনিক নাম দিন। এটি আপনার ফাংশনটি চিহ্নিত করার জন্য প্রয়োজনীয়।
  2. Runtime: আপনি যে প্রোগ্রামিং ভাষায় ফাংশনটি লিখবেন, তা নির্বাচন করুন (যেমন Python, Node.js, Java, C# ইত্যাদি)।
  3. Role: ফাংশনটি চালানোর জন্য IAM Role নির্বাচন করুন, যা AWS সেবাগুলির সাথে সংযোগ স্থাপন করতে ব্যবহৃত হবে। আপনি একটি নতুন রোল তৈরি করতে পারেন অথবা পূর্ববর্তী কোনো রোল নির্বাচন করতে পারেন।

Execution Timeout

  1. Timeout: Lambda ফাংশনটির জন্য একটি টাইমআউট নির্ধারণ করতে হবে। এটি নিশ্চিত করে যে, ফাংশনটি কোনো কারণে অনির্দিষ্টকাল ধরে চলতে না পারে। টাইমআউটের মান সাধারণত 15 মিনিটের মধ্যে হতে পারে।

Memory Allocation

  1. Memory: Lambda ফাংশনের জন্য মেমরি নির্বাচন করুন। AWS Lambda ফাংশনটি স্বয়ংক্রিয়ভাবে স্কেল করে, তবে মেমরি নির্বাচন করা ফাংশনের পারফরম্যান্সে প্রভাব ফেলতে পারে। প্রয়োজনীয় কার্যক্রমের জন্য উপযুক্ত মেমরি নির্বাচন করা উচিত।

Environment Variables

  1. Environment Variables: Lambda ফাংশনে প্রয়োজনে পরিবেশগত ভেরিয়েবল সেট করা যেতে পারে। এগুলি সাধারনত সেইসব কনফিগারেশন ডেটার জন্য ব্যবহৃত হয়, যা বার বার কোডে ব্যবহার করা হয়, যেমন API কীগুলি, ডেটাবেস কনফিগারেশন ইত্যাদি।

VPC Configuration

  1. VPC: যদি আপনার Lambda ফাংশনটি কোনো নির্দিষ্ট VPC (Virtual Private Cloud) এর মধ্যে চলতে হয়, তবে সেক্ষেত্রে VPC সেট করতে হবে। Lambda ফাংশনটি VPC-এ চললে, আপনার ফাংশনটি VPC-এর নেটওয়ার্ক রিসোর্সগুলির সাথে সংযুক্ত হতে পারে (যেমন RDS, DynamoDB ইত্যাদি)।

Dead Letter Queue (DLQ)

  1. DLQ (Dead Letter Queue): Lambda ফাংশনটি কোনো কারণে সফলভাবে কাজ না করলে, আপনি একটি DLQ সিস্টেম কনফিগার করতে পারেন, যাতে ব্যর্থ হওয়া মেসেজগুলো সেখানে জমা হয়। এটি মেসেজ হারানো থেকে রক্ষা করে।

Lambda Function Deployment এবং Configuration এর উদাহরণ

ধরা যাক, আপনি একটি Python Lambda ফাংশন তৈরি করেছেন যা S3 বকেট থেকে ফাইল ইভেন্ট গ্রহণ করবে এবং কিছু প্রসেসিং করবে। এই Lambda ফাংশনটির জন্য কিছু কনফিগারেশন করতে হবে।

  1. Function Name: ProcessS3File
  2. Runtime: Python 3.8
  3. Memory: 512 MB (যেহেতু এটি একটি সাদামাটা ফাইল প্রসেসিং ফাংশন)
  4. Timeout: 5 মিনিট
  5. Environment Variables:
    • S3_BUCKET: my-bucket
    • PROCESSING_PATH: s3://my-bucket/processed/
  6. VPC: my-vpc
  7. Dead Letter Queue: my-dlq

এই কনফিগারেশন সেটিংসের মাধ্যমে Lambda ফাংশনটি কার্যকরভাবে কাজ করতে সক্ষম হবে, এবং S3 থেকে ফাইল আপলোড হলে তা প্রক্রিয়া করবে।


Lambda Function এর Auto Scaling

AWS Lambda স্বয়ংক্রিয়ভাবে স্কেল হয়, অর্থাৎ যখন Lambda ফাংশনটি বেশি ট্রাফিক বা ইভেন্ট গ্রহণ করবে, তখন এটি স্বয়ংক্রিয়ভাবে আরো ইনস্ট্যান্সে রান করবে। এই জন্য আলাদা কোনো স্কেলিং কনফিগারেশন করতে হয় না। তবে আপনি Concurrency Limit নির্ধারণ করতে পারেন, যাতে ফাংশনটি নির্দিষ্ট সংখ্যক রিকোয়েস্টের বাইরে এক্সিকিউট না হয়।


সারাংশ

AWS Lambda ফাংশন তৈরি করার পর, সেটি সঠিকভাবে ডিপ্লয় এবং কনফিগার করা খুবই গুরুত্বপূর্ণ। Deployment ধাপে কোড সংরক্ষণ এবং টেস্ট করার পর ফাংশনটি রিয়েল-টাইম পরিবেশে ডিপ্লয় করা হয়। Configuration ধাপে ফাংশনের জন্য প্রয়োজনীয় রোল, মেমরি, টাইমআউট, VPC কনফিগারেশন ইত্যাদি সেট করা হয়। সঠিক কনফিগারেশন Lambda ফাংশনের পারফরম্যান্স এবং কার্যকারিতাকে শক্তিশালী এবং দক্ষ করে তোলে।

Content added By

AWS Lambda ফাংশন তৈরি করার সময়, কোড এবং প্রাসঙ্গিক ডিপেনডেন্সি সংরক্ষণ করার জন্য একটি Deployment Package তৈরি করতে হয়। এই প্যাকেজটি AWS Lambda ফাংশনের এক্সিকিউশন পরিবেশে রান করার জন্য প্রয়োজনীয় সমস্ত ফাইল এবং ডিপেনডেন্সি ধারণ করে। AWS Lambda ফাংশন ডিপ্লয় করার জন্য প্রধানত দুটি পদ্ধতি ব্যবহৃত হয়: ZIP Deployment Package এবং Container Image


ZIP Deployment Package

ZIP Deployment Package হলো একটি সাধারণ পদ্ধতি যা AWS Lambda ফাংশন ডিপ্লয় করতে ব্যবহার করা হয়। এটি মূলত আপনার কোড এবং প্রয়োজনীয় লাইব্রেরি/ডিপেনডেন্সির একটি সংযুক্ত (compressed) ফাইল।

ZIP Deployment Package তৈরি করার ধাপ

  1. কোড লেখুন
    প্রথমে আপনার Lambda ফাংশনের কোড লেখুন। উদাহরণস্বরূপ, Python ফাংশন হতে পারে:

    def lambda_handler(event, context):
        return "Hello, " + event['name']
    
  2. ডিপেনডেন্সি যুক্ত করুন (যদি প্রয়োজন হয়)
    যদি আপনার কোড কোনো নির্দিষ্ট লাইব্রেরি ব্যবহার করে, তবে সেগুলোও প্যাকেজে অন্তর্ভুক্ত করতে হবে। যেমন, যদি আপনি requests লাইব্রেরি ব্যবহার করেন, তাহলে এটি ইনস্টল করতে হবে:

    pip install requests -t /path/to/your/project
    

    এই কমান্ডটি requests লাইব্রেরি ইনস্টল করবে এবং তা আপনার প্রকল্পের ফোল্ডারে নিয়ে আসবে।

  3. ZIP ফাইল তৈরি করুন
    কোড ও সমস্ত ডিপেনডেন্সি একসাথে একটি ZIP ফাইলে প্যাকেজ করুন। এটি করার জন্য, নিম্নলিখিত কমান্ডটি ব্যবহার করতে পারেন:

    zip -r my_lambda_function.zip .
    

    এই কমান্ডটি বর্তমান ডিরেক্টরির সমস্ত ফাইল ও ফোল্ডার (কোড এবং ডিপেনডেন্সি) নিয়ে একটি my_lambda_function.zip ফাইল তৈরি করবে।

  4. Lambda Console এ আপলোড করুন
    AWS Management Console এ গিয়ে, Lambda ফাংশনের Function code সেকশনে ZIP ফাইল আপলোড করুন:
    • Function code > Code entry type: Select Upload a .zip file
    • Upload বাটনে ক্লিক করে তৈরি করা ZIP ফাইলটি আপলোড করুন।
  5. ফাংশন ডিপ্লয় করুন
    কোড আপলোড করার পর, Deploy বাটনে ক্লিক করে ফাংশনটি ডিপ্লয় করুন।

Container Image Deployment Package

AWS Lambda ফাংশন কনটেইনার ইমেজ ব্যবহার করে ডিপ্লয় করা একটি আধুনিক পদ্ধতি, যা আপনাকে কাস্টম Runtime এবং নির্দিষ্ট কনফিগারেশনের সাথে ফাংশন তৈরি করার সুবিধা দেয়। এই পদ্ধতিতে, আপনি আপনার Lambda ফাংশনকে Docker কনটেইনার ইমেজ হিসেবে প্যাকেজ করবেন।

Container Image Deployment Package তৈরি করার ধাপ

  1. Dockerfile তৈরি করুন
    একটি Dockerfile তৈরি করুন যা আপনার কোড এবং ডিপেনডেন্সি কনটেইনারে যোগ করবে। উদাহরণস্বরূপ, একটি Python Lambda ফাংশনের জন্য Dockerfile হতে পারে:

    FROM public.ecr.aws/lambda/python:3.8
    
    # কোড কপি করা
    COPY app.py ${LAMBDA_TASK_ROOT}
    
    # Lambda হ্যান্ডলার সেট করা
    CMD ["app.lambda_handler"]
    

    এখানে:

    • FROM public.ecr.aws/lambda/python:3.8: এটি AWS Lambda Python runtime এর একটি ইমেজ।
    • COPY app.py ${LAMBDA_TASK_ROOT}: আপনার কোডের ফাইল কনটেইনারে কপি করা হচ্ছে।
    • CMD ["app.lambda_handler"]: এটি Lambda ফাংশনের হ্যান্ডলার ফাংশন, যা কনটেইনারে এক্সিকিউট হবে।
  2. Docker ইমেজ বিল্ড করা
    Dockerfile তৈরি হওয়ার পর, কনটেইনার ইমেজ তৈরি করতে নিম্নলিখিত কমান্ডটি চালান:

    docker build -t my-lambda-image .
    

    এই কমান্ডটি my-lambda-image নামে একটি Docker ইমেজ তৈরি করবে।

  3. ইমেজ পুশ করা (ECR)
    Docker ইমেজটি AWS Lambda এ ডিপ্লয় করার জন্য, আপনাকে ইমেজটি AWS ECR (Elastic Container Registry) এ পুশ করতে হবে। প্রথমে একটি ECR রিপোজিটরি তৈরি করুন এবং তারপর ইমেজটি পুশ করুন:

    # ECR রিপোজিটরি তৈরি করুন
    aws ecr create-repository --repository-name my-lambda-repo
    
    # ECR লগইন
    aws ecr get-login-password --region <region> | docker login --username AWS --password-stdin <aws_account_id>.dkr.ecr.<region>.amazonaws.com
    
    # ইমেজ ট্যাগ এবং পুশ করুন
    docker tag my-lambda-image:latest <aws_account_id>.dkr.ecr.<region>.amazonaws.com/my-lambda-repo:latest
    docker push <aws_account_id>.dkr.ecr.<region>.amazonaws.com/my-lambda-repo:latest
    
  4. Lambda Console এ কনটেইনার ইমেজ পছন্দ করুন
    AWS Lambda Console এ গিয়ে, Create function সেকশনে Container image নির্বাচন করুন। তারপর ECR রিপোজিটরি থেকে ইমেজ পছন্দ করুন।
  5. ফাংশন ডিপ্লয় করুন
    ইমেজ পুশ করার পর, Lambda কনসোলে গিয়েই ফাংশনটি ডিপ্লয় করুন।

সারাংশ

AWS Lambda ফাংশন ডিপ্লয় করার জন্য দুটি প্রধান পদ্ধতি রয়েছে: ZIP Deployment Package এবং Container Image। ZIP প্যাকেজ সহজ এবং দ্রুত ব্যবহারের জন্য উপযুক্ত, যেখানে কোড ও ডিপেনডেন্সি একটি ZIP ফাইলে সংরক্ষিত হয়। অন্যদিকে, কনটেইনার ইমেজ পদ্ধতি অধিক কাস্টমাইজেশন এবং কনটেইনারাইজড পরিবেশ ব্যবহারের জন্য উপযুক্ত, যেখানে একটি Docker ইমেজ Lambda ফাংশন হিসেবে পুশ করা হয়। এই দুটি পদ্ধতি AWS Lambda ফাংশন ডিপ্লয়মেন্টের জন্য সুবিধাজনক এবং শক্তিশালী টুলস প্রদান করে।

Content added By

AWS Lambda ফাংশন ডিপ্লয়মেন্টের জন্য বিভিন্ন পদ্ধতি রয়েছে, যার মাধ্যমে আপনি Lambda ফাংশন বিভিন্নভাবে ডিপ্লয় করতে পারেন। এই পদ্ধতিগুলির মধ্যে রয়েছে AWS CLI (Command Line Interface), SAM (Serverless Application Model), এবং AWS Management Console। এই গাইডে আমরা এই তিনটি পদ্ধতির মাধ্যমে Lambda ফাংশন ডিপ্লয় করার প্রক্রিয়া আলোচনা করব।


1. AWS CLI (Command Line Interface) এর মাধ্যমে Lambda ডিপ্লয় করা

AWS CLI ব্যবহার করে Lambda ফাংশন ডিপ্লয় করার জন্য আপনাকে প্রথমে AWS CLI ইন্সটল করতে হবে এবং সেটআপ করতে হবে। এরপর আপনি কমান্ড লাইন থেকে Lambda ফাংশন ডিপ্লয় করতে পারবেন।

AWS CLI দিয়ে Lambda ফাংশন ডিপ্লয় করার ধাপ:

  1. AWS CLI ইন্সটল করুন এবং কনফিগার করুন
    • প্রথমে AWS CLI ইন্সটল করুন।
    • CLI কনফিগার করতে, কমান্ড লাইন ওপেন করে নিম্নলিখিত কমান্ডটি চালান:

      aws configure
      
    • এখানে আপনি আপনার AWS Access Key, Secret Key, Region, এবং Output format প্রদান করবেন।
  2. Lambda ফাংশন আপলোড করুন
    Lambda ফাংশন ডিপ্লয় করার জন্য, প্রথমে কোড ফাইল (যেমন .zip ফাইল) তৈরি করুন। এর পর, AWS CLI ব্যবহার করে ফাংশন আপলোড করুন:

    aws lambda create-function \
      --function-name MyLambdaFunction \
      --runtime python3.8 \
      --role arn:aws:iam::ACCOUNT_ID:role/ROLE_NAME \
      --handler lambda_function.lambda_handler \
      --zip-file fileb://function.zip
    

    এখানে:

    • function-name: ফাংশনের নাম।
    • runtime: আপনি যে প্রোগ্রামিং ভাষা ব্যবহার করছেন (যেমন python3.8)।
    • role: IAM রোলের ARN (যা Lambda ফাংশনটি চালানোর জন্য প্রয়োজনীয় পারমিশন দেয়)।
    • handler: ফাংশনের হ্যান্ডলার (যেমন lambda_function.lambda_handler)।
    • zip-file: Lambda ফাংশনের কোডের ZIP ফাইল।
  3. ফাংশন আপডেট করুন
    যদি কোডের কোনো পরিবর্তন করতে হয়, তবে আপনি নিচের কমান্ডটি ব্যবহার করতে পারেন:

    aws lambda update-function-code \
      --function-name MyLambdaFunction \
      --zip-file fileb://function.zip
    

2. SAM (Serverless Application Model) এর মাধ্যমে Lambda ডিপ্লয় করা

AWS SAM (Serverless Application Model) একটি ফ্রেমওয়ার্ক যা আপনাকে সহজে serverless অ্যাপ্লিকেশন তৈরি, ডিপ্লয়, এবং ম্যানেজ করতে সহায়তা করে। SAM ব্যবহার করে Lambda ফাংশন ডিপ্লয় করতে, আপনাকে template.yaml ফাইল তৈরি করতে হবে এবং সেই অনুযায়ী অ্যাপ্লিকেশন ডিপ্লয় করতে হবে।

SAM দিয়ে Lambda ফাংশন ডিপ্লয় করার ধাপ:

  1. AWS SAM ইন্সটল করুন
    AWS SAM ইন্সটল করার জন্য, নিচের কমান্ডটি ব্যবহার করুন:

    pip install aws-sam-cli
    
  2. SAM অ্যাপ্লিকেশন তৈরি করুন
    SAM CLI দিয়ে একটি নতুন সার্ভারলেস অ্যাপ্লিকেশন তৈরি করতে, নিচের কমান্ডটি চালান:

    sam init
    

    এই কমান্ডটি আপনাকে একটি নতুন অ্যাপ্লিকেশন তৈরি করতে সাহায্য করবে। SAM আপনাকে প্রোজেক্টের জন্য রানটাইম এবং অন্যান্য কনফিগারেশন নির্ধারণ করতে চাইবে।

  3. template.yaml ফাইল তৈরি করুন
    SAM অ্যাপ্লিকেশন তৈরির পর, আপনি template.yaml ফাইলের মধ্যে আপনার Lambda ফাংশন কনফিগারেশন লিখবেন। উদাহরণস্বরূপ:

    Resources:
      MyLambdaFunction:
        Type: AWS::Serverless::Function
        Properties:
          Handler: lambda_function.lambda_handler
          Runtime: python3.8
          CodeUri: .
          MemorySize: 128
          Timeout: 3
    

    এখানে:

    • Handler: Lambda ফাংশনের হ্যান্ডলার।
    • Runtime: আপনি যে প্রোগ্রামিং ভাষা ব্যবহার করছেন (যেমন python3.8)।
    • CodeUri: ফাংশনের কোডের লোকেশন।
  4. ডিপ্লয় করুন
    SAM দিয়ে Lambda ফাংশন ডিপ্লয় করার জন্য, প্রথমে আপনি একটি স্যাম্পল প্যাকেজ তৈরি করবেন, তারপর ডিপ্লয় করবেন:

    sam build
    sam deploy --guided
    

    এই কমান্ডটি আপনাকে AWS অ্যাকাউন্টে Lambda ফাংশন এবং অন্যান্য রিসোর্স ডিপ্লয় করতে সহায়তা করবে। ডিপ্লয় করার সময় আপনাকে বিভিন্ন কনফিগারেশন নির্বাচন করতে হতে পারে, যেমন সেগুলোর জন্য অ্যাক্সেস পারমিশন, রোল, এবং অন্য ডিপেনডেন্সি।


3. AWS Management Console এর মাধ্যমে Lambda ডিপ্লয় করা

AWS Management Console ব্যবহার করে Lambda ফাংশন ডিপ্লয় করা অনেক সহজ এবং দ্রুত। এখানে আমরা একটি Lambda ফাংশন তৈরি করার জন্য কনসোল ইন্টারফেস ব্যবহার করার প্রক্রিয়া আলোচনা করব।

AWS Console এ Lambda ফাংশন ডিপ্লয় করার ধাপ:

  1. AWS Management Console এ লগইন করুন
    প্রথমে AWS Management Console এ লগইন করুন।
  2. Lambda সেবা নির্বাচন করুন
    Console এর সার্চ বারে "Lambda" লিখে Lambda সেবা নির্বাচন করুন।
  3. Create Function
    Lambda ড্যাশবোর্ডে গিয়ে Create function বাটনে ক্লিক করুন।
  4. ফাংশন কনফিগারেশন দিন
    • Author from scratch নির্বাচন করুন।
    • ফাংশনের নাম দিন, যেমন MyLambdaFunction
    • রানটাইম নির্বাচন করুন (যেমন Python 3.x)।
    • Execution role নির্বাচন করুন (নতুন রোল বা পূর্ববর্তী রোল)।
  5. কোড আপলোড করুন
    • কোড লেখার জন্য Inline code editor ব্যবহার করতে পারেন, অথবা .zip ফাইল আপলোড করতে পারেন।
    • কোড আপলোড হয়ে গেলে, Deploy বাটনে ক্লিক করুন।
  6. টেস্ট করুন
    Lambda ফাংশন ডিপ্লয় করার পর, আপনি Test বাটনে ক্লিক করে ফাংশনটি টেস্ট করতে পারবেন। ফাংশনের ইনপুট হিসেবে JSON ইনপুট প্রদান করুন।

সারাংশ

AWS Lambda ফাংশন ডিপ্লয় করার জন্য আপনি তিনটি প্রধান পদ্ধতি ব্যবহার করতে পারেন:

  1. AWS CLI: কমান্ড লাইন থেকে Lambda ফাংশন তৈরি ও আপডেট করার জন্য ব্যবহার হয়।
  2. AWS SAM: Serverless অ্যাপ্লিকেশন তৈরি ও ডিপ্লয় করার জন্য একটি ফ্রেমওয়ার্ক।
  3. AWS Management Console: সহজ এবং দ্রুত Lambda ফাংশন তৈরি ও ডিপ্লয় করার জন্য GUI ইন্টারফেস।

এগুলির মধ্যে আপনি আপনার প্রয়োজন অনুযায়ী যেকোনো পদ্ধতি ব্যবহার করতে পারেন, তবে SAM সাধারণত বড় সার্ভারলেস অ্যাপ্লিকেশন ডিপ্লয় করার জন্য আরও উপযুক্ত।

Content added By

AWS Lambda ফাংশন একটি IAM (Identity and Access Management) Role ব্যবহার করে অন্যান্য AWS সেবার সঙ্গে যোগাযোগ করতে পারে এবং প্রয়োজনীয় কার্য সম্পাদন করতে সক্ষম হয়। এই রোলটি Lambda ফাংশনের Execution Role হিসেবে পরিচিত, এবং এটি ফাংশনটির নিরাপত্তা এবং অ্যাক্সেস কনফিগার করে।

Lambda ফাংশন সঠিকভাবে কাজ করার জন্য AWS সেবা (যেমন S3, DynamoDB, SNS) অ্যাক্সেস করার অনুমতি প্রদান করতে এই IAM Role তৈরি এবং কনফিগার করতে হয়।


Lambda Execution Role কনফিগার করার প্রক্রিয়া

  1. AWS Management Console এ লগইন করুন
  2. IAM সেবা নির্বাচন করুন
    • লগইন করার পর, সার্চ বারে IAM লিখে IAM সেবা নির্বাচন করুন।
  3. Role তৈরি করুন
    • IAM ড্যাশবোর্ডে Roles এ যান এবং তারপর Create role বাটনে ক্লিক করুন।
  4. Role type নির্বাচন করুন
    • Select trusted entity পর্বে, AWS service নির্বাচন করুন এবং এর মধ্যে Lambda সিলেক্ট করুন।
  5. Permission policies নির্বাচন করুন

    • এখানে আপনি যে পরিষেবাগুলির জন্য Lambda ফাংশনকে অনুমতি দিতে চান, তাদের জন্য পলিসি নির্বাচন করতে হবে। কিছু সাধারণ পলিসি হতে পারে:
      • AWSLambdaBasicExecutionRole: Lambda ফাংশনকে CloudWatch Logs এ লগ লেখার অনুমতি দেয়।
      • AmazonS3ReadOnlyAccess: Lambda ফাংশনকে S3 বকেট থেকে ফাইল পড়ার অনুমতি দেয়।
      • AmazonDynamoDBFullAccess: Lambda ফাংশনকে DynamoDB টেবিলের সম্পূর্ণ অ্যাক্সেস দেয়।

    আপনার প্রয়োজন অনুসারে এক বা একাধিক পলিসি নির্বাচন করুন এবং Next: Tags বাটনে ক্লিক করুন।

  6. Role নাম দিন
    • Role name ফিল্ডে একটি নাম দিন, যেমন MyLambdaExecutionRole
    • তারপর Create role বাটনে ক্লিক করুন।

Lambda ফাংশনে Execution Role অ্যাসাইন করা

Lambda ফাংশন তৈরি বা সম্পাদনা করার পর, আপনি যে Execution Role তৈরি করেছেন, সেটি Lambda ফাংশনের জন্য অ্যাসাইন করতে হবে।

  1. Lambda Console এ যান
    • AWS Management Console এ ফিরে যান এবং Lambda সেবা নির্বাচন করুন।
  2. Lambda Function নির্বাচন করুন
    • আপনার তৈরি করা Lambda ফাংশন নির্বাচন করুন।
  3. Configuration ট্যাব নির্বাচন করুন
    • Lambda ফাংশনের ড্যাশবোর্ড থেকে Configuration ট্যাব নির্বাচন করুন।
  4. Permissions সেকশনে Execution Role কনফিগার করুন
    • Permissions সেকশনে গিয়ে, আপনি দেখতে পাবেন Execution role এর অধীনে একটি IAM রোল রয়েছে।
    • যদি আপনি নতুন রোল অ্যাসাইন করতে চান, Edit বাটনে ক্লিক করুন এবং আপনার তৈরি করা Execution role নির্বাচন করুন অথবা নতুন রোল তৈরি করুন।
  5. Save Changes
    • সবকিছু সঠিকভাবে কনফিগার করার পর Save বাটনে ক্লিক করুন।

Lambda Execution Role এর পলিসি

Lambda Execution Role এর জন্য কিছু সাধারণ পলিসি যে কাজগুলো করতে সাহায্য করে তা হলো:

  • AWSLambdaBasicExecutionRole:

    • এটি Lambda ফাংশনকে CloudWatch Logs এ লগ রাইট করার অনুমতি দেয়। সাধারণত Lambda ফাংশনগুলোর জন্য এটি একটি মৌলিক এবং অপরিহার্য পলিসি।

    উদাহরণ:

    {
        "Version": "2012-10-17",
        "Statement": [
            {
                "Effect": "Allow",
                "Action": "logs:*",
                "Resource": "arn:aws:logs:REGION:ACCOUNT_ID:log-group:/aws/lambda/*"
            }
        ]
    }
    
  • AmazonS3FullAccess:

    • যদি আপনার Lambda ফাংশনকে S3 বকেটের সম্পূর্ণ অ্যাক্সেস (পড়া, লেখা, মুছে ফেলা ইত্যাদি) দিতে চান, তবে এই পলিসি ব্যবহার করতে পারেন।

    উদাহরণ:

    {
        "Version": "2012-10-17",
        "Statement": [
            {
                "Effect": "Allow",
                "Action": "s3:*",
                "Resource": "arn:aws:s3:::bucket-name/*"
            }
        ]
    }
    
  • AmazonDynamoDBFullAccess:

    • DynamoDB টেবিলের সাথে কাজ করার জন্য এই পলিসি প্রয়োজন। এর মাধ্যমে Lambda ফাংশনটি DynamoDB এ ডেটা পড়তে বা লিখতে পারবে।

    উদাহরণ:

    {
        "Version": "2012-10-17",
        "Statement": [
            {
                "Effect": "Allow",
                "Action": "dynamodb:*",
                "Resource": "arn:aws:dynamodb:REGION:ACCOUNT_ID:table/TABLE_NAME"
            }
        ]
    }
    

IAM Role এর সুরক্ষা

IAM Role তৈরি করার সময় কিছু গুরুত্বপূর্ণ নিরাপত্তা বিষয় লক্ষ্য রাখা উচিত:

  1. ন্যূনতম অনুমতি (Least Privilege): Lambda ফাংশনের জন্য যে সব সেবার প্রয়োজন, সেই সেবার জন্যই শুধু অনুমতি দিন। অপ্রয়োজনীয় সেবার অ্যাক্সেস প্রদান করবেন না।
  2. Role এবং Policies পর্যালোচনা করা: সময় সময়ে IAM রোল এবং পলিসি পর্যালোচনা করুন, এবং দেখুন ফাংশনের প্রয়োজন অনুযায়ী কোনো অতিরিক্ত অ্যাক্সেস অনুমতি দেওয়া হয়েছে কিনা।
  3. AWS CloudTrail ব্যবহার করা: সুরক্ষিতভাবে লগ রাখা এবং IAM Role এর কার্যক্রম ট্র্যাক করা অত্যন্ত গুরুত্বপূর্ণ। CloudTrail এর মাধ্যমে আপনি যে কোনো API কলের লগ রাখতে পারেন।

সারাংশ

AWS Lambda ফাংশনকে কার্যকর করতে Lambda Execution Role অত্যন্ত গুরুত্বপূর্ণ, যা AWS সেবাগুলোর সাথে যোগাযোগ করার জন্য প্রয়োজনীয় অনুমতি প্রদান করে। IAM Role তৈরি এবং সেটআপ করার মাধ্যমে আপনি Lambda ফাংশনের নিরাপত্তা ও অ্যাক্সেস কনফিগার করতে পারেন, যাতে ফাংশনটি সঠিকভাবে এবং সুরক্ষিতভাবে কাজ করে।

Content added By

AWS Lambda ফাংশন তৈরি করার সময়, আপনাকে কিছু গুরুত্বপূর্ণ কনফিগারেশন সেট করতে হয় যা ফাংশনের পারফরম্যান্স এবং কার্যকারিতা প্রভাবিত করে। এর মধ্যে রয়েছে মেমোরি, টাইমআউট, এবং ভলিউম কনফিগারেশন। এই কনফিগারেশনগুলি Lambda ফাংশনের কার্যকারিতা নির্ধারণে বড় ভূমিকা পালন করে, বিশেষ করে যখন আপনি হাই-পারফরম্যান্স এবং স্কেলেবিলিটি প্রয়োজন হয়।


মেমোরি কনফিগারেশন

AWS Lambda ফাংশনের মেমোরি কনফিগারেশন সেট করে আপনি কতটুকু রিসোর্স ফাংশনটি ব্যবহার করতে পারবেন। Lambda ফাংশনকে রান করার সময়, আপনি এক্সিকিউশন টাইম এবং মেমোরির আকার কনফিগার করতে পারেন।

মেমোরি কনফিগারেশনের প্রভাব

  • পারফরম্যান্স: ফাংশনের মেমোরি সাইজ বৃদ্ধি করলে সাধারণত পারফরম্যান্স বৃদ্ধি পায়, কারণ এটি CPU সাইকেল বাড়ানোর মাধ্যমে আরও দ্রুত কাজ করতে সক্ষম হয়।
  • মূল্য: মেমোরি বাড়ানোর সাথে সাথে Lambda ফাংশনের রানটাইম খরচও বৃদ্ধি পায়, কারণ AWS Lambda ফাংশনের জন্য প্রতি মিলিসেকেন্ডে মেমোরি ব্যবহারের জন্য চার্জ করে।

মেমোরি কনফিগারেশন সেট করা

AWS Lambda ফাংশন তৈরি বা সম্পাদনা করার সময় আপনি মেমোরি কনফিগারেশন নির্ধারণ করতে পারেন। এটি 128 MB থেকে 10,240 MB (10 GB) পর্যন্ত সেট করা যায়। সাধারণত, মেমোরি সাইজ বৃদ্ধির সাথে ফাংশনের কর্মক্ষমতা উন্নত হয়, তবে খরচও বাড়ে।

  1. Lambda ফাংশন তৈরি করার সময়, Memory (MB) সেকশনে মেমোরি সাইজ নির্ধারণ করুন।
  2. আপনি মেমোরি সাইজ ও সময়ের মধ্যে একটি ভাল ব্যালেন্স করতে পারেন, যাতে অপটিমাইজড পারফরম্যান্স পাওয়া যায়।

টাইমআউট কনফিগারেশন

AWS Lambda ফাংশন যখন চালানো হয়, তখন একটি নির্দিষ্ট সময়ের জন্য এটি রান করতে পারে। যদি ফাংশনটি নির্ধারিত সময়ের মধ্যে কাজ সম্পন্ন না করে, তবে এটি টাইমআউট হয়ে যাবে এবং এর প্রক্রিয়া থেমে যাবে। টাইমআউট কনফিগারেশন Lambda ফাংশনের নির্দিষ্ট ম্যাক্সিমাম এক্সিকিউশন টাইম নির্ধারণ করে।

টাইমআউটের প্রভাব

  • পারফরম্যান্স: টাইমআউটের সময় বেশি রাখলে বড় এবং দীর্ঘক্ষণের কাজগুলো সম্পন্ন করা সম্ভব হবে। তবে অতিরিক্ত সময় দেওয়ার ফলে খরচ বেড়ে যেতে পারে।
  • ব্যবহার: আপনি যখন একাধিক মাইক্রোসার্ভিস বা API কল করে কাজ করছেন, তখন টাইমআউট বেশি নির্ধারণ করা প্রয়োজন।

টাইমআউট কনফিগারেশন সেট করা

Lambda ফাংশনের টাইমআউট কনফিগারেশন সাধারণত 1 সেকেন্ড থেকে 15 মিনিট (900 সেকেন্ড) পর্যন্ত দেওয়া যায়। যদি আপনার ফাংশনটি দীর্ঘ সময় নেয়, যেমন বড় ডেটাবেস কোয়েরি বা অন্য কোনো প্রক্রিয়া সম্পন্ন করতে, তবে টাইমআউট টাইম বাড়ানো উচিত।

  1. Lambda ফাংশন সম্পাদনা করার সময় Timeout সেকশনে টাইমআউট সময় সেট করুন।
  2. এই সময়ের মধ্যে Lambda ফাংশনটির কাজ শেষ না হলে, এটি Execution Timeout হয়ে যাবে।

ভলিউম কনফিগারেশন

AWS Lambda ফাংশন সাধারণত Ephemeral Storage (অস্থায়ী স্টোরেজ) ব্যবহার করে, যা প্রতিটি ফাংশনের জন্য 512 MB ডিফল্ট স্টোরেজ থাকে। তবে, আপনার ফাংশন যদি আরো বেশি ডেটা প্রক্রিয়া করতে চায় বা কোনো ফাইল সিস্টেমে ডেটা সংরক্ষণ করতে চায়, তাহলে Lambda ফাংশনে Amazon Elastic File System (EFS) ইন্টিগ্রেট করা যেতে পারে।

ভলিউম কনফিগারেশন সাপোর্ট

  1. Ephemeral Storage: AWS Lambda ফাংশনের জন্য 512 MB এর ডিফল্ট স্টোরেজ দেওয়া থাকে, যা শুধুমাত্র এক্সিকিউশনের সময় পর্যন্ত টিকে থাকে। ফাংশন এক্সিকিউট হওয়ার পরে এই স্টোরেজটি ক্লিয়ার হয়ে যায়।
  2. Amazon EFS (Elastic File System): যদি আপনার Lambda ফাংশনটি বড় ফাইল বা ডেটা স্টোরেজের সাথে কাজ করতে চায়, তবে আপনি Amazon EFS ব্যবহার করতে পারেন। EFS আপনাকে অব্যাহত এবং শেয়ারযোগ্য স্টোরেজ প্রদান করে, যা Lambda ফাংশন এবং অন্যান্য AWS রিসোর্সের মধ্যে শেয়ার করা যায়।

ভলিউম কনফিগারেশন সেট করা

Lambda ফাংশনের ভলিউম কনফিগারেশন করার জন্য:

  1. Ephemeral Storage কনফিগারেশন:
    Lambda ফাংশনের Temporary storage সেকশনে 512 MB থেকে 10 GB পর্যন্ত সাইজ বাড়ানো যেতে পারে। এটি শুধুমাত্র ফাংশনের রানটাইমে অ্যাক্সেসযোগ্য থাকবে এবং ফাংশন শেষ হলে ডাটা মুছে যাবে।
  2. Amazon EFS কনফিগারেশন:
    আপনি যদি EFS কনফিগার করতে চান, তবে Lambda ফাংশনে EFS মাউন্ট পয়েন্ট যুক্ত করতে হবে। EFS কনফিগারেশন করতে:
    • EFS তৈরি করুন এবং একটি মাউন্ট পয়েন্ট তৈরি করুন।
    • Lambda ফাংশনে EFS ডেটা শেয়ার করতে VPC এবং EFS কনফিগারেশন সেট করুন।
    • মাউন্ট পয়েন্টের মাধ্যমে Lambda ফাংশন EFS থেকে ডেটা পড়তে এবং লিখতে পারবে।

সারাংশ

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

Content added By
Promotion

Are you sure to start over?

Loading...