প্রতিদিনের ছবি: ল্যাব 6—ওয়ার্কফ্লো সহ অর্কেস্ট্রেশন

1. ওভারভিউ

পূর্ববর্তী ল্যাবগুলিতে, আপনি Pic-a-Daily অ্যাপের একটি ইভেন্ট-চালিত সংস্করণ তৈরি করেছেন যা চিত্র বিশ্লেষণ পরিষেবার জন্য একটি Google ক্লাউড স্টোরেজ ট্রিগার ক্লাউড ফাংশন ব্যবহার করে, থাম্বনেইল পরিষেবার জন্য Pub/Sub-এর মাধ্যমে একটি GCS ট্রিগার ক্লাউড রান কন্টেইনার এবং ক্লাউড রানে ইমেজ গারবেজ কালেক্টর পরিষেবা ট্রিগার করতে Eventarc। এছাড়াও একটি ক্লাউড শিডিউলার ট্রিগার করা কোলাজ পরিষেবা ছিল:

d93345bfc235f81e.png

এই ল্যাবে, আপনি অ্যাপটির একটি অর্কেস্ট্রেটেড সংস্করণ তৈরি করবেন। সিস্টেমের মধ্য দিয়ে প্রবাহিত বিভিন্ন ধরণের ইভেন্টের পরিবর্তে, আপনি নিম্নোক্তভাবে অর্কেস্ট্রেট এবং কল করার জন্য ওয়ার্কফ্লো ব্যবহার করবেন:

b763efcbf5589747.png

আপনি কি শিখবেন

  • অ্যাপ ইঞ্জিন
  • ক্লাউড ফায়ারস্টোর
  • ক্লাউড ফাংশন
  • ক্লাউড রান
  • কর্মপ্রবাহ

2. সেটআপ এবং প্রয়োজনীয়তা

স্ব-গতিসম্পন্ন পরিবেশ সেটআপ

  1. ক্লাউড কনসোলে সাইন ইন করুন এবং একটি নতুন প্রকল্প তৈরি করুন বা বিদ্যমান একটি পুনরায় ব্যবহার করুন৷ (আপনার যদি ইতিমধ্যেই একটি Gmail বা Google Workspace অ্যাকাউন্ট না থাকে, তাহলে আপনাকে অবশ্যই একটি তৈরি করতে হবে।)

96a9c957bc475304.png

b9a10ebdf5b5a448.png

a1e3c01a38fa61c2.png

প্রজেক্ট আইডিটি মনে রাখবেন, সমস্ত Google ক্লাউড প্রকল্প জুড়ে একটি অনন্য নাম (উপরের নামটি ইতিমধ্যে নেওয়া হয়েছে এবং আপনার জন্য কাজ করবে না, দুঃখিত!)। এটি পরে এই কোডল্যাবে PROJECT_ID হিসাবে উল্লেখ করা হবে।

  1. এর পরে, Google ক্লাউড সংস্থানগুলি ব্যবহার করার জন্য আপনাকে ক্লাউড কনসোলে বিলিং সক্ষম করতে হবে৷

এই কোডল্যাবের মাধ্যমে চালানোর জন্য খুব বেশি খরচ করা উচিত নয়, যদি কিছু থাকে। "ক্লিনিং আপ" বিভাগে যে কোনও নির্দেশাবলী অনুসরণ করতে ভুলবেন না যা আপনাকে কীভাবে সংস্থানগুলি বন্ধ করতে হবে তা পরামর্শ দেয় যাতে আপনি এই টিউটোরিয়ালের বাইরে বিলিং করতে না পারেন৷ Google ক্লাউডের নতুন ব্যবহারকারীরা $300 USD বিনামূল্যের ট্রায়াল প্রোগ্রামের জন্য যোগ্য৷

ক্লাউড শেল শুরু করুন

যদিও Google ক্লাউড আপনার ল্যাপটপ থেকে দূরবর্তীভাবে পরিচালিত হতে পারে, এই কোডল্যাবে আপনি Google ক্লাউড শেল ব্যবহার করবেন, একটি কমান্ড লাইন পরিবেশ যা ক্লাউডে চলছে।

GCP কনসোল থেকে উপরের ডানদিকে টুলবারে ক্লাউড শেল আইকনে ক্লিক করুন:

bce75f34b2c53987.png

পরিবেশের ব্যবস্থা করতে এবং সংযোগ করতে এটি শুধুমাত্র কয়েক মুহূর্ত নিতে হবে। এটি সমাপ্ত হলে, আপনি এই মত কিছু দেখতে হবে:

f6ef2b5f13479f3a.png

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

3. কর্মপ্রবাহের ভূমিকা

90fcd42d556e310e.jpeg

সার্ভারবিহীন ওয়ার্কফ্লো তৈরি করতে আপনি ওয়ার্কফ্লো ব্যবহার করতে পারেন যা আপনার সংজ্ঞায়িত ক্রমানুসারে সার্ভারহীন কাজগুলির একটি সিরিজকে একসাথে লিঙ্ক করে। আপনি Google ক্লাউডের API এর শক্তি, ক্লাউড ফাংশন এবং ক্লাউড রানের মতো সার্ভারহীন পণ্য এবং নমনীয় সার্ভারহীন অ্যাপ্লিকেশন তৈরি করতে বাহ্যিক API তে কল করতে পারেন।

