Catch up on everthing we announced at this year's Firebase Summit. Learn more

ক্লাউড রান সহ গতিশীল সামগ্রী এবং হোস্ট মাইক্রোসার্ভেসিকে পরিবেশন করুন

আপনার গতিশীল বিষয়বস্তু তৈরি এবং পরিবেশন করতে বা মাইক্রোসার্ভিসেস হিসাবে REST API গুলি তৈরি করতে Firebase হোস্টিং এর সাথে জোড় ক্লাউড চালান।

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

  • ক্লাউড চালান সমর্থন অনেকগুলি ভাষায় আপনি নমনীয়তা আপনার পছন্দের প্রোগ্রামিং ভাষা ও ফ্রেমওয়ার্ক ব্যবহার করতে দেবার, (যান, Node.js, পাইথন, জাভা সহ)।
  • ক্লাউড চালান স্বয়ংক্রিয়ভাবে এবং অনুভূমিকভাবে আইশ , গ্রহণ অনুরোধ পরিচালনা করতে আপনার ধারক ইমেজ তারপর আইশ যখন চাহিদা হ্রাস পায়।
  • আপনি শুধুমাত্র দিতে CPU- র, মেমরি জন্য, এবং অনুরোধ সামলাচ্ছে সময় ধ্বংস নেটওয়ার্কিং।

উদাহরণস্বরূপ ব্যবহারের ক্ষেত্রে এবং ক্লাউড রান নমুনা Firebase হোস্টিং সাথে একত্রিত জন্য, আমাদের দেখার জন্য serverless ওভারভিউ


এই নির্দেশিকা আপনাকে দেখায় কিভাবে:

  1. একটি সহজ হ্যালো ওয়ার্ল্ড অ্যাপ্লিকেশন লিখুন
  2. একটি অ্যাপকে কনটেইনারাইজ করে কনটেইনার রেজিস্ট্রিতে আপলোড করুন
  3. ক্লাউড রান কন্টেইনার ইমেজ স্থাপন করুন
  4. আপনার কন্টেইনারাইজড অ্যাপে সরাসরি হোস্টিং অনুরোধ

লক্ষ্য করুন গতিশীল বিষয়বস্তু, আপনি বিকল্প হিসেবে সুর আপনার যা করতে পারেন ভজনা পারফরম্যান্সের উন্নতি করতে ক্যাশে সেটিংস

তুমি শুরু করার আগে

ক্লাউড চালান ব্যবহারের আগে, আপনি একটি ক্লাউড বিলিং অ্যাকাউন্ট সেট আপ, ক্লাউড চালান এপিআই সক্রিয়, এবং ইনস্টল করার সহ কিছু প্রাথমিক কাজ, সম্পূর্ণ করতে হবে gcloud কমান্ড লাইন টুল।

আপনার প্রকল্পের জন্য বিলিং সেট করুন

ক্লাউড চালান উপলব্ধ করা হয় ফ্রী ব্যবহার কোটা , কিন্তু আপনি এখনও একটি থাকতে হবে ক্লাউড বিলিং অ্যাকাউন্ট ব্যবহার করার জন্য আপনার Firebase প্রকল্পের সঙ্গে সংশ্লিষ্ট অথবা ক্লাউড রান আউট করার চেষ্টা করুন।

API সক্ষম করুন এবং SDK ইনস্টল করুন

  1. গুগল এপিআই কনসোলে ক্লাউড রান এপিআই সক্ষম করুন:

    1. খুলুন ক্লাউড চালান এপিআই পৃষ্ঠা Google APIs কনসোলে।

    2. অনুরোধ করা হলে, আপনার Firebase প্রকল্প নির্বাচন করুন।

    3. ক্লাউড চালান এপিআই পৃষ্ঠাতে সক্ষম করুন ক্লিক করুন।

  2. ইনস্টল করুন এবং আরম্ভ ক্লাউড SDK এর।

  3. পরীক্ষা করে দেখুন যে gcloud টুল সঠিক প্রকল্পের জন্য কনফিগার করা হয়েছে:

    gcloud config list

