Mulai menggunakan Python

Tutorial ini ditujukan bagi mereka yang baru membuat aplikasi di cloud, seperti engineer dan developer web, yang ingin mempelajari konsep utama pengembangan aplikasi sebagaimana yang berlaku untuk Google Cloud.

Tujuan

Biaya

Dalam dokumen ini, Anda akan menggunakan komponen Google Cloudyang dapat ditagih berikut:

Petunjuk dalam dokumen ini dirancang untuk menjaga agar penggunaan resource Anda tetap dalam batasan paket Always Free Google Cloud. Untuk membuat perkiraan biaya berdasarkan proyeksi penggunaan Anda, gunakan kalkulator harga.

Pengguna Google Cloud baru mungkin memenuhi syarat untuk mendapatkan uji coba gratis.

Setelah menyelesaikan tugas yang dijelaskan dalam dokumen ini, Anda dapat menghindari penagihan berkelanjutan dengan menghapus resource yang Anda buat. Untuk mengetahui informasi selengkapnya, baca bagian Pembersihan.

Sebelum memulai

  1. Login ke akun Google Cloud Anda. Jika Anda baru menggunakan Google Cloud, buat akun untuk mengevaluasi performa produk kami dalam skenario dunia nyata. Pelanggan baru juga mendapatkan kredit gratis senilai $300 untuk menjalankan, menguji, dan men-deploy workload.
  2. In the Google Cloud console, on the project selector page, select or create a Google Cloud project.

    Roles required to select or create a project

    • Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
    • Create a project: To create a project, you need the Project Creator role (roles/resourcemanager.projectCreator), which contains the resourcemanager.projects.create permission. Learn how to grant roles.

    Go to project selector

  3. Verify that billing is enabled for your Google Cloud project.

  4. In the Google Cloud console, on the project selector page, select or create a Google Cloud project.

    Roles required to select or create a project

    • Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
    • Create a project: To create a project, you need the Project Creator role (roles/resourcemanager.projectCreator), which contains the resourcemanager.projects.create permission. Learn how to grant roles.

    Go to project selector

  5. Verify that billing is enabled for your Google Cloud project.

  6. Untuk membuat database Firestore dalam mode Native, selesaikan langkah-langkah berikut:
    1. Di konsol Google Cloud , buka halaman Firestore create database.

      Buka Firestore buat database

    2. Dari layar Select a Cloud Firestore mode, klik Select Native Mode.
    3. Pilih lokasi untuk database Firestore Anda. Setelan lokasi ini adalah lokasi resource default Google Cloud untuk project Google Cloud Anda . Lokasi ini digunakan untuk Google Cloud layanan di Google Cloud project Anda yang memerlukan setelan lokasi, khususnya, bucket Cloud Storage default dan aplikasi Cloud Run.
    4. Klik Create database.
  7. Aktifkan Cloud Run Admin, Cloud Storage, Cloud Logging, dan Error Reporting API.

    Peran yang diperlukan untuk mengaktifkan API

    Untuk mengaktifkan API, Anda memerlukan peran IAM Service Usage Admin (roles/serviceusage.serviceUsageAdmin), yang berisi izin serviceusage.services.enable. Pelajari cara memberikan peran.

    Aktifkan API

  8. Clone repositori contoh dan buka aplikasi contoh di Cloud Shell:
    Buka Cloud Shell

    Cloud Shell menyediakan akses command line ke Google Cloud resource Anda langsung dari browser.

  9. Untuk mendownload kode contoh dan beralih ke direktori aplikasi, klik Lanjutkan.
  10. Di Cloud Shell, konfigurasi alat gcloud untuk menggunakan project Google Cloud baru Anda:

    # Configure gcloud for your project
    gcloud config set project PROJECT_ID

    Ganti PROJECT_ID dengan project ID Google Cloud yang Anda buat menggunakan konsol Google Cloud .

    Google Cloud CLI adalah cara utama Anda berinteraksi dengan resource Google Cloud dari command line. Dalam tutorial ini, Anda akan menggunakan alat gcloud untuk men-deploy dan memantau aplikasi.