আপনি একজন অর্কেস্ট্রেটরের কাছ থেকে আশা করতে পারেন, ওয়ার্কফ্লো আপনাকে YAML/JSON ভিত্তিক ওয়ার্কফ্লো সংজ্ঞা ভাষায় আপনার ব্যবসার যুক্তির প্রবাহকে সংজ্ঞায়িত করতে দেয় এবং সেই প্রবাহগুলিকে ট্রিগার করার জন্য একটি Workflows Execution API এবং Workflows UI প্রদান করে।

এটি এই অন্তর্নির্মিত এবং কনফিগারযোগ্য বৈশিষ্ট্যগুলির সাথে একটি নিছক অর্কেস্ট্রেটরের চেয়ে বেশি:

  • নমনীয় পুনঃপ্রচেষ্টা এবং পদক্ষেপগুলির নির্ভরযোগ্য সম্পাদনের জন্য ধাপগুলির মধ্যে ত্রুটি পরিচালনা।
  • আঠালো-কোড এড়ানোর জন্য JSON পার্সিং এবং ভেরিয়েবল ধাপের মধ্যে পাসিং।
  • সিদ্ধান্তের জন্য অভিব্যক্তি সূত্র শর্তসাপেক্ষ পদক্ষেপ কার্যকর করার অনুমতি দেয়।
  • মডুলার এবং পুনরায় ব্যবহারযোগ্য ওয়ার্কফ্লোগুলির জন্য সাবওয়ার্কফ্লো।
  • বাহ্যিক পরিষেবাগুলির জন্য সমর্থন Google ক্লাউডের বাইরে পরিষেবাগুলির অর্কেস্ট্রেশনের অনুমতি দেয়৷
  • Google ক্লাউড এবং নিরাপদ পদক্ষেপ সম্পাদনের জন্য বহিরাগত পরিষেবাগুলির জন্য প্রমাণীকরণ সমর্থন।
  • Google ক্লাউড পরিষেবাগুলির সংযোগকারীগুলি যেমন Pub/Sub, Firestore, Tasks, সিক্রেট ম্যানেজার সহজে একীকরণের জন্য৷

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

4. APIs সক্ষম করুন৷

এই ল্যাবে, আপনি ক্লাউড ফাংশন এবং ক্লাউড রান পরিষেবাগুলিকে ওয়ার্কফ্লোগুলির সাথে সংযুক্ত করবেন৷ আপনি অ্যাপ ইঞ্জিন, ক্লাউড বিল্ড, ভিশন API এবং অন্যান্য পরিষেবাগুলিও ব্যবহার করবেন৷

ক্লাউড শেল-এ, নিশ্চিত করুন যে সমস্ত প্রয়োজনীয় পরিষেবা সক্রিয় আছে:

gcloud services enable \
  appengine.googleapis.com \
  cloudbuild.googleapis.com \
  cloudfunctions.googleapis.com \
  compute.googleapis.com \
  firestore.googleapis.com \
  run.googleapis.com \
  vision.googleapis.com \
  workflows.googleapis.com \

কিছু সময় পরে, আপনি সফলভাবে অপারেশন শেষ দেখতে হবে:

Operation "operations/acf.5c5ef4f6-f734-455d-b2f0-ee70b5a17322" finished successfully.

5. কোড পান

কোডটি পান, যদি আপনি ইতিমধ্যে পূর্ববর্তী কোড ল্যাবগুলিতে না থাকেন:

git clone https://github.com/GoogleCloudPlatform/serverless-photosharing-workshop

আপনার কাছে নিম্নলিখিত ফোল্ডার কাঠামো থাকবে যা এই ল্যাবের জন্য প্রাসঙ্গিক:

frontend
 |
workflows
 |
 ├── functions
 ├── |── trigger-workflow
 ├── |── vision-data-transform
 ├── services
 ├── |── collage
 ├── |── thumbnails
 ├── workflows.yaml

এই প্রাসঙ্গিক ফোল্ডার:

  • frontend অ্যাপ ইঞ্জিন ফ্রন্টএন্ড রয়েছে যা আমরা ল্যাব 4 থেকে পুনরায় ব্যবহার করব।
  • functions জন্য তৈরি করা ক্লাউড ফাংশনগুলি রয়েছে৷
  • services ওয়ার্কফ্লো-এর জন্য পরিবর্তিত ক্লাউড রান পরিষেবা রয়েছে৷
  • workflows.yaml হল ওয়ার্কফ্লো সংজ্ঞা ফাইল।

6. ওয়ার্কফ্লোস YAML অন্বেষণ করুন

workflows.yaml একাধিক ধাপে ওয়ার্কফ্লোকে সংজ্ঞায়িত করে। এটি আরও ভালভাবে বোঝার জন্য এর মধ্য দিয়ে যাওয়া যাক।

ওয়ার্কফ্লো শুরুতে, কিছু প্যারামিটার আছে যেগুলো পাস করা হয়। সেগুলো দুটি ক্লাউড ফাংশন দ্বারা পাস করা হবে যা ওয়ার্কফ্লোকে ট্রিগার করবে। আমরা পরে এই ফাংশনগুলিতে পৌঁছব তবে ওয়ার্কফ্লোগুলি এভাবে শুরু হয়:

d44a5e18aa9d4660.png

YAML-এ, আপনি দেখতে পাচ্ছেন যে এই প্যারামিটারগুলি init ধাপে ভেরিয়েবলগুলিতে বরাদ্দ করা হয়েছে যেমন ফাইল এবং বাকেটের নামগুলি ইভেন্টটিকে ট্রিগার করে এবং কিছু ক্লাউড ফাংশন এবং ক্লাউড রান পরিষেবাগুলির URL যা ওয়ার্কফ্লো কল করবে:

main:
  params: [args]
  steps:
    - init:
        assign:
          - file: ${args.file}
          - bucket: ${args.bucket}
          - gsUri: ${"gs://" + bucket + "/" + file}
          - projectId: ${sys.get_env("GOOGLE_CLOUD_PROJECT_ID")}
          - urls: ${args.urls}

এর পরে, ওয়ার্কফ্লো ইভেন্টের ধরন পরীক্ষা করে। এখানে 2টি ইভেন্টের ধরন সমর্থিত: object.finalize (ক্লাউড স্টোরেজ বালতিতে একটি ফাইল সংরক্ষণ করা হলে নির্গত হয়) এবং object.delete (ফাইল মুছে ফেলা হলে নির্গত হয়)। অন্য কিছু এমন একটি ঘটনা উত্থাপন করবে যা সমর্থিত ব্যতিক্রম নয়।

dd1f450983655619.png

YAML ওয়ার্কফ্লো সংজ্ঞায় এই ধাপটি, যেখানে আমরা ফাইল স্টোরেজ ইভেন্টের ধরন পরীক্ষা করি:

    - eventTypeSwitch:
        switch:
            - condition: ${args.eventType == "google.storage.object.finalize"}
              next: imageAnalysisCall
            - condition: ${args.eventType == "google.storage.object.delete"}
              next: pictureGarbageCollectionGCS
    - eventTypeNotSupported:
        raise: ${"eventType " + args.eventType + " is not supported"}
        next: end

লক্ষ্য করুন কিভাবে ওয়ার্কফ্লোস সুইচের বিবৃতি এবং ব্যতিক্রম হ্যান্ডলিংকে সমর্থন করে, সুইচ নির্দেশনা এবং এর বিভিন্ন শর্ত সহ, এবং ইভেন্টটি স্বীকৃত না হলে একটি ত্রুটি উত্থাপন করার নির্দেশনা বৃদ্ধি করে।

এর পরে, আসুন imageAnalysisCall দেখে নেওয়া যাক। এটি চিত্র বিশ্লেষণ করার জন্য Vision API-কে কল করতে, ছবিতে স্বীকৃত জিনিসগুলির লেবেলগুলি সাজানোর জন্য Vision API প্রতিক্রিয়া ডেটা রূপান্তর করতে, প্রভাবশালী রঙগুলি বেছে নিতে, ছবিটি প্রদর্শনের জন্য নিরাপদ কিনা তা পরীক্ষা করতে ওয়ার্কফ্লোস থেকে কলের একটি সিরিজ। তারপর মেটাডেটা ক্লাউড ফায়ারস্টোরে সংরক্ষণ করুন।

মনে রাখবেন যে ভিশন ট্রান্সফর্ম ক্লাউড ফাংশনগুলি (যা আমরা পরে স্থাপন করব) ছাড়া ওয়ার্কফ্লোতে সবকিছু করা হয়:

ca2ad16b9cbb436.png

YAML-এ পদক্ষেপগুলি এইভাবে দেখায়:

    - imageAnalysisCall:
        call: http.post
        args:
          url: https://vision.googleapis.com/v1/images:annotate
          headers:
            Content-Type: application/json
          auth:
            type: OAuth2
          body:
            requests:
            - image:
                source:
                  gcsImageUri: ${gsUri}
              features:
              - type: LABEL_DETECTION
              - type: SAFE_SEARCH_DETECTION
              - type: IMAGE_PROPERTIES
        result: imageAnalysisResponse
    - transformImageAnalysisData:
        call: http.post
        args:
          url: ${urls.VISION_DATA_TRANSFORM_URL}
          auth:
            type: OIDC
          body: ${imageAnalysisResponse.body}
        result: imageMetadata
    - checkSafety:
        switch:
          - condition: ${imageMetadata.body.safe == true}
            next: storeMetadata
        next: end
    - storeMetadata:
        call: http.request
        args:
          url: ${"https://firestore.googleapis.com/v1/projects/" + projectId + "/databases/(default)/documents/pictures/" + file + "?updateMask.fieldPaths=color&updateMask.fieldPaths=labels&updateMask.fieldPaths=created"}
          auth:
            type: OAuth2
          method: PATCH
          body:
            name: ${"projects/" + projectId + "/databases/(default)/documents/pictures/" + file}
            fields:
              color:
                stringValue: ${imageMetadata.body.color}
              created:
                timestampValue: ${imageMetadata.body.created}
              labels:
                arrayValue:
                  values: ${imageMetadata.body.labels}
        result: storeMetadataResponse

একবার ইমেজ বিশ্লেষণ করা হলে, পরবর্তী দুটি ধাপ হল ইমেজের থাম্বনেইল এবং সাম্প্রতিক ইমেজের একটি কোলাজ তৈরি করা। এটি 2টি ক্লাউড রান পরিষেবা স্থাপন করে এবং thumbnailCall এবং collageCall ধাপ থেকে তাদের কল করার মাধ্যমে করা হয়:

76f9179323c3144.png

YAML-এ পদক্ষেপ:

   - thumbnailCall:
        call: http.post
        args:
          url: ${urls.THUMBNAILS_URL}
          auth:
            type: OIDC
          body:
              gcsImageUri: ${gsUri}
        result: thumbnailResponse
    - collageCall:
        call: http.get
        args:
          url: ${urls.COLLAGE_URL}
          auth:
            type: OIDC
        result: collageResponse