ধাপ 1: নমুনা আবেদন লিখুন

লক্ষ্য করুন ক্লাউড চালান সমর্থন অনেক অন্যান্য ভাষায় নিম্নলিখিত নমুনা দেখানো ভাষায় ছাড়াও।

যাওয়া

  1. একটি নতুন নামের ডিরেক্টরি তৈরি করুন helloworld-go , এটা তারপরে পরিবর্তন ডিরেক্টরি:

    mkdir helloworld-go
    cd helloworld-go
  2. একটি নতুন ফাইল নামক তৈরি করুন helloworld.go , তারপর নিচের কোডটি যুক্ত করুন:

    package main
    
    import (
    	"fmt"
    	"log"
    	"net/http"
    	"os"
    )
    
    func handler(w http.ResponseWriter, r *http.Request) {
    	log.Print("helloworld: received a request")
    	target := os.Getenv("TARGET")
    	if target == "" {
    		target = "World"
    	}
    	fmt.Fprintf(w, "Hello %s!\n", target)
    }
    
    func main() {
    	log.Print("helloworld: starting server...")
    
    	http.HandleFunc("/", handler)
    
    	port := os.Getenv("PORT")
    	if port == "" {
    		port = "8080"
    	}
    
    	log.Printf("helloworld: listening on port %s", port)
    	log.Fatal(http.ListenAndServe(fmt.Sprintf(":%s", port), nil))
    }
    

    এই কোড মৌলিক ওয়েব সার্ভার যে পোর্টে শোনা দ্বারা সংজ্ঞায়িত সৃষ্টি PORT এনভায়রনমেন্ট ভেরিয়েবল।

আপনার অ্যাপটি শেষ এবং কনটেইনারাইজড এবং কনটেইনার রেজিস্ট্রিতে আপলোড করার জন্য প্রস্তুত।

Node.js

  1. নামে একটি নতুন ডিরেক্টরি তৈরি করুন helloworld-nodejs তা, তারপর পরিবর্তন ডিরেক্টরি:

    mkdir helloworld-nodejs
    cd helloworld-nodejs
  2. একটি তৈরি করুন package.json নিম্নলিখিত বিষয়বস্তু সঙ্গে ফাইল:

    {
      "name": "knative-serving-helloworld",
      "version": "1.0.0",
      "description": "Simple hello world sample in Node",
      "main": "index.js",
      "scripts": {
        "start": "node index.js"
      },
      "author": "",
      "license": "Apache-2.0",
      "dependencies": {
        "express": "^4.16.4"
      }
    }
    
  3. একটি নতুন ফাইল নামক তৈরি করুন index.js , তারপর নিচের কোডটি যুক্ত করুন:

    const express = require('express');
    const app = express();
    
    app.get('/', (req, res) => {
      console.log('Hello world received a request.');
    
      const target = process.env.TARGET || 'World';
      res.send(`Hello ${target}!\n`);
    });
    
    const port = process.env.PORT || 8080;
    app.listen(port, () => {
      console.log('Hello world listening on port', port);
    });
    

    এই কোড মৌলিক ওয়েব সার্ভার যে পোর্টে শোনা দ্বারা সংজ্ঞায়িত সৃষ্টি PORT এনভায়রনমেন্ট ভেরিয়েবল।

আপনার অ্যাপ সমাপ্ত এবং কনটেইনারাইজড এবং কনটেইনার রেজিস্ট্রিতে আপলোড করার জন্য প্রস্তুত।

পাইথন

  1. একটি নতুন নামের ডিরেক্টরি তৈরি করুন helloworld-python , এটা তারপরে পরিবর্তন ডিরেক্টরি:

    mkdir helloworld-python
    cd helloworld-python
  2. একটি নতুন নামের ফাইল তৈরি করুন app.py , তারপর নিচের কোডটি যুক্ত করুন:

    import os
    
    from flask import Flask
    
    app = Flask(__name__)
    
    @app.route('/')
    def hello_world():
        target = os.environ.get('TARGET', 'World')
        return 'Hello {}!\n'.format(target)
    
    if __name__ == "__main__":
        app.run(debug=True,host='0.0.0.0',port=int(os.environ.get('PORT', 8080)))
    

    এই কোড মৌলিক ওয়েব সার্ভার যে পোর্টে শোনা দ্বারা সংজ্ঞায়িত সৃষ্টি PORT এনভায়রনমেন্ট ভেরিয়েবল।

