Bắt đầu sử dụng Terraform và Firebase

Firebase đang bắt đầu hỗ trợ Terraform. Nếu bạn đang làm việc trong một nhóm muốn tự động hoá và chuẩn hoá việc tạo dự án Firebase với các tài nguyên cụ thể được cung cấp và các dịch vụ được bật, thì việc sử dụng Terraform với Firebase có thể phù hợp với bạn.

Quy trình làm việc cơ bản để sử dụng Terraform với Firebase bao gồm những bước sau:

  • Tạo và tuỳ chỉnh tệp cấu hình Terraform (tệp .tf) chỉ định cơ sở hạ tầng mà bạn muốn cung cấp (tức là tài nguyên bạn muốn cung cấp và các dịch vụ bạn muốn bật).

  • Sử dụng các lệnh gcloud CLI giao tiếp với Terraform để cung cấp cơ sở hạ tầng được chỉ định trong tệp .tf.

Bạn có thể làm gì với Terraform và Firebase?

Quy trình công việc tổng quát mẫu trong hướng dẫn này là tạo một dự án Firebase mới bằng ứng dụng Android. Tuy nhiên, bạn có thể làm nhiều việc khác bằng Terraform, chẳng hạn như:

  • Xoá và sửa đổi cơ sở hạ tầng hiện có bằng Terraform.

  • Quản lý cấu hình và các tác vụ dành riêng cho sản phẩm bằng Terraform, chẳng hạn như:

    • Bật trình cung cấp dịch vụ đăng nhập Firebase Authentication.
    • Tạo các vùng chứa Cloud Storage hoặc phiên bản cơ sở dữ liệu và triển khai Firebase Security Rules cho các vùng chứa hoặc phiên bản đó.
    • Tạo các phần phụ trợ Firebase App Hosting, bản dựng và các tài nguyên liên quan khác.

Bạn có thể sử dụng các tệp và lệnh cấu hình Terraform tiêu chuẩn để hoàn thành tất cả các tác vụ này. Để giúp bạn thực hiện việc này, chúng tôi đã cung cấp các tệp cấu hình Terraform mẫu cho một số trường hợp sử dụng phổ biến.



Quy trình chung để sử dụng Terraform với Firebase

Điều kiện tiên quyết

Hướng dẫn này giới thiệu cách sử dụng Terraform với Firebase, vì vậy, bạn cần có kiến thức cơ bản về Terraform. Đảm bảo bạn đã hoàn tất các điều kiện tiên quyết sau đây trước khi bắt đầu quy trình này.

  • Cài đặt Terraform và tìm hiểu về Terraform thông qua các hướng dẫn chính thức của họ.

  • Cài đặt Google Cloud CLI (gcloud CLI). Đăng nhập bằng tài khoản người dùng hoặc tài khoản dịch vụ.


Bước 1: Tạo và tuỳ chỉnh tệp cấu hình Terraform

Tệp cấu hình Terraform cần có 2 phần chính (được mô tả chi tiết bên dưới):

Thiết lập provider

Bạn phải thiết lập provider bất kể sản phẩm hoặc dịch vụ nào của Firebase có liên quan.

  1. Tạo một tệp cấu hình Terraform (chẳng hạn như tệp main.tf) trong thư mục cục bộ.

    Trong hướng dẫn này, bạn sẽ sử dụng tệp cấu hình này để chỉ định cả chế độ thiết lập provider và tất cả cơ sở hạ tầng mà bạn muốn Terraform tạo. Tuy nhiên, lưu ý rằng bạn có các lựa chọn về cách thêm chế độ thiết lập nhà cung cấp.

  2. Thêm chế độ thiết lập provider sau đây vào đầu tệp main.tf.

    Bạn phải sử dụng nhà cung cấp google-beta vì đây là bản phát hành beta của việc sử dụng Firebase với Terraform. Hãy thận trọng khi sử dụng trong quá trình phát hành chính thức.

    # Terraform configuration to set up providers by version.
    terraform {
      required_providers {
        google-beta = {
          source  = "hashicorp/google-beta"
          version = "~> 6.0"
        }
      }
    }
    
    # Configures the provider to use the resource block's specified project for quota checks.
    provider "google-beta" {
      user_project_override = true
    }
    
    # Configures the provider to not use the resource block's specified project for quota checks.
    # This provider should only be used during project creation and initializing services.
    provider "google-beta" {
      alias = "no_user_project_override"
      user_project_override = false
    }

    Tìm hiểu thêm về các loại thuộc tính liên quan đến dự án (bao gồm cả những gì hướng dẫn này gọi là "dự án kiểm tra hạn mức") khi sử dụng Terraform với Firebase.

  3. Tiếp tục chuyển sang phần tiếp theo để hoàn tất tệp cấu hình và chỉ định cơ sở hạ tầng cần tạo.