finalizeCompleted ধাপে প্রতিটি পরিষেবা থেকে স্ট্যাটাস কোড ফেরত দিয়ে সম্পাদনের এই শাখাটি শেষ হয়:

    - finalizeCompleted:
        return:
          imageAnalysis: ${imageAnalysisResponse.code}
          storeMetadata: ${storeMetadataResponse.code}
          thumbnail: ${thumbnailResponse.code}
          collage: ${collageResponse.code}

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

f172379274dcb3c2.png

YAML-এ পদক্ষেপ:

    - pictureGarbageCollectionGCS:
        try:
          call: http.request
          args:
            url: ${"https://storage.googleapis.com/storage/v1/b/thumbnails-" + projectId + "/o/" + file}
            auth:
              type: OAuth2
            method: DELETE
          result: gcsDeletionResult
        except:
          as: e
          steps:
              - dummyResultInOutVar:
                  assign:
                      - gcsDeletionResult:
                          code: 200
                          body: "Workaround for empty body response"
    - pictureGarbageCollectionFirestore:
        call: http.request
        args:
          url: ${"https://firestore.googleapis.com/v1/projects/" + projectId + "/databases/(default)/documents/pictures/" + file}
          auth:
            type: OAuth2
          method: DELETE
        result: firestoreDeletionResult

প্রতিটি ধাপ থেকে ফলাফল/কোড ফেরত দিয়ে মুছে ফেলা শাখা শেষ হয়:

    - deleteCompleted:
        return:
          gcsDeletion: ${gcsDeletionResult}
          firestoreDeletion: ${firestoreDeletionResult.code}

নিম্নলিখিত ধাপে, আমরা ওয়ার্কফ্লোগুলির সমস্ত বাহ্যিক নির্ভরতা তৈরি করব: বালতি, ক্লাউড ফাংশন, ক্লাউড রান পরিষেবা এবং ফায়ারস্টোর ডাটাবেস৷

7. বালতি তৈরি করুন

ছবিগুলির জন্য আপনার 2টি বালতি প্রয়োজন: 1টি আসল উচ্চ-রেজোলিউশনের ছবিগুলি সংরক্ষণ করতে এবং 1টি ছবির থাম্বনেলগুলি সংরক্ষণ করতে৷

gsutil টুল ব্যবহার করে ব্যবহারকারীদের ছবি আপলোড করার জন্য অভিন্ন অ্যাক্সেস সহ একটি পাবলিক আঞ্চলিক (এই ক্ষেত্রে ইউরোপে) বালতি তৈরি করুন:

export BUCKET_PICTURES=uploaded-pictures-${GOOGLE_CLOUD_PROJECT}
gsutil mb -l EU gs://${BUCKET_PICTURES}
gsutil uniformbucketlevelaccess set on gs://${BUCKET_PICTURES}
gsutil iam ch allUsers:objectViewer gs://${BUCKET_PICTURES}

থাম্বনেইলের জন্য অন্য পাবলিক আঞ্চলিক বালতি তৈরি করুন:

export BUCKET_THUMBNAILS=thumbnails-${GOOGLE_CLOUD_PROJECT}
gsutil mb -l EU gs://${BUCKET_THUMBNAILS}
gsutil uniformbucketlevelaccess set on gs://${BUCKET_THUMBNAILS}
gsutil iam ch allUsers:objectViewer gs://${BUCKET_THUMBNAILS}

আপনি ক্লাউড কনসোলের ক্লাউড স্টোরেজ বিভাগে গিয়ে বালতি তৈরি এবং সর্বজনীন কিনা তা দুবার চেক করতে পারেন:

15063936edd72f06.png

8. ভিশন ডেটা ট্রান্সফর্ম (ক্লাউড ফাংশন)

Workflows.yaml শুরু হয় init , eventTypeSwitch , eventTypeNotSupported ধাপ দিয়ে। এগুলি নিশ্চিত করে যে বালতি থেকে আগত ইভেন্টগুলি সঠিক পদক্ষেপে রুট করা হয়েছে৷

object.finalize ইভেন্টের জন্য, imageAnalysisCall ধাপটি তৈরি করা ছবির মেটাডেটা বের করতে Vision API-কে একটি কল করে। এই সমস্ত পদক্ষেপ কর্মপ্রবাহের মধ্যে সম্পন্ন করা হয়:

daaed43a22d2b0d3.png

এর পরে, আমরা Firestore-এ সংরক্ষণ করতে পারার আগে, Vision API থেকে ফিরে আসা ডেটা রূপান্তর করতে হবে। আরও নির্দিষ্টভাবে, আমাদের প্রয়োজন:

  • ছবির জন্য ফিরে আসা লেবেল তালিকা করুন.
  • ছবির প্রভাবশালী রঙ পুনরুদ্ধার করুন.
  • ছবি নিরাপদ কিনা তা নির্ধারণ করুন।

এটি একটি ক্লাউড ফাংশনের কোডে করা হয় এবং ওয়ার্কফ্লোগুলি কেবল এই ফাংশনটিকে কল করে:

5e120e70c67779cd.png

কোড অন্বেষণ

ক্লাউড ফাংশনকে vision-data-transform বলা হয়। আপনি index.js- এ এর সম্পূর্ণ কোড চেক করতে পারেন। আপনি দেখতে পাচ্ছেন, এই ফাংশনের একমাত্র উদ্দেশ্য হল JSON থেকে JSON রূপান্তর করা, যাতে Firestore-এ ছবির মেটাডেটা সুবিধাজনকভাবে সংরক্ষণ করা যায়।

ক্লাউড ফাংশনে স্থাপন করুন

ফোল্ডারে নেভিগেট করুন:

cd workflows/functions/vision-data-transform/nodejs

আপনার পছন্দের অঞ্চল সেট করুন:

export REGION=europe-west1
gcloud config set functions/region ${REGION}

এর সাথে ফাংশনটি স্থাপন করুন:

export SERVICE_NAME=vision-data-transform
gcloud functions deploy ${SERVICE_NAME} \
  --source=. \
  --runtime nodejs10 \
  --entry-point=vision_data_transform \
  --trigger-http \
  --allow-unauthenticated

একবার ফাংশনটি স্থাপন করা হলে, Workflows transformImageAnalysisData ধাপটি Vision API ডেটা ট্রান্সফরমেশন করতে এই ফাংশনটিকে কল করতে সক্ষম হবে।

9. ডাটাবেস প্রস্তুত করুন

ওয়ার্কফ্লোতে পরবর্তীটি হল ইমেজ ডেটা থেকে ছবির নিরাপত্তা পরীক্ষা করা এবং তারপরে ক্লাউড ফায়ারস্টোর ডাটাবেসে ভিশন এপিআই দ্বারা প্রত্যাবর্তিত ছবি সম্পর্কিত তথ্য সংরক্ষণ করা, একটি দ্রুত, সম্পূর্ণরূপে পরিচালিত, সার্ভারহীন, ক্লাউড-নেটিভ NoSQL ডকুমেন্ট ডাটাবেস:

6624c616bc7cd97f.png

এই দুটিই ওয়ার্কফ্লোতে করা হয় কিন্তু কাজ করার জন্য আপনাকে মেটাডেটা সংরক্ষণের জন্য Firestore ডাটাবেস তৈরি করতে হবে।

প্রথমে, আপনি যে অঞ্চলে ফায়ারস্টোর ডাটাবেস চান সেখানে একটি অ্যাপ ইঞ্জিন অ্যাপ তৈরি করুন (ফায়ারস্টোরের জন্য একটি প্রয়োজনীয়তা):

export REGION_FIRESTORE=europe-west2
gcloud app create --region=${REGION_FIRESTORE}

এরপরে, একই অঞ্চলে ফায়ারস্টোর ডাটাবেস তৈরি করুন:

gcloud firestore databases create --region=${REGION_FIRESTORE}