Menjalankan aplikasi Anda

  1. Di Cloud Shell, instal dependensi aplikasi Anda menggunakan pip:

    pip3 install -r requirements.txt --user
    
  2. Jalankan server HTTP Gunicorn:
    ~/.local/bin/gunicorn -b :8080 main:app
    
  3. Di Cloud Shell, klik Pratinjau Web , lalu pilih Pratinjau di port 8080. Tindakan ini akan membuka jendela baru dengan aplikasi yang sedang berjalan.

Men-deploy aplikasi Anda ke Cloud Run

Google Cloud menawarkan beberapa opsi untuk menjalankan kode Anda. Untuk contoh ini, Anda menggunakan Cloud Run untuk men-deploy aplikasi yang skalabel ke Google Cloud. Cloud Run tidak mengharuskan Anda mengelola server dan otomatis melakukan penskalaan untuk mendukung lonjakan traffic.

  1. Gunakan Cloud Build untuk membangun container Docker dan memublikasikan ke Container Registry:
    gcloud builds submit --tag gcr.io/PROJECT_ID/bookshelf .

    Ganti PROJECT_ID dengan ID project yang Anda buat. Google Cloud

  2. Jalankan container dengan Cloud Run:
    gcloud run deploy bookshelf --image gcr.io/PROJECT_ID/bookshelf \
    --platform managed --region us-central1 --allow-unauthenticated

    Aplikasi Anda kini dapat dilihat di URL yang ditampilkan dalam output gcloud run:

    Service [bookshelf] revision [bookshelf-00001] has been deployed and is serving 100 percent of traffic. 
    Service URL: https://bookshelf-swsmmh5s5a-uc.a.run.app

  3. Salin URL ke browser web Anda untuk melihat aplikasi.

    Halaman beranda aplikasi Bookshelf

Untuk mengetahui informasi selengkapnya tentang cara men-deploy ke Cloud Run, lihat dokumentasi Cloud Run.

Mempertahankan data Anda dengan Firestore

Anda tidak dapat menyimpan informasi di instance Cloud Run, karena informasi tersebut akan hilang jika instance dimulai ulang, dan tidak ada saat instance baru dibuat. Sebagai gantinya, Anda menggunakan database yang dibaca dan ditulis oleh semua instance Anda.

Google Cloud menawarkan beberapa opsi untuk menyimpan data Anda. Dalam contoh ini, Anda menggunakan Firestore untuk menyimpan data setiap buku. Firestore adalah database dokumen NoSQL serverless yang terkelola sepenuhnya, yang memungkinkan Anda menyimpan dan membuat kueri data. Firestore melakukan penskalaan otomatis untuk memenuhi kebutuhan aplikasi Anda, dan melakukan penskalaan hingga nol saat Anda tidak menggunakannya. Tambahkan buku pertama Anda sekarang.

  1. Untuk membuat buku bagi aplikasi yang di-deploy, klik Tambahkan buku.

    Menambahkan buku ke aplikasi Bookshelf
  2. Di kolom Title, masukkan Moby Dick.
  3. Pada kolom Author, masukkan Herman Melville.
  4. Klik Simpan. Sekarang ada entri ke aplikasi Bookshelf Anda.

    Entri aplikasi Bookshelf Moby Dick
  5. Di konsol Google Cloud , untuk memuat ulang halaman Firestore, klik Muat ulang . Data akan muncul di Firestore. Aplikasi Bookshelf menyimpan setiap buku sebagai dokumen Firestore dengan ID unik, dan semua dokumen ini disimpan dalam koleksi Firestore. Untuk tujuan tutorial ini, koleksinya disebut buku. Contoh dokumen Firestore.

Firestore menyimpan buku menggunakan Library Klien Firestore. Berikut adalah contoh pengambilan dokumen Firestore:

from google.cloud import firestore
db = firestore.Client()
book_ref = db.collection(u'Book').document(book_id)
snapshot = book_ref.get()

Untuk mengetahui informasi selengkapnya tentang penggunaan Firestore, lihat artikel Menambahkan data ke Firestore.

Menyimpan upload file di Cloud Storage

Setelah menambahkan buku, saatnya menambahkan gambar sampul buku. Anda tidak dapat menyimpan file di instance Anda. Database bukan pilihan yang tepat untuk file gambar. Sebagai gantinya, Anda akan menggunakan Cloud Storage.