Chỉ định cơ sở hạ tầng cần tạo bằng cách sử dụng các khối resource

Trong tệp cấu hình Terraform (đối với hướng dẫn này, tệp main.tf của bạn), bạn cần chỉ định tất cả cơ sở hạ tầng mà bạn muốn Terraform tạo (tức là tất cả tài nguyên bạn muốn cung cấp và tất cả dịch vụ bạn muốn bật). Trong hướng dẫn này, hãy xem danh sách đầy đủ tất cả các tài nguyên Firebase hỗ trợ Terraform.

  1. Mở tệp main.tf.

  2. Trong chế độ thiết lập provider, hãy thêm cấu hình sau của các khối resource.

    Ví dụ cơ bản này tạo một dự án Firebase mới, sau đó tạo một Ứng dụng Firebase cho Android trong dự án đó.

    # Terraform configuration to set up providers by version.
    ...
    
    # Configures the provider to use the resource block's specified project for quota checks.
    ...
    
    # Configures the provider to not use the resource block's specified project for quota checks.
    ...
    
    # Creates a new Google Cloud project.
    resource "google_project" "default" {
      provider   = google-beta.no_user_project_override
    
      name       = "Project Display Name"
      project_id = "project-id-for-new-project"
      # Required for any service that requires the Blaze pricing plan
      # (like Firebase Authentication with GCIP)
      billing_account = "000000-000000-000000"
    
      # Required for the project to display in any list of Firebase projects.
      labels = {
        "firebase" = "enabled"
      }
    }
    
    # Enables required APIs.
    resource "google_project_service" "default" {
      provider = google-beta.no_user_project_override
      project  = google_project.default.project_id
      for_each = toset([
        "cloudbilling.googleapis.com",
        "cloudresourcemanager.googleapis.com",
        "firebase.googleapis.com",
        # Enabling the ServiceUsage API allows the new project to be quota checked from now on.
        "serviceusage.googleapis.com",
      ])
      service = each.key
    
      # Don't disable the service if the resource block is removed by accident.
      disable_on_destroy = false
    }
    
    # Enables Firebase services for the new project created above.
    resource "google_firebase_project" "default" {
      provider = google-beta
      project  = google_project.default.project_id
    
      # Waits for the required APIs to be enabled.
      depends_on = [
        google_project_service.default
      ]
    }
    
    # Creates a Firebase Android App in the new project created above.
    resource "google_firebase_android_app" "default" {
      provider = google-beta
    
      project      = google_project.default.project_id
      display_name = "My Awesome Android app"
      package_name = "awesome.package.name"
    
      # Wait for Firebase to be enabled in the Google Cloud project before creating this App.
      depends_on = [
        google_firebase_project.default,
      ]
    }


Bước 2: Chạy các lệnh Terraform để tạo cơ sở hạ tầng được chỉ định

Để cung cấp tài nguyên và bật các dịch vụ được chỉ định trong tệp main.tf, hãy chạy các lệnh sau trong cùng thư mục với tệp main.tf. Để biết thông tin chi tiết về các lệnh này, hãy xem tài liệu về Terraform.

  1. Nếu đây là lần đầu tiên chạy các lệnh Terraform trong thư mục, bạn cần khởi động thư mục cấu hình và cài đặt trình cung cấp Google Terraform. Hãy thực hiện việc này bằng cách chạy lệnh sau:

    terraform init
  2. Tạo cơ sở hạ tầng được chỉ định trong tệp main.tf bằng cách chạy lệnh sau:

    terraform apply
  3. Xác nhận rằng mọi thứ đã được cung cấp hoặc bật như mong đợi:

    • Cách 1: Xem cấu hình được in trong cửa sổ dòng lệnh bằng cách chạy lệnh sau:

      terraform show
    • Cách 2: Xem dự án Firebase của bạn trong bảng điều khiển Firebase.



Các tài nguyên Firebase có hỗ trợ Terraform

Các tài nguyên sau đây của Firebase và Google có hỗ trợ Terraform. Chúng tôi liên tục bổ sung thêm các tài nguyên mới! Vì vậy, nếu bạn không thấy tài nguyên mà bạn muốn quản lý bằng Terraform, hãy kiểm tra lại sau để xem tài nguyên đó có sẵn hay không hoặc yêu cầu tài nguyên đó bằng cách gửi vấn đề trong kho lưu trữ GitHub.


Quản lý dự án và ứng dụng Firebase

  • google_firebase_project – bật các dịch vụ Firebase trên một dự án Google Cloud hiện có

  • Ứng dụng Firebase


Firebase Authentication

  • google_identity_platform_config – bật Google Cloud Identity Platform (GCIP) (là phần phụ trợ cho Firebase Authentication) và cung cấp chế độ cài đặt xác thực ở cấp dự án

    • Để định cấu hình Firebase Authentication thông qua Terraform, bạn cần bật GCIP. Nhớ xem tệp .tf mẫu để biết cách thiết lập Firebase Authentication.

    • Dự án mà Terraform sẽ bật GCIP và/hoặc Firebase Authentication phải thuộc gói giá Blaze (tức là dự án phải có tài khoản Cloud Billing được liên kết). Bạn có thể thực hiện việc này theo phương thức lập trình bằng cách đặt thuộc tính billing_account trong tài nguyên google_project.

    • Tài nguyên này cũng cho phép bạn thiết lập thêm nhiều cấu hình, chẳng hạn như các phương thức đăng nhập cục bộ (như xác thực ẩn danh, email/mật khẩu và điện thoại), cũng như các chức năng chặn và miền được uỷ quyền.

  • google_identity_platform_default_supported_idp_config – định cấu hình các Nhà cung cấp danh tính liên kết phổ biến, chẳng hạn như Google, Facebook hoặc Apple

  • identity_platform_oauth_idp_config – định cấu hình các nguồn Nhà cung cấp danh tính (IdP) OAuth tuỳ ý

  • google_identity_platform_inbound_saml_config – định cấu hình chế độ tích hợp SAML

Chưa được hỗ trợ:

  • Định cấu hình tính năng xác thực đa yếu tố (MFA) thông qua Terraform

Firebase App Hosting

  • google_firebase_app_hosting_backend – tạo và quản lý một phần phụ trợ Firebase App Hosting, bao gồm cả kết nối kho lưu trữ GitHub và nhánh trực tiếp để triển khai liên tục.

  • google_firebase_app_hosting_build – tạo bản dựng cho một phần phụ trợ, tại một thẻ tham chiếu cơ sở mã và thời điểm cụ thể.

  • google_firebase_app_hosting_traffic – triển khai bản dựng hoặc định cấu hình quy trình triển khai liên tục trên GitHub.


Firebase Data Connect


Firebase Realtime Database

Chưa được hỗ trợ:

  • Triển khai Firebase Realtime Database Security Rules thông qua Terraform (tìm hiểu cách triển khai Rules này bằng các công cụ khác, bao gồm cả các lựa chọn có thể lập trình)

Cloud Firestore

  • google_firestore_database – tạo một phiên bản Cloud Firestore

  • google_firestore_index – cho phép truy vấn hiệu quả cho Cloud Firestore

  • google_firestore_document – khởi tạo một thực thể Cloud Firestore bằng một tài liệu cụ thể trong một bộ sưu tập

    Quan trọng: Không sử dụng dữ liệu thực của người dùng cuối hoặc dữ liệu sản xuất trong tài liệu ban đầu này.


Cloud Storage for Firebase

  • google_firebase_storage_bucket – cho phép Firebase SDK, tính năng xác thực và Firebase Security Rules truy cập vào một vùng chứa Cloud Storage hiện có

  • google_storage_bucket_object – thêm một đối tượng vào một vùng chứa Cloud Storage

    Quan trọng: Không sử dụng dữ liệu thực của người dùng cuối hoặc dữ liệu sản xuất trong tệp này.


Firebase Security Rules (cho Cloud FirestoreCloud Storage)

Xin lưu ý rằng Firebase Realtime Database sử dụng một hệ thống cung cấp khác cho Firebase Security Rules.

  • google_firebaserules_ruleset – xác định Firebase Security Rules áp dụng cho một thực thể Cloud Firestore hoặc một nhóm Cloud Storage

  • google_firebaserules_release – triển khai các quy tắc cụ thể cho một phiên bản Cloud Firestore hoặc một vùng chứa Cloud Storage


Firebase App Check


Firebase Extensions



Tệp cấu hình Terraform mẫu cho các trường hợp sử dụng phổ biến



Khắc phục sự cố và câu hỏi thường gặp