Kết hợp Cloud Run với Firebase Hosting để tạo và phân phát nội dung động hoặc xây dựng API REST dưới dạng các dịch vụ vi mô.
Khi sử dụng Cloud Run, bạn có thể triển khai một ứng dụng được đóng gói trong hình ảnh vùng chứa. Sau đó, khi sử dụng Firebase Hosting, bạn có thể chuyển các yêu cầu HTTPS để kích hoạt ứng dụng được vùng chứa hoá.
- Cloud Run hỗ trợ một số ngôn ngữ (bao gồm Go, Node.js, Python và Java), giúp bạn linh hoạt sử dụng ngôn ngữ lập trình và khung mà bạn chọn.
- Cloud Run tự động và theo chiều ngang mở rộng hình ảnh vùng chứa để xử lý các yêu cầu nhận được, sau đó thu hẹp khi nhu cầu giảm.
- Bạn chỉ phải trả tiền cho CPU, bộ nhớ và mạng đã dùng trong quá trình xử lý yêu cầu.
Để xem các trường hợp sử dụng mẫu và mẫu cho Cloud Run được tích hợp với Firebase Hosting, hãy truy cập vào phần tổng quan về máy chủ phi máy chủ.
Hướng dẫn này sẽ chỉ cho bạn cách:
- Viết một ứng dụng Hello World đơn giản
- Vùng chứa hoá một ứng dụng và tải ứng dụng đó lên Artifact Registry
- Triển khai hình ảnh vùng chứa lên Cloud Run
- Chuyển Hosting các yêu cầu Hosting đến ứng dụng được vùng chứa hoá
Xin lưu ý rằng để cải thiện hiệu suất phân phát nội dung động, bạn có thể điều chỉnh các chế độ cài đặt bộ nhớ đệm (không bắt buộc).
Trước khi bắt đầu
Trước khi sử dụng Cloud Run, bạn cần hoàn tất một số tác vụ ban đầu,
bao gồm thiết lập tài khoản Cloud Billing, bật Cloud Run
API và cài đặt công cụ dòng lệnh gcloud.
Thiết lập thông tin thanh toán cho dự án của bạn
Cloud Run cung cấp hạn mức sử dụng miễn phí, nhưng bạn vẫn phải có một Cloud Billing tài khoản được liên kết với dự án Firebase để sử dụng hoặc dùng thử Cloud Run.
Bật API và cài đặt SDK
Bật Cloud Run API trong bảng điều khiển Google APIs:
Khi được nhắc, hãy chọn dự án Firebase.
Nhấp vào Bật trên trang API Cloud Run.
Cài đặt và khởi chạy Cloud SDK.
Kiểm tra để đảm bảo công cụ
gcloudđược định cấu hình cho đúng dự án:gcloud config list
Bước 1: Viết ứng dụng mẫu
Xin lưu ý rằng Cloud Run hỗ trợ nhiều ngôn ngữ khác ngoài các ngôn ngữ được hiển thị trong mẫu sau.
Bắt đầu
Tạo một thư mục mới có tên là
helloworld-go, sau đó thay đổi thư mục thành thư mục đó:mkdir helloworld-go
cd helloworld-go
Tạo một tệp mới có tên là
helloworld.go, sau đó thêm mã sau:Mã này tạo một máy chủ web cơ bản, lắng nghe trên cổng do biến môi trường
PORTxác định.
Ứng dụng của bạn đã hoàn tất và sẵn sàng được vùng chứa hoá và tải lên Artifact Registry.
Node.js
Tạo một thư mục mới có tên là
helloworld-nodejs, sau đó thay đổi thư mục thành thư mục đó:mkdir helloworld-nodejs
cd helloworld-nodejs
Tạo một tệp
package.jsoncó nội dung sau:Tạo một tệp mới có tên là
index.js, sau đó thêm mã sau:Mã này tạo một máy chủ web cơ bản, lắng nghe trên cổng do biến môi trường
PORTxác định.
Ứng dụng của bạn đã hoàn tất và sẵn sàng được vùng chứa hoá và tải lên Artifact Registry.
Python
Tạo một thư mục mới có tên là
helloworld-python, sau đó thay đổi thư mục thành thư mục đó:mkdir helloworld-python
cd helloworld-python
Tạo một tệp mới có tên là
app.py, sau đó thêm mã sau:Mã này tạo một máy chủ web cơ bản, lắng nghe trên cổng do biến môi trường
PORTxác định.
Ứng dụng của bạn đã hoàn tất và sẵn sàng được vùng chứa hoá và tải lên Artifact Registry.
Java
Cài đặt Java SE 8 trở lên JDK và CURL.
Xin lưu ý rằng chúng ta chỉ cần thực hiện việc này để tạo dự án web mới ở bước tiếp theo. Dockerfile (được mô tả sau) sẽ tải tất cả các phần phụ thuộc vào vùng chứa.
Từ bảng điều khiển, hãy tạo một dự án web trống mới bằng cách sử dụng cURL rồi giải nén các lệnh:
curl https://start.spring.io/starter.zip \ -d dependencies=web \ -d name=helloworld \ -d artifactId=helloworld \ -o helloworld.zipunzip helloworld.zip
Thao tác này sẽ tạo một dự án SpringBoot.
Cập nhật lớp
SpringBootApplicationtrongsrc/main/java/com/example/helloworld/HelloworldApplication.javabằng cách thêm@RestControllerđể xử lý việc ánh xạ/và cũng thêm một@Valuetrường để cung cấp biến môi trườngTARGET:Mã này tạo một máy chủ web cơ bản, lắng nghe trên cổng do biến môi trường
PORTxác định.
Ứng dụng của bạn đã hoàn tất và sẵn sàng được vùng chứa hoá và tải lên Artifact Registry.
Bước 2: Vùng chứa hoá một ứng dụng và tải ứng dụng đó lên Artifact Registry
Vùng chứa hoá ứng dụng mẫu bằng cách tạo một tệp mới có tên là
Dockerfiletrong cùng thư mục với các tệp nguồn. Sao chép nội dung sau vào tệp của bạn.Bắt đầu
Node.js
Python
Java
Tạo hình ảnh vùng chứa bằng Cloud Build bằng cách chạy lệnh sau từ thư mục chứa Dockerfile:
gcloud builds submit --tag gcr.io/PROJECT_ID/helloworld
Sau khi thành công, bạn sẽ thấy một thông báo THÀNH CÔNG có chứa tên hình ảnh
(gcr.io/PROJECT_ID/helloworld).
Hình ảnh vùng chứa hiện được lưu trữ trong Artifact Registry và có thể được sử dụng lại nếu muốn.
Xin lưu ý rằng thay vì Cloud Build, bạn có thể sử dụng phiên bản Docker được cài đặt cục bộ để tạo vùng chứa cục bộ.
Bước 3: Triển khai hình ảnh vùng chứa lên Cloud Run
Triển khai bằng lệnh sau:
gcloud run deploy --image gcr.io/PROJECT_ID/helloworld
Khi được nhắc:
- Chọn một khu vực (ví dụ:
us-central1) - Xác nhận tên dịch vụ (ví dụ:
helloworld) - Trả lời
Yđể cho phép các lệnh gọi chưa được xác thực
- Chọn một khu vực (ví dụ:
Chờ một lát để quá trình triển khai hoàn tất. Khi thành công, dòng lệnh sẽ hiển thị URL dịch vụ. Ví dụ:
https://helloworld-RANDOM_HASH-us-central1.a.run.app Truy cập vào vùng chứa đã triển khai bằng cách mở URL dịch vụ trong trình duyệt web.
Bước tiếp theo sẽ hướng dẫn bạn cách truy cập vào ứng dụng được vùng chứa hoá này từ Firebase Hosting URL để ứng dụng có thể tạo nội dung động cho trang web được lưu trữ trên Firebase.
Bước 4: Chuyển các yêu cầu Hosting đến ứng dụng được vùng chứa hoá
Với các quy tắc viết lại, bạn có thể chuyển các yêu cầu khớp với các mẫu cụ thể đến một đích đến duy nhất.
Ví dụ sau đây cho biết cách chuyển tất cả các yêu cầu từ trang
/helloworld trên trang web Hosting để kích hoạt quá trình khởi động và chạy
phiên bản vùng chứa helloworld.
Đảm bảo rằng:
Bạn có phiên bản mới nhất của CLIFirebase.
Bạn đã khởi chạy Firebase Hosting.
Để biết hướng dẫn chi tiết về cách cài đặt CLI và khởi chạy Hosting, hãy xem hướng dẫn Bắt đầu sử dụng Hosting.
Mở tệp
firebase.json.Thêm cấu hình
rewritesau vào phầnhosting:"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) "pinTag": true // optional (see note below) } } ] }
Triển khai cấu hình Lưu trữ lên trang web của bạn bằng cách chạy lệnh sau từ gốc thư mục dự án:
firebase deploy --only hosting
Giờ đây, bạn có thể truy cập vào vùng chứa thông qua các URL sau:
Các miền con Firebase:
PROJECT_ID.web.app/vàPROJECT_ID.firebaseapp.com/Mọi miền tuỳ chỉnh được kết nối:
CUSTOM_DOMAIN/
Hãy truy cập vào trang cấu hình Hosting để biết thêm thông tin chi tiết về các quy tắc viết lại . Bạn cũng có thể tìm hiểu về thứ tự ưu tiên của các phản hồi cho nhiều Hosting cấu hình.
Kiểm thử cục bộ
Trong quá trình phát triển, bạn có thể chạy và kiểm thử hình ảnh vùng chứa cục bộ. Để biết hướng dẫn chi tiết, hãy truy cập vào Cloud Run tài liệu.
Các bước tiếp theo
Thiết lập tính năng lưu vào bộ nhớ đệm cho nội dung động trên CDN toàn cầu.
Tương tác với các dịch vụ Firebase khác bằng SDK của Firebase dành cho quản trị viên.
Tìm hiểu thêm về Cloud Run, bao gồm hướng dẫn chi tiết về cách thiết lập, quản lý và định cấu hình vùng chứa.
Xem giá cũng như hạn mức và giới hạn cho Cloud Run.