Cloud Storage adalah penyimpanan blob utama untuk Google Cloud. Anda dapat menggunakan Cloud Storage untuk menghosting aset aplikasi yang ingin Anda bagikan di seluruh Google Cloud. Untuk menggunakan Cloud Storage, Anda harus membuat bucket Cloud Storage, yaitu container dasar untuk menyimpan data Anda.

  1. Di konsol Google Cloud , buka halaman Browser Cloud Storage.

    Buka halaman Browser Cloud Storage

  2. Klik Create bucket.
  3. Di dialog Buat bucket, masukkan nama untuk bucket Anda dengan menambahkan ID project Google Cloud ke string _bucket sehingga nama bucket terlihat seperti YOUR_PROJECT_ID_bucket. Nama ini tunduk pada persyaratan nama bucket. Semua kolom lainnya dapat tetap menggunakan nilai defaultnya.
  4. Klik Create.
  5. Setelah bucket Anda dibuat, objek harus dibuat agar dapat diakses secara publik agar dapat dilihat oleh pengguna. Untuk membuat objek Anda dapat diakses secara publik, lihat Membuat Data Publik.
  6. Klik Edit buku, lalu pilih gambar untuk diupload sebagai sampul buku Anda. Misalnya, Anda dapat menggunakan gambar domain publik ini:
    Sampul buku Moby Dick
  7. Klik Simpan. Anda akan dialihkan ke halaman beranda, tempat terdapat entri ke aplikasi Bookshelf Anda.
    Entri aplikasi Bookshelf Moby Dick

Aplikasi rak buku mengirimkan file yang diupload ke Cloud Storage menggunakan Cloud Storage Client Library.

client = storage.Client()
bucket = client.bucket(bucketname)
blob = bucket.blob(filename)

blob.upload_from_string(
    file_stream,
    content_type=content_type)
# Ensure the file is publicly readable.
blob.make_public()

url = blob.public_url

Untuk mengetahui informasi selengkapnya tentang cara menggunakan Cloud Storage, lihat Pengantar Cloud Storage.

Memantau aplikasi Anda menggunakan Google Cloud Observability

Anda telah men-deploy aplikasi serta membuat dan mengubah buku. Untuk memantau peristiwa ini bagi pengguna Anda, gunakan Pengelolaan Performa Aplikasi.

Memantau log dengan Cloud Logging

  1. Di Google Cloud, buka Logs Explorer

    Buka Logs Explorer

    Anda dapat memantau aplikasi secara real time. Jika Anda mengalami masalah dengan aplikasi Anda, ini adalah salah satu tempat pertama yang harus dilihat.

    Stackdriver Log Viewer
  2. Di menu drop-down Resource, pilih Cloud Run Revision, bookshelf.

Pantau kesalahan menggunakan Pelaporan Kesalahan

  1. Di konsol Google Cloud , buka halaman Error Reporting.
    Buka halaman Error Reporting
    Error Reporting menyoroti error dan pengecualian dalam aplikasi Anda dan memungkinkan Anda menyiapkan pemberitahuan terkait error dan pengecualian tersebut.
  2. Di browser Anda, buka URL /errors di aplikasi Anda.
    YOUR_CLOUD_RUN_URL/errors

    Tindakan ini akan menghasilkan pengecualian pengujian baru dan mengirimkannya ke Google Cloud Observability.

  3. Di konsol Google Cloud , kembali ke halaman Error Reporting, dan setelah beberapa saat, error baru akan terlihat. Klik Muat Ulang Otomatis agar Anda tidak perlu memuat ulang halaman secara manual.

    Pesan error dari Error Reporting.

Pembersihan

Agar tidak perlu membayar biaya pada akun Google Cloud Anda untuk resource yang digunakan dalam tutorial ini, hapus project yang berisi resource tersebut, atau simpan project dan hapus setiap resource.

Menghapus project

  1. Di Konsol Google Cloud , buka halaman Manage resources.

    Buka Kelola resource

  2. Pada daftar project, pilih project yang ingin Anda hapus, lalu klik Delete.
  3. Pada dialog, ketik project ID, lalu klik Shut down untuk menghapus project.

Langkah berikutnya