আপনার অ্যাপ সমাপ্ত এবং কনটেইনারাইজড এবং কনটেইনার রেজিস্ট্রিতে আপলোড করার জন্য প্রস্তুত।

জাভা

  1. ইনস্টল করুন জাভা SE 8 বা পরবর্তী JDK এবং কার্ল

    মনে রাখবেন যে পরবর্তী ধাপে নতুন ওয়েব প্রজেক্ট তৈরির জন্য আমাদের কেবল এটি করতে হবে। ডকারফিল, যা পরে বর্ণনা করা হয়েছে, সমস্ত নির্ভরতাকে পাত্রে লোড করবে।

  2. কনসোল থেকে, CURL ব্যবহার করে একটি নতুন খালি ওয়েব প্রকল্প তৈরি করুন তারপর কমান্ডগুলি আনজিপ করুন:

    curl https://start.spring.io/starter.zip \
        -d dependencies=web \
        -d name=helloworld \
        -d artifactId=helloworld \
        -o helloworld.zip
    unzip helloworld.zip

    এটি একটি স্প্রিংবুট প্রকল্প তৈরি করে।

  3. আপডেট করুন SpringBootApplication মধ্যে বর্গ src/main/java/com/example/helloworld/HelloworldApplication.java একটি যোগ করে @RestController হ্যান্ডেল করতে / ম্যাপিং এবং একটি যোগ @Value ক্ষেত্র প্রদান TARGET এনভায়রনমেন্ট ভেরিয়েবল:

    package com.example.helloworld;
    
    import org.springframework.beans.factory.annotation.Value;
    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
    import org.springframework.web.bind.annotation.GetMapping;
    import org.springframework.web.bind.annotation.RestController;
    
    @SpringBootApplication
    public class HelloworldApplication {
    
      @Value("${TARGET:World}")
      String target;
    
      @RestController
      class HelloworldController {
        @GetMapping("/")
        String hello() {
          return "Hello " + target + "!";
        }
      }
    
      public static void main(String[] args) {
        SpringApplication.run(HelloworldApplication.class, args);
      }
    }
    

    এই কোড মৌলিক ওয়েব সার্ভার যে পোর্টে শোনা দ্বারা সংজ্ঞায়িত সৃষ্টি PORT এনভায়রনমেন্ট ভেরিয়েবল।

আপনার অ্যাপ সমাপ্ত এবং কনটেইনারাইজড এবং কনটেইনার রেজিস্ট্রিতে আপলোড করার জন্য প্রস্তুত।