নথিগুলি আমাদের সংগ্রহে প্রোগ্রাম্যাটিকভাবে তৈরি করা হবে এবং এতে 4টি ক্ষেত্র থাকবে:

  • নাম (স্ট্রিং): আপলোড করা ছবির ফাইলের নাম, যা নথির কীও
  • লেবেল (স্ট্রিংগুলির অ্যারে): ভিশন API দ্বারা স্বীকৃত আইটেমগুলির লেবেল৷
  • রঙ (স্ট্রিং): প্রভাবশালী রঙের হেক্সাডেসিমেল রঙের কোড (যেমন #ab12ef)
  • তৈরি করা হয়েছে (তারিখ): এই ছবির মেটাডেটা কখন সংরক্ষণ করা হয়েছিল তার টাইমস্ট্যাম্প
  • থাম্বনেইল (বুলিয়ান): একটি ঐচ্ছিক ক্ষেত্র যা উপস্থিত থাকবে এবং এই ছবির জন্য একটি থাম্বনেইল চিত্র তৈরি করা হলে তা সত্য হবে

থাম্বনেইল উপলব্ধ ছবিগুলি খুঁজে পেতে এবং তৈরির তারিখ বরাবর সাজানোর জন্য আমরা Firestore-এ অনুসন্ধান করব, আমাদের একটি অনুসন্ধান সূচক তৈরি করতে হবে। আপনি নিম্নলিখিত কমান্ড দিয়ে সূচক তৈরি করতে পারেন:

gcloud firestore indexes composite create --collection-group=pictures \
  --field-config field-path=thumbnail,order=descending \
  --field-config field-path=created,order=descending

নোট করুন যে সূচক তৈরি হতে 10 মিনিট বা তার বেশি সময় লাগতে পারে।

একবার সূচী তৈরি হয়ে গেলে, আপনি এটি ক্লাউড কনসোলে দেখতে পারেন:

43af1f5103bf423.png

ওয়ার্কফ্লো storeMetadata স্টেপ এখন ফায়ারস্টোরে ইমেজ মেটাডেটা সংরক্ষণ করতে সক্ষম হবে।

10. থাম্বনেইল পরিষেবা (ক্লাউড রান)

শৃঙ্খলে পরবর্তী একটি চিত্রের থাম্বনেইল তৈরি করা হয়। এটি একটি ক্লাউড রান পরিষেবার কোডে করা হয় এবং ওয়ার্কফ্লো এই পরিষেবাটিকে thumbnailCall ধাপে কল করে:

84d987647f082b53.png

কোড অন্বেষণ

ক্লাউড রান পরিষেবাটিকে thumbnails বলা হয়। আপনি index.js- এ এর সম্পূর্ণ কোড চেক করতে পারেন।

কন্টেইনার ইমেজ তৈরি ও প্রকাশ করুন

ক্লাউড রান কন্টেইনার চালায় তবে আপনাকে প্রথমে কন্টেইনার ইমেজ তৈরি করতে হবে ( Dockerfile সংজ্ঞায়িত)। Google ক্লাউড বিল্ড কনটেইনার ইমেজ তৈরি করতে এবং তারপর Google কন্টেইনার রেজিস্ট্রিতে হোস্ট করতে ব্যবহার করা যেতে পারে।

ফোল্ডারে নেভিগেট করুন:

cd workflows/services/thumbnails/nodejs

নির্মাণ:

export SERVICE_SRC=thumbnails
export SERVICE_NAME=${SERVICE_SRC}-service
gcloud builds submit \
  . \
  --tag gcr.io/${GOOGLE_CLOUD_PROJECT}/${SERVICE_NAME}

এক বা দুই মিনিট পরে, বিল্ডটি সফল হওয়া উচিত এবং কন্টেইনারটি Google কন্টেইনার রেজিস্ট্রিতে স্থাপন করা হবে৷

ক্লাউড রানে স্থাপন করুন

কিছু প্রয়োজনীয় ভেরিয়েবল এবং কনফিগারেশন সেট করুন:

export BUCKET_THUMBNAILS=thumbnails-${GOOGLE_CLOUD_PROJECT}
export REGION=europe-west1
gcloud config set run/region ${REGION}
gcloud config set run/platform managed

নিম্নলিখিত কমান্ড দিয়ে স্থাপন করুন:

gcloud run deploy ${SERVICE_NAME} \
    --image gcr.io/${GOOGLE_CLOUD_PROJECT}/${SERVICE_NAME} \
    --no-allow-unauthenticated \
    --memory=1Gi \
    --update-env-vars BUCKET_THUMBNAILS=${BUCKET_THUMBNAILS}

একবার পরিষেবাটি স্থাপন করা হলে, ওয়ার্কফ্লোস thumbnailCall ধাপ এই পরিষেবাটিকে কল করতে সক্ষম হবে।

11. কোলাজ পরিষেবা (ক্লাউড রান)

চেইনের পরেরটি হল সাম্প্রতিকতম ছবিগুলি থেকে একটি কোলাজ তৈরি করা৷ এটি একটি ক্লাউড রান পরিষেবার কোডে করা হয় এবং Workflows এই পরিষেবাটিকে collageCall ধাপে কল করে:

591e36149066e1ba.png

কোড অন্বেষণ

ক্লাউড রান পরিষেবাকে collage বলা হয়। আপনি index.js- এ এর সম্পূর্ণ কোড চেক করতে পারেন।

কন্টেইনার ইমেজ তৈরি ও প্রকাশ করুন

ক্লাউড রান কন্টেইনার চালায় তবে আপনাকে প্রথমে কন্টেইনার ইমেজ তৈরি করতে হবে ( Dockerfile সংজ্ঞায়িত)। Google ক্লাউড বিল্ড কনটেইনার ইমেজ তৈরি করতে এবং তারপর Google কন্টেইনার রেজিস্ট্রিতে হোস্ট করতে ব্যবহার করা যেতে পারে।

ফোল্ডারে নেভিগেট করুন:

cd services/collage/nodejs

নির্মাণ:

export SERVICE_SRC=collage
export SERVICE_NAME=${SERVICE_SRC}-service
gcloud builds submit \
  . \
  --tag gcr.io/${GOOGLE_CLOUD_PROJECT}/${SERVICE_NAME}

এক বা দুই মিনিট পরে, বিল্ডটি সফল হওয়া উচিত এবং কন্টেইনারটি Google কন্টেইনার রেজিস্ট্রিতে স্থাপন করা হবে৷

ক্লাউড রানে স্থাপন করুন

কিছু প্রয়োজনীয় ভেরিয়েবল এবং কনফিগারেশন সেট করুন:

export BUCKET_THUMBNAILS=thumbnails-${GOOGLE_CLOUD_PROJECT}
export REGION=europe-west1
gcloud config set run/region ${REGION}
gcloud config set run/platform managed

স্থাপন:

gcloud run deploy ${SERVICE_NAME} \
    --image gcr.io/${GOOGLE_CLOUD_PROJECT}/${SERVICE_NAME} \
    --no-allow-unauthenticated \
    --memory=1Gi \
    --update-env-vars BUCKET_THUMBNAILS=${BUCKET_THUMBNAILS}

একবার পরিষেবাটি স্থাপন করা হলে, আপনি উভয় পরিষেবাই ক্লাউড কনসোলের ক্লাউড রান বিভাগের অধীনে চলছে তা পরীক্ষা করতে পারেন এবং ওয়ার্কফ্লোস collageCall ধাপ এই পরিষেবাটিকে কল করতে সক্ষম হবে:

3ae9873f4cbbf423.png

12. কর্মপ্রবাহ স্থাপন

আমরা কর্মপ্রবাহের সমস্ত বাহ্যিক নির্ভরতা স্থাপন করেছি। বাকি সব ধাপ ( finalizeCompleted , pictureGarbageCollectionGCS , pictureGarbageCollectionFirestore , deleteCompleted ) ওয়ার্কফ্লোস নিজেই সম্পন্ন করতে পারে।

এটা ওয়ার্কফ্লো স্থাপন করার সময়!

যে ফোল্ডারটিতে workflows.yaml ফাইল রয়েছে সেখানে নেভিগেট করুন এবং এটির সাথে স্থাপন করুন:

export WORKFLOW_REGION=europe-west4
export WORKFLOW_NAME=picadaily-workflows
gcloud workflows deploy ${WORKFLOW_NAME} \
  --source=workflows.yaml \
  --location=${WORKFLOW_REGION}

কয়েক সেকেন্ডের মধ্যে, ওয়ার্কফ্লো স্থাপন করা উচিত এবং আপনি এটি ক্লাউড কনসোলের ওয়ার্কফ্লো বিভাগে দেখতে পারেন:

94a720149e5df9c5.png

আপনি যদি চান ওয়ার্কফ্লোতে ক্লিক করুন এবং এটি সম্পাদনা করতে পারেন। সম্পাদনার সময়, আপনি ওয়ার্কফ্লোটির একটি সুন্দর ভিজ্যুয়াল উপস্থাপনা পাবেন:

55441b158f6027f3.png

আপনি সঠিক পরামিতি সহ ক্লাউড কনসোল থেকে ম্যানুয়ালি ওয়ার্কফ্লো চালাতে পারেন। পরিবর্তে, আমরা পরবর্তী ধাপে ক্লাউড স্টোরেজ ইভেন্টগুলির প্রতিক্রিয়া হিসাবে এটি স্বয়ংক্রিয়ভাবে কার্যকর করব।

13. ওয়ার্কফ্লো ট্রিগার (ক্লাউড ফাংশন)

কর্মপ্রবাহ স্থাপন এবং প্রস্তুত করা হয়. এখন, ক্লাউড স্টোরেজ বালতিতে একটি ফাইল তৈরি বা মুছে ফেলা হলে আমাদের ওয়ার্কফ্লো ট্রিগার করতে হবে। এগুলো যথাক্রমে storage.object.finalize এবং storage.object.delete ইভেন্ট।

ওয়ার্কফ্লোতে আপনি ব্যবহার করতে পারেন এমন ওয়ার্কফ্লো তৈরি, পরিচালনা এবং কার্যকর করার জন্য API এবং ক্লায়েন্ট লাইব্রেরি রয়েছে। এই ক্ষেত্রে, আপনি Workflows Execution API এবং আরও নির্দিষ্টভাবে এর Node.js ক্লায়েন্ট লাইব্রেরি ব্যবহার করবেন ওয়ার্কফ্লোকে ট্রিগার করতে।

আপনি ক্লাউড স্টোরেজ ইভেন্টগুলি শুনে ক্লাউড ফাংশন থেকে ওয়ার্কফ্লো ট্রিগার করবেন। যেহেতু একটি ক্লাউড ফাংশন শুধুমাত্র একটি ইভেন্টের প্রকারের জন্য শুনতে পারে, তাই আপনি দুটি ক্লাউড ফাংশন স্থাপন করবেন ইভেন্ট তৈরি এবং মুছে ফেলার জন্য শোনার জন্য:

c4d79646de729e4.png

কোড অন্বেষণ

ক্লাউড ফাংশনকে trigger-workflow বলা হয়। আপনি index.js- এ এর সম্পূর্ণ কোড চেক করতে পারেন।

ক্লাউড ফাংশনে স্থাপন করুন

ফোল্ডারে নেভিগেট করুন:

cd workflows/functions/trigger-workflow/nodejs

কিছু প্রয়োজনীয় ভেরিয়েবল এবং কনফিগারেশন সেট করুন:

export BUCKET_PICTURES=uploaded-pictures-${GOOGLE_CLOUD_PROJECT}
export REGION=europe-west1
export WORKFLOW_NAME=picadaily-workflows
export WORKFLOW_REGION=europe-west4
export COLLAGE_URL=$(gcloud run services describe collage-service --format 'value(status.url)')
export THUMBNAILS_URL=$(gcloud run services describe thumbnails-service --format 'value(status.url)')
export VISION_DATA_TRANSFORM_URL=$(gcloud functions describe vision-data-transform --format 'value(httpsTrigger.url)')
gcloud config set functions/region ${REGION}

ইভেন্টগুলি চূড়ান্ত করার জন্য সাড়া ফাংশন স্থাপন করুন:

export SERVICE_NAME=trigger-workflow-on-finalize
gcloud functions deploy ${SERVICE_NAME} \
  --source=. \
  --runtime nodejs10 \
  --entry-point=trigger_workflow \
  --trigger-resource=${BUCKET_PICTURES} \
  --trigger-event=google.storage.object.finalize \
  --allow-unauthenticated \
  --set-env-vars GOOGLE_CLOUD_PROJECT=${GOOGLE_CLOUD_PROJECT},WORKFLOW_REGION=${WORKFLOW_REGION},WORKFLOW_NAME=${WORKFLOW_NAME},THUMBNAILS_URL=${THUMBNAILS_URL},COLLAGE_URL=${COLLAGE_URL},VISION_DATA_TRANSFORM_URL=${VISION_DATA_TRANSFORM_URL}

ইভেন্টগুলি মুছে ফেলার প্রতিক্রিয়া জানিয়ে দ্বিতীয় ফাংশন স্থাপন করুন:

export SERVICE_NAME=trigger-workflow-on-delete
gcloud functions deploy ${SERVICE_NAME} \
  --source=. \
  --runtime nodejs10 \
  --entry-point=trigger_workflow \
  --trigger-resource=${BUCKET_PICTURES} \
  --trigger-event=google.storage.object.delete \
  --allow-unauthenticated \
  --set-env-vars GOOGLE_CLOUD_PROJECT=${GOOGLE_CLOUD_PROJECT},WORKFLOW_REGION=${WORKFLOW_REGION},WORKFLOW_NAME=${WORKFLOW_NAME},THUMBNAILS_URL=${THUMBNAILS_URL},COLLAGE_URL=${COLLAGE_URL},VISION_DATA_TRANSFORM_URL=${VISION_DATA_TRANSFORM_URL}

যখন স্থাপনা সম্পূর্ণ হয়, আপনি ক্লাউড কনসোলে উভয় ফাংশন দেখতে পাবেন:

7d60c8b7851f39f5.png

14. ফ্রন্টেন্ড (অ্যাপ ইঞ্জিন)

এই ধাপে, আপনি পিক-এ-ডেইলি থেকে Google অ্যাপ ইঞ্জিনে একটি ওয়েব ফ্রন্টএন্ড তৈরি করুন: ল্যাব 4—একটি ওয়েব ফ্রন্টএন্ড তৈরি করুন যা ব্যবহারকারীদের ওয়েব অ্যাপ্লিকেশন থেকে ছবি আপলোড করতে দেয়, সেইসাথে আপলোড করা ছবি এবং তাদের থাম্বনেইলগুলি ব্রাউজ করতে দেয়৷

223fb2281614d053.png

আপনি অ্যাপ ইঞ্জিন সম্পর্কে আরও জানতে পারেন এবং Pic-a-Daily-এ কোডের বিবরণ পড়তে পারেন: ল্যাব 4—একটি ওয়েব ফ্রন্টএন্ড তৈরি করুন

কোড অন্বেষণ

অ্যাপ ইঞ্জিন অ্যাপটিকে frontend বলা হয়। আপনি index.js- এ এর সম্পূর্ণ কোড চেক করতে পারেন।

অ্যাপ ইঞ্জিনে স্থাপন করুন

ফোল্ডারে নেভিগেট করুন:

cd frontend

আপনার পছন্দের অঞ্চলটি সেট করুন এবং আপনার প্রকৃত প্রকল্প আইডি দিয়ে app.yaml-এ GOOGLE_CLOUD_PROJECT প্রতিস্থাপন করুন:

export REGION=europe-west1
gcloud config set compute/region ${REGION}
sed -i -e "s/GOOGLE_CLOUD_PROJECT/${GOOGLE_CLOUD_PROJECT}/" app.yaml

স্থাপন:

gcloud app deploy app.yaml -q

এক বা দুই মিনিট পরে, আপনাকে বলা হবে যে অ্যাপ্লিকেশনটি ট্র্যাফিক পরিবেশন করছে:

Beginning deployment of service [default]...
╔════════════════════════════════════════════════════════════╗
╠═ Uploading 8 files to Google Cloud Storage                ═╣
╚════════════════════════════════════════════════════════════╝
File upload done.
Updating service [default]...done.
Setting traffic split for service [default]...done.
Deployed service [default] to [https://GOOGLE_CLOUD_PROJECT.appspot.com]
You can stream logs from the command line by running:
  $ gcloud app logs tail -s default
To view your application in the web browser run:
  $ gcloud app browse

আপনি ক্লাউড কনসোলের অ্যাপ ইঞ্জিন বিভাগে গিয়ে দেখতে পারেন যে অ্যাপটি স্থাপন করা হয়েছে এবং অ্যাপ ইঞ্জিনের বৈশিষ্ট্যগুলি যেমন সংস্করণ এবং ট্রাফিক বিভাজন অন্বেষণ করুন:

f4bd5f4de028bd83.png

15. ওয়ার্কফ্লো পরীক্ষা করুন

পরীক্ষা করতে, অ্যাপটির ডিফল্ট অ্যাপ ইঞ্জিন URL-এ যান ( https://<YOUR_PROJECT_ID>.appspot.com/ ) অ্যাপ এবং আপনি ফ্রন্টএন্ড UI আপ এবং চলমান দেখতে পাবেন!

1649ac060441099.png

একটি ছবি আপলোড করুন. এটি ওয়ার্কফ্লোগুলিকে ট্রিগার করবে এবং আপনি ক্লাউড কনসোলে Active অবস্থায় ওয়ার্কফ্লো এক্সিকিউশন দেখতে পাবেন:

b5a2a3d7a2bc094.png

ওয়ার্কফ্লো হয়ে গেলে, আপনি এক্সিকিউশন আইডিতে ক্লিক করতে পারেন এবং বিভিন্ন পরিষেবা থেকে আউটপুট দেখতে পারেন:

8959df5098c21548.png

আরো 3টি ছবি আপলোড করুন। আপনি ক্লাউড স্টোরেজ বালতি এবং অ্যাপ ইঞ্জিন ফ্রন্টএন্ড আপডেট করা চিত্রগুলির থাম্বনেইল এবং কোলাজ দেখতে পাবেন:

d90c786ff664a5dc.png

16. পরিষ্কার করুন (ঐচ্ছিক)

আপনি যদি অ্যাপটি রাখতে না চান, তাহলে আপনি খরচ বাঁচাতে এবং পুরো প্রকল্পটি মুছে দিয়ে সামগ্রিকভাবে ভালো ক্লাউড নাগরিক হতে সম্পদ পরিষ্কার করতে পারেন:

gcloud projects delete ${GOOGLE_CLOUD_PROJECT} 

17. অভিনন্দন!

আপনি অর্কেস্ট্রেট এবং কল পরিষেবাদির জন্য ওয়ার্কফ্লো ব্যবহার করে অ্যাপের একটি অর্কেস্ট্রেটেড সংস্করণ তৈরি করেছেন৷

আমরা কভার করেছি কি

  • অ্যাপ ইঞ্জিন
  • ক্লাউড ফায়ারস্টোর
  • ক্লাউড ফাংশন
  • ক্লাউড রান
  • কর্মপ্রবাহ