1. Tổng quan
Loạt lớp học lập trình này (hướng dẫn thực hành, tự học) nhằm giúp nhà phát triển hiểu rõ các lựa chọn mà họ có khi triển khai ứng dụng. Trong lớp học lập trình này, bạn sẽ tìm hiểu cách sử dụng API Dịch của Google Cloud bằng Python và chạy trên máy hoặc triển khai lên nền tảng điện toán không có máy chủ trên Google Cloud (App Engine, Cloud Functions hoặc Cloud Run). Ứng dụng mẫu có trong kho lưu trữ của hướng dẫn này có thể được triển khai theo (ít nhất) 8 cách khác nhau mà chỉ cần thay đổi cấu hình nhỏ:
- Máy chủ Flask cục bộ (Python 2)
- Máy chủ Flask cục bộ (Python 3)
- App Engine (Python 2)
- App Engine (Python 3)
- Cloud Functions (Python 3)
- Cloud Run (Python 2 thông qua Docker)
- Cloud Run (Python 3 thông qua Docker)
- Cloud Run (Python 3 thông qua Cloud Buildpacks)
Lớp học lập trình này tập trung vào việc triển khai ứng dụng này cho(các) nền tảng in đậm ở trên.
Bạn sẽ tìm hiểu cách
- Sử dụng API Google Cloud, cụ thể là API Dịch trên đám mây (nâng cao/phiên bản 3)
- Chạy một ứng dụng web cơ bản trên máy hoặc triển khai trên nền tảng điện toán không có máy chủ trên đám mây
Bạn cần có
- Dự án trên Google Cloud có tài khoản Cloud Billing đang hoạt động
- Đã cài đặt Flask để chạy cục bộ hoặc đã bật nền tảng điện toán không có máy chủ trên đám mây cho các bản triển khai dựa trên đám mây
- Kỹ năng cơ bản về Python
- Có kiến thức cơ bản về các lệnh hệ điều hành
Bài khảo sát
Bạn sẽ sử dụng hướng dẫn này như thế nào?
Bạn đánh giá thế nào về trải nghiệm của mình với Python?
Bạn đánh giá trải nghiệm sử dụng các dịch vụ của Google Cloud như thế nào?
2. Cách thiết lập và yêu cầu
Thiết lập môi trường theo tốc độ của riêng bạn
- Đăng nhập vào Google Cloud Console rồi tạo một dự án mới hoặc sử dụng lại một dự án hiện có. Nếu chưa có tài khoản Gmail hoặc Google Workspace, bạn phải tạo một tài khoản.
- Tên dự án là tên hiển thị cho người tham gia dự án này. Đây là một chuỗi ký tự không được API của Google sử dụng và bạn có thể cập nhật chuỗi này bất cứ lúc nào.
- Mã dự án phải là duy nhất trên tất cả các dự án Google Cloud và không thể thay đổi được (không thể thay đổi sau khi đặt). Cloud Console sẽ tự động tạo một chuỗi duy nhất; thường thì bạn không cần quan tâm đến chuỗi này. Trong hầu hết các lớp học lập trình, bạn sẽ cần tham chiếu đến Mã dự án (và mã này thường được xác định là
PROJECT_ID
). Vì vậy, nếu không thích mã này, hãy tạo một mã ngẫu nhiên khác hoặc bạn có thể thử mã của riêng mình và xem mã đó có được chấp nhận hay không. Sau đó, tệp này sẽ "đóng băng" sau khi dự án được tạo. - Có một giá trị thứ ba là Mã dự án mà một số API sử dụng. Tìm hiểu thêm về cả ba giá trị này trong tài liệu.
- Tiếp theo, bạn cần bật tính năng thanh toán trong Cloud Console để sử dụng các tài nguyên/API trên Cloud. Việc tham gia lớp học lập trình này sẽ không tốn kém nhiều chi phí, nếu có. Để tắt các tài nguyên để không bị tính phí sau khi kết thúc hướng dẫn này, hãy làm theo hướng dẫn "dọn dẹp" ở cuối lớp học lập trình. Người dùng mới của Google Cloud đủ điều kiện tham gia chương trình Dùng thử miễn phí 300 USD.
3. Bật API dịch
Bật Cloud API
Trong phần này, bạn sẽ tìm hiểu cách bật API Google nói chung. Đối với ứng dụng mẫu của chúng tôi, bạn sẽ bật Cloud Translation API, Cloud Run và Cloud Artifact Registry.
Giới thiệu
Bất kể bạn muốn sử dụng API Google nào trong ứng dụng, bạn đều phải bật các API đó. Ví dụ sau đây cho thấy hai cách để bật API Cloud Vision. Sau khi tìm hiểu cách bật một Cloud API, bạn có thể bật các API khác vì quy trình này tương tự.
Cách 1: Từ Cloud Shell hoặc giao diện dòng lệnh
Mặc dù việc bật API từ Cloud Console phổ biến hơn, nhưng một số nhà phát triển lại thích làm mọi việc từ dòng lệnh. Để làm như vậy, bạn cần tra cứu "tên dịch vụ" của API. Mã này có dạng như một URL: SERVICE_NAME
.googleapis.com
. Bạn có thể tìm thấy các sản phẩm này trong Biểu đồ sản phẩm được hỗ trợ hoặc bạn có thể truy vấn các sản phẩm này theo phương thức lập trình bằng Google Discovery API.
Khi đã có thông tin này, bạn có thể sử dụng Cloud Shell (hoặc môi trường phát triển cục bộ đã cài đặt công cụ dòng lệnh gcloud
) để bật một API như sau:
gcloud services enable SERVICE_NAME.googleapis.com
Ví dụ: lệnh này bật Cloud Vision API:
gcloud services enable vision.googleapis.com
Lệnh này bật App Engine:
gcloud services enable appengine.googleapis.com
Bạn cũng có thể bật nhiều API bằng một yêu cầu. Ví dụ: dòng lệnh này bật Cloud Run, Cloud Artifact Registry và Cloud Translation API:
gcloud services enable artifactregistry.googleapis.com run.googleapis.com translate.googleapis.com
Cách 2: Trong Bảng điều khiển Google Cloud
Bạn cũng có thể bật API Vision trong Trình quản lý API. Trên Cloud Console, hãy chuyển đến Trình quản lý API rồi chọn Thư viện.
Nếu bạn muốn bật API Cloud Vision, hãy bắt đầu nhập "vision" (tầm nhìn) vào thanh tìm kiếm. Mọi nội dung khớp với nội dung bạn đã nhập cho đến thời điểm này sẽ xuất hiện:
Chọn API bạn muốn bật rồi nhấp vào Bật:
Chi phí
Mặc dù bạn có thể sử dụng nhiều API của Google mà không mất phí, nhưng việc sử dụng các sản phẩm và API của Google Cloud không miễn phí. Khi bật API đám mây, bạn có thể được yêu cầu cung cấp một tài khoản thanh toán đang hoạt động. Tuy nhiên, điều quan trọng cần lưu ý là một số sản phẩm của Google Cloud có cấp "Luôn miễn phí" (hằng ngày/hằng tháng). Bạn phải vượt quá cấp này thì mới phải trả phí; nếu không, thẻ tín dụng (hoặc phương thức thanh toán đã chỉ định) của bạn sẽ không bị tính phí.
Người dùng nên tham khảo thông tin về giá của mọi API trước khi bật, đặc biệt là lưu ý xem API đó có cấp miễn phí hay không và nếu có thì cấp đó là gì. Nếu đang bật API Cloud Vision, bạn sẽ kiểm tra trang thông tin về giá của API đó. Cloud Vision có hạn mức miễn phí. Miễn là bạn tuân thủ hạn mức tổng thể (trong mỗi tháng), bạn sẽ không phải trả phí.
Mức giá và các cấp miễn phí khác nhau giữa các API của Google. Ví dụ:
- Google Cloud/GCP – mỗi sản phẩm được tính phí theo cách khác nhau và thường là trả phí theo chu kỳ vCPU, người dùng bộ nhớ, mức sử dụng bộ nhớ hoặc trả phí theo mức sử dụng; xem thông tin về cấp miễn phí ở trên.
- Google Maps – cung cấp một bộ API và tặng người dùng 200 USD tín dụng miễn phí mỗi tháng.
- API Google Workspace (trước đây là G Suite) – cung cấp quyền sử dụng miễn phí (tối đa đến một số giới hạn nhất định) trong phạm vi phí thuê bao Workspace hằng tháng, vì vậy, bạn sẽ không bị tính phí trực tiếp khi sử dụng API Gmail, Google Drive, Lịch, Tài liệu, Trang tính và Trang trình bày.
Các sản phẩm của Google được tính phí theo cách khác nhau, vì vậy, hãy nhớ tham khảo tài liệu của API để biết thông tin đó.
Tóm tắt
Giờ đây, bạn đã biết cách bật API của Google nói chung, hãy chuyển đến Trình quản lý API rồi bật Cloud Translation API, Cloud Run và Cloud Artifact Registry (nếu bạn chưa bật). Bạn bật quyền truy cập trước đó vì ứng dụng của chúng tôi sử dụng quyền này. Bạn bật tính năng này vì đó là nơi lưu trữ hình ảnh vùng chứa của chúng tôi trước khi được triển khai để bắt đầu dịch vụ Cloud Run. Đó là lý do bạn phải bật tính năng đó. Nếu bạn muốn bật tất cả các tính năng này bằng công cụ gcloud
, hãy đưa ra lệnh sau từ thiết bị đầu cuối:
gcloud services enable artifactregistry.googleapis.com run.googleapis.com translate.googleapis.com
Mặc dù hạn mức hằng tháng không được liệt kê trong trang tóm tắt tổng thể về cấp "Luôn miễn phí", nhưng trang giá của API Dịch cho biết tất cả người dùng đều nhận được một lượng ký tự được dịch cố định hằng tháng. Bạn sẽ không phải trả bất kỳ khoản phí nào từ API nếu vẫn ở dưới ngưỡng đó. Nếu có bất kỳ khoản phí nào khác liên quan đến Google Cloud, chúng tôi sẽ thảo luận về các khoản phí đó ở phần cuối trong mục "Dọn dẹp".
4. Tải mã ứng dụng mẫu
Sao chép mã trong kho lưu trữ trên máy hoặc trong Cloud Shell (bằng lệnh git clone
) hoặc tải tệp ZIP xuống qua nút Mã màu xanh lục như trong ảnh chụp màn hình sau:
Giờ thì bạn đã có mọi thứ, hãy tạo một bản sao đầy đủ của thư mục để thực hiện hướng dẫn cụ thể này, vì hướng dẫn này có thể liên quan đến việc xoá hoặc thay đổi các tệp. Nếu muốn triển khai một cách khác, bạn có thể bắt đầu lại bằng cách sao chép bản gốc để không phải sao chép hoặc tải xuống lại.
5. Tham quan ứng dụng mẫu
Ứng dụng mẫu là một sản phẩm phái sinh đơn giản của Google Dịch, nhắc người dùng nhập văn bản bằng tiếng Anh và nhận bản dịch tương đương của văn bản đó bằng tiếng Tây Ban Nha. Bây giờ, hãy mở tệp main.py
để xem cách hoạt động. Nếu bỏ qua các dòng có chú thích về việc cấp phép, thì ở đầu và cuối tệp sẽ có nội dung như sau:
from flask import Flask, render_template, request
import google.auth
from google.cloud import translate
app = Flask(__name__)
_, PROJECT_ID = google.auth.default()
TRANSLATE = translate.TranslationServiceClient()
PARENT = 'projects/{}'.format(PROJECT_ID)
SOURCE, TARGET = ('en', 'English'), ('es', 'Spanish')
# . . . [translate() function definition] . . .
if __name__ == '__main__':
import os
app.run(debug=True, threaded=True, host='0.0.0.0',
port=int(os.environ.get('PORT', 8080)))
- Các lệnh nhập này mang lại chức năng Flask, mô-đun
google.auth
và thư viện ứng dụng API Dịch trên đám mây. - Các biến toàn cục đại diện cho ứng dụng Flask, mã dự án trên Google Cloud, ứng dụng API Dịch, "đường dẫn vị trí" gốc cho các lệnh gọi API Dịch, cũng như ngôn ngữ nguồn và ngôn ngữ đích. Trong trường hợp này, đó là tiếng Anh (
en
) và tiếng Tây Ban Nha (es
), nhưng bạn có thể thay đổi các giá trị này thành mã ngôn ngữ khác do Cloud Translation API hỗ trợ. - Khối
if
lớn ở dưới cùng được dùng trong hướng dẫn chạy ứng dụng này trên máy – khối này sử dụng máy chủ phát triển Flask để phân phát ứng dụng của chúng ta. Phần này cũng có trong hướng dẫn triển khai Cloud Run trong trường hợp máy chủ web không được đóng gói vào vùng chứa. Bạn sẽ được yêu cầu bật tính năng đóng gói máy chủ trong vùng chứa, nhưng trong trường hợp bạn bỏ qua việc này, mã ứng dụng sẽ quay lại sử dụng máy chủ phát triển Flask. (Đây không phải là vấn đề với App Engine hoặc Cloud Functions vì đó là các nền tảng dựa trên nguồn, nghĩa là Google Cloud cung cấp và chạy một máy chủ web mặc định.)
Cuối cùng, ở giữa main.py
là phần cốt lõi của ứng dụng, hàm translate()
:
@app.route('/', methods=['GET', 'POST'])
def translate(gcf_request=None):
"""
main handler - show form and possibly previous translation
"""
# Flask Request object passed in for Cloud Functions
# (use gcf_request for GCF but flask.request otherwise)
local_request = gcf_request if gcf_request else request
# reset all variables (GET)
text = translated = None
# if there is data to process (POST)
if local_request.method == 'POST':
text = local_request.form['text']
data = {
'contents': [text],
'parent': PARENT,
'target_language_code': TARGET[0],
}
# handle older call for backwards-compatibility
try:
rsp = TRANSLATE.translate_text(request=data)
except TypeError:
rsp = TRANSLATE.translate_text(**data)
translated = rsp.translations[0].translated_text
# create context & render template
context = {
'orig': {'text': text, 'lc': SOURCE},
'trans': {'text': translated, 'lc': TARGET},
}
return render_template('index.html', **context)
Hàm chính thực hiện việc nhập dữ liệu của người dùng và gọi API Dịch để thực hiện các thao tác phức tạp. Hãy cùng phân tích:
- Kiểm tra xem các yêu cầu có đến từ Cloud Functions hay không bằng cách sử dụng biến
local_request
. Cloud Functions gửi đối tượng Yêu cầu Flask của riêng mình, trong khi tất cả các đối tượng khác (chạy cục bộ hoặc triển khai lên App Engine hoặc Cloud Run) sẽ nhận được đối tượng yêu cầu trực tiếp từ Flask. - Đặt lại các biến cơ bản cho biểu mẫu. Điều này chủ yếu dành cho các yêu cầu GET vì các yêu cầu POST sẽ có dữ liệu thay thế các yêu cầu này.
- Nếu đó là yêu cầu POST, hãy lấy văn bản cần dịch và tạo một cấu trúc JSON thể hiện yêu cầu về siêu dữ liệu API. Sau đó, hãy gọi API, quay lại phiên bản API trước đó nếu người dùng đang sử dụng một thư viện cũ.
- Dù sao đi nữa, hãy định dạng kết quả thực tế (POST) hoặc không có dữ liệu (GET) vào ngữ cảnh mẫu và hiển thị.
Phần hình ảnh của ứng dụng nằm trong tệp index.html
của mẫu. Trang này hiển thị mọi kết quả đã dịch trước đó (nếu không thì sẽ để trống), theo sau là biểu mẫu yêu cầu nội dung cần dịch:
<!doctype html>
<html><head><title>My Google Translate 1990s</title><body>
<h2>My Google Translate (1990s edition)</h2>
{% if trans['text'] %}
<h4>Previous translation</h4>
<li><b>Original</b>: {{ orig['text'] }} (<i>{{ orig['lc'][0] }}</i>)</li>
<li><b>Translated</b>: {{ trans['text'] }} (<i>{{ trans['lc'][0] }}</i>)</li>
{% endif %}
<h4>Enter <i>{{ orig['lc'][1] }}</i> text to translate to <i>{{ trans['lc'][1] }}</i>:</h4>
<form method="POST"><input name="text"><input type="submit"></form>
</body></html>
6. Thiết lập Docker để tạo hình ảnh Python 3
Bây giờ, hãy mở tệp Dockerfile
. Tệp này sẽ có dạng như sau nếu không có thông tin giấy phép:
#FROM python:3-slim
FROM python:2-slim
WORKDIR /app
COPY . .
RUN pip install -r requirements.txt
ENTRYPOINT ["python", "main.py"]
Như bạn có thể thấy, theo mặc định, trình biên dịch này được thiết lập cho Python 2. Vì vậy, hãy thay đổi điều đó bằng cách chỉnh sửa dòng FROM
từ python:2-slim
thành python:3-slim
hoặc bỏ ghi chú dòng trên cùng và xoá dòng FROM
cũ. Khi hoàn tất, Dockerfile
sẽ có dạng như sau:
FROM python:3-slim
WORKDIR /app
COPY . .
RUN pip install -r requirements.txt
ENTRYPOINT ["python", "main.py"]
7. Triển khai dịch vụ
Giờ đây, bạn đã sẵn sàng triển khai dịch vụ dịch sang Cloud Run bằng cách chạy lệnh sau:
gcloud run deploy translate --source . --allow-unauthenticated --platform managed
Kết quả sẽ có dạng như sau và đưa ra một số lời nhắc cho các bước tiếp theo:
$ gcloud run deploy translate --source . --allow-unauthenticated --platform managed Please specify a region: [1] asia-east1 [2] asia-east2 . . . (other regions) . . . [28] us-west4 [29] cancel Please enter your numeric choice: REGION_CHOICE To make this the default region, run `gcloud config set run/region REGION`. Deploying from source requires an Artifact Registry repository to store build artifacts. A repository named [cloud-run-source-deploy] in region [REGION] will be created. Do you want to continue (Y/n)? This command is equivalent to running "gcloud builds submit --pack image=[IMAGE] ." and "gcloud run deploy translate --image [IMAGE]" Building . . . and deploying container to Cloud Run service [translate] in project [PROJECT_ID] region [REGION] ✓ Building and deploying... Done. ✓ Creating Container Repository... ✓ Uploading sources... ✓ Building Container... Logs are available at [https://console.cloud.google.com/cloud-build/builds/60e1b 9bb-b991-4b4e-8d8a-HASH?project=PROJECT_NUMBER]. ✓ Creating Revision... ✓ Routing traffic... ✓ Setting IAM Policy... Done. Service [translate] revision [translate-00001-xyz] has been deployed and is serving 100 percent of traffic. Service URL: https://SVC_NAME-HASH-REG_ABBR.a.run.app
Giờ đây, ứng dụng của bạn đã có trên toàn cầu, bạn có thể truy cập vào ứng dụng đó tại URL chứa mã dự án của bạn như trong kết quả triển khai:
Hãy dịch một nội dung nào đó để xem tính năng này hoạt động như thế nào!
8. Kết luận
Xin chúc mừng! Bạn đã tìm hiểu cách bật Cloud Translation API, lấy thông tin xác thực cần thiết và triển khai một ứng dụng web đơn giản cho Python 3 Cloud Run!
Dọn dẹp
Cloud Translation API cho phép bạn thực hiện một số lượng ký tự được dịch cố định mỗi tháng mà không mất phí. App Engine cũng có hạn mức miễn phí, tương tự như Cloud Functions và Cloud Run. Bạn sẽ phải trả phí nếu vượt quá một trong hai hạn mức này. Nếu dự định tiếp tục lớp học lập trình tiếp theo, bạn không cần phải tắt ứng dụng.
Tuy nhiên, nếu bạn chưa sẵn sàng chuyển sang phần hướng dẫn tiếp theo hoặc lo ngại rằng Internet sẽ phát hiện ứng dụng mà bạn vừa triển khai, hãy tắt ứng dụng App Engine, xoá Hàm trên đám mây hoặc tắt dịch vụ Cloud Run để tránh bị tính phí. Khi đã sẵn sàng chuyển sang lớp học lập trình tiếp theo, bạn có thể bật lại tính năng này. Mặt khác, nếu không tiếp tục với ứng dụng này hoặc các lớp học lập trình khác và muốn xoá mọi thứ hoàn toàn, bạn có thể tắt dự án.
Ngoài ra, việc triển khai lên nền tảng điện toán không máy chủ của Google Cloud sẽ gây ra một số chi phí nhỏ về việc xây dựng và lưu trữ. Cloud Build có hạn mức miễn phí riêng, cũng như Cloud Storage. Để tăng tính minh bạch, Cloud Build sẽ tạo hình ảnh ứng dụng của bạn, sau đó lưu trữ hình ảnh đó trong Cloud Container Registry (Kho lưu trữ vùng chứa trên đám mây) hoặc Artifact Registry (Kho lưu trữ cấu phần phần mềm), phiên bản kế nhiệm của Cloud Container Registry. Việc lưu trữ hình ảnh đó sẽ sử dụng một phần hạn mức đó cũng như lưu lượng truy cập mạng khi chuyển hình ảnh đó đến dịch vụ. Tuy nhiên, bạn có thể sống ở một khu vực không có cấp miễn phí như vậy. Vì vậy, hãy lưu ý đến mức sử dụng bộ nhớ để giảm thiểu chi phí tiềm ẩn.
9. Tài nguyên khác
Trong các phần sau, bạn có thể tìm thấy tài liệu đọc bổ sung cũng như các bài tập được đề xuất để mở rộng kiến thức đã có được sau khi hoàn thành hướng dẫn này.
Nghiên cứu bổ sung
Giờ đây, khi bạn đã có một số kinh nghiệm với API Dịch, hãy làm một số bài tập bổ sung để phát triển thêm kỹ năng của bạn. Để tiếp tục lộ trình học tập, hãy sửa đổi ứng dụng mẫu của chúng tôi để thực hiện những việc sau:
- Hoàn tất tất cả các phiên bản khác của lớp học lập trình này để chạy cục bộ hoặc triển khai trên các nền tảng điện toán không có máy chủ của Google Cloud (xem README của kho lưu trữ).
- Hoàn thành hướng dẫn này bằng một ngôn ngữ lập trình khác.
- Thay đổi ứng dụng này để hỗ trợ nhiều ngôn ngữ nguồn hoặc đích.
- Nâng cấp ứng dụng này để có thể dịch văn bản sang nhiều ngôn ngữ; thay đổi tệp mẫu để có trình đơn thả xuống gồm các ngôn ngữ đích được hỗ trợ.
Tìm hiểu thêm
Google App Engine
- Trang chủ App Engine
- Tài liệu về App Engine
- Bài viết nhanh về App Engine Python 3
- Tài khoản dịch vụ mặc định cho App Engine
- Thời gian chạy Python 2 App Engine (Chuẩn)
- Thời gian chạy Python 3 App Engine (Chuẩn)
- Sự khác biệt giữa thời gian chạy Python 2 và 3 trên App Engine (Chuẩn)
- Hướng dẫn di chuyển Python 2 sang 3 App Engine (Chuẩn)
Google Cloud Functions
- Trang chủ của Cloud Functions
- Tài liệu về Cloud Functions
- Hướng dẫn bắt đầu nhanh về Cloud Functions bằng Python
- Tài khoản dịch vụ mặc định cho Cloud Functions
Google Cloud Run
- Trang chủ Cloud Run
- Tài liệu về Cloud Run
- Hướng dẫn nhanh về Python Cloud Run
- Tài khoản dịch vụ mặc định cho Cloud Run
Google Cloud Buildpacks, Container Registry, Artifact Registry
- Thông báo về Cloud Buildpacks
- Kho lưu trữ Cloud Buildpacks
- Trang chủ của Cloud Artifact Registry
- Tài liệu về Cloud Artifact Registry
- Trang chủ của Cloud Container Registry
- Tài liệu về Cloud Container Registry
Google Cloud Translation và Bộ công cụ máy học của Google
- Trang chủ của Cloud Translation
- Tài liệu về Cloud Translation
- Trang giá của API Dịch
- Tất cả API "khối xây dựng" AI/ML trên đám mây
- Bộ công cụ học máy của Google (nhóm nhỏ API AI/ML trên đám mây dành cho thiết bị di động)
- API dịch của Bộ công cụ học máy của Google
Các sản phẩm/trang khác của Google Cloud
- Hỗ trợ Python trên Google Cloud
- Thư viện ứng dụng Google Cloud
- Cấp "Luôn miễn phí" của Google Cloud
- Tất cả tài liệu về Google Cloud
Python và Flask
Giấy phép
Hướng dẫn này được cấp phép theo Giấy phép chung Ghi nhận tác giả 2.0 của Creative Commons, còn mã nguồn trong kho lưu trữ được cấp phép theo Apache 2.