পদক্ষেপ 2: Containerize একটি অ্যাপ্লিকেশন এবং কনটেইনার রেজিস্ট্রি এটি আপলোড

  1. একটি নতুন নামের ফাইল তৈরি করে নমুনা অ্যাপ্লিকেশন Containerize Dockerfile সোর্স ফাইল হিসাবে একই ডিরেক্টরির মধ্যে। নিচের বিষয়বস্তু আপনার ফাইলে অনুলিপি করুন।

    যাওয়া

    # Use the official Golang image to create a build artifact.
    # This is based on Debian and sets the GOPATH to /go.
    FROM golang:1.13 as builder
    
    # Create and change to the app directory.
    WORKDIR /app
    
    # Retrieve application dependencies using go modules.
    # Allows container builds to reuse downloaded dependencies.
    COPY go.* ./
    RUN go mod download
    
    # Copy local code to the container image.
    COPY . ./
    
    # Build the binary.
    # -mod=readonly ensures immutable go.mod and go.sum in container builds.
    RUN CGO_ENABLED=0 GOOS=linux go build -mod=readonly -v -o server
    
    # Use the official Alpine image for a lean production container.
    # https://hub.docker.com/_/alpine
    # https://docs.docker.com/develop/develop-images/multistage-build/#use-multi-stage-builds
    FROM alpine:3
    RUN apk add --no-cache ca-certificates
    
    # Copy the binary to the production image from the builder stage.
    COPY --from=builder /app/server /server
    
    # Run the web service on container startup.
    CMD ["/server"]
    

    Node.js

    # Use the official lightweight Node.js 12 image.
    # https://hub.docker.com/_/node
    FROM node:12-slim
    
    # Create and change to the app directory.
    WORKDIR /usr/src/app
    
    # Copy application dependency manifests to the container image.
    # A wildcard is used to ensure both package.json AND package-lock.json are copied.
    # Copying this separately prevents re-running npm install on every code change.
    COPY package*.json ./
    
    # Install production dependencies.
    RUN npm install --only=production
    
    # Copy local code to the container image.
    COPY . ./
    
    # Run the web service on container startup.
    CMD [ "npm", "start" ]
    

    পাইথন

    # Use the official lightweight Python image.
    # https://hub.docker.com/_/python
    FROM python:3.7-slim
    
    # Allow statements and log messages to immediately appear in the Knative logs
    ENV PYTHONUNBUFFERED True
    
    # Copy local code to the container image.
    ENV APP_HOME /app
    WORKDIR $APP_HOME
    COPY . ./
    
    # Install production dependencies.
    RUN pip install Flask gunicorn
    
    # Run the web service on container startup. Here we use the gunicorn
    # webserver, with one worker process and 8 threads.
    # For environments with multiple CPU cores, increase the number of workers
    # to be equal to the cores available.
    CMD exec gunicorn --bind :$PORT --workers 1 --threads 8 --timeout 0 app:app
    

    জাভা

    # Use the official maven/Java 8 image to create a build artifact: https://hub.docker.com/_/maven
    FROM maven:3.5-jdk-8-alpine as builder
    
    # Copy local code to the container image.
    WORKDIR /app
    COPY pom.xml .
    COPY src ./src
    
    # Build a release artifact.
    RUN mvn package -DskipTests
    
    # Use the Official OpenJDK image for a lean production stage of our multi-stage build.
    # https://hub.docker.com/_/openjdk
    # https://docs.docker.com/develop/develop-images/multistage-build/#use-multi-stage-builds
    FROM openjdk:8-jre-alpine
    
    # Copy the jar to the production image from the builder stage.
    COPY --from=builder /app/target/helloworld-*.jar /helloworld.jar
    
    # Run the web service on container startup.
    CMD ["java", "-Djava.security.egd=file:/dev/./urandom", "-jar", "/helloworld.jar"]
    

  2. আপনার ডকারফিল ধারণকারী ডিরেক্টরি থেকে নিম্নোক্ত কমান্ডটি চালিয়ে ক্লাউড বিল্ড ব্যবহার করে আপনার ধারক চিত্রটি তৈরি করুন:

    gcloud builds submit --tag gcr.io/PROJECT_ID/helloworld

    সাফল্যের পরে, আপনি ছবির নাম সম্বলিত একটি সফল বার্তা দেখতে পাবেন
    ( gcr.io/ PROJECT_ID /helloworld )।

কন্টেইনার ইমেজটি এখন কনটেইনার রেজিস্ট্রিতে সংরক্ষিত আছে এবং ইচ্ছা করলে পুনরায় ব্যবহার করা যেতে পারে।

উল্লেখ্য, ক্লাউড বিল্ড পরিবর্তে, আপনি Docker একটি স্থানীয়ভাবে ইনস্টল করা সংস্করণ ব্যবহার করতে পারেন আপনার ধারক স্থানীয়ভাবে গড়ে তুলতে

ধাপ 3: ক্লাউড রান করার ধারক ইমেজ স্থাপন করুন

  1. নিম্নলিখিত কমান্ড ব্যবহার করে স্থাপন করুন:

    gcloud run deploy --image gcr.io/PROJECT_ID/helloworld

  2. অনুরোধ করা হলে:

    • একটি অঞ্চল নির্বাচন করুন (উদাহরণস্বরূপ us-central1 )
    • সেবা নাম নিশ্চিত (উদাহরণস্বরূপ, helloworld )
    • প্রতিক্রিয়া জানান Y থেকে অবিশ্বস্ত আমন্ত্রণ অনুমতি
  3. ডিপ্লাই সম্পূর্ণ হওয়ার জন্য কিছু মুহূর্ত অপেক্ষা করুন। সাফল্যে, কমান্ড লাইন পরিষেবা URL প্রদর্শন করে। উদাহরণস্বরূপ: https://helloworld- RANDOM_HASH -us-central1.a.run.app

  4. একটি ওয়েব ব্রাউজারে সার্ভিস ইউআরএল খোলার মাধ্যমে আপনার স্থাপন করা পাত্রে যান।

পরবর্তী ধাপে কিভাবে Firebase হোস্টিং URL থেকে এই containerized app টি এটি অ্যাক্সেস যাতে এটি আপনার Firebase-হোস্ট করা সাইটের জন্য ডায়নামিক সামগ্রী তৈরি করতে পারেন মাধ্যমে আপনাকে নিয়ে যাবে।

পদক্ষেপ 4: আপনার containerized অ্যাপ্লিকেশন সরাসরি হোস্টিং অনুরোধ

সঙ্গে লেখা নিয়ম , আপনি অনুরোধ একটি একক গন্তব্য নির্দিষ্ট প্যাটার্নে মেলে নির্দেশ দিতে পারেন।

নিম্নলিখিত উদাহরণে দেখায় কিভাবে পাতা থেকে সমস্ত অনুরোধ নির্দেশ /helloworld আপনার হোস্টিং সাইটে প্রারম্ভে আরম্ভ এবং আপনার চালাচ্ছে helloworld ধারক উদাহরণস্বরূপ।

  1. নিশ্চিত করো যে:

    CLI ইনস্টল এবং হোস্টিং আরম্ভের বিষয়ে বিস্তারিত নির্দেশাবলীর জন্য, দেখুন হোস্টিং জন্য পেতে শুরু করার নির্দেশিকা

  2. আপনার খোলা firebase.json ফাইল

  3. নিম্নলিখিত যোগ rewrite অধীনে কনফিগারেশন hosting অধ্যায়:

    "hosting": {
      // ...
    
      // Add the "rewrites" attribute within "hosting"
      "rewrites": [ {
        "source": "/helloworld",
        "run": {
          "serviceId": "helloworld",  // "service name" (from when you deployed the container image)
          "region": "us-central1"     // optional (if omitted, default is us-central1)
        }
      } ]
    }
    
  4. আপনার প্রজেক্ট ডাইরেক্টরির মূল থেকে নিম্নলিখিত কমান্ডটি চালানোর মাধ্যমে আপনার সাইটে আপনার হোস্টিং কনফিগারেশন স্থাপন করুন:

    firebase deploy

আপনার কন্টেইনারটি এখন নিম্নোক্ত URL গুলির মাধ্যমে পৌঁছানো যাবে:

  • আপনার Firebase সাবডোমেন:
    PROJECT_ID .web.app/ এবং PROJECT_ID .firebaseapp.com/

  • কোন সংযুক্ত কাস্টম ডোমেন :
    CUSTOM_DOMAIN /

জন্য হোস্টিং কনফিগারেশন পৃষ্ঠায় যান লেখা নিয়ম সম্পর্কে আরো বিস্তারিত জানার । এছাড়াও আপনি সম্পর্কে জানতে পারেন প্রতিক্রিয়া অগ্রাধিকার ক্রম বিভিন্ন হোস্টিং কনফিগারেশনের জন্য।

স্থানীয়ভাবে পরীক্ষা করুন

বিকাশের সময়, আপনি স্থানীয়ভাবে আপনার ধারক চিত্রটি চালাতে এবং পরীক্ষা করতে পারেন। বিস্তারিত নির্দেশাবলীর জন্য, এখানে যান ক্লাউড চালান ডকুমেন্টেশন

পরবর্তী পদক্ষেপ