Tutorial ini menunjukkan cara menangani sesi di App Engine.
Banyak aplikasi memerlukan penanganan sesi untuk autentikasi dan preferensi pengguna. PHP hadir dengan implementasi berbasis memori untuk menjalankan fungsi ini. Namun, implementasi ini tidak cocok untuk aplikasi yang dapat disalurkan dari beberapa instance, karena sesi yang direkam dalam satu instance mungkin berbeda dari instance lainnya.
Tujuan
- Tulis aplikasi.
- Jalankan aplikasi secara lokal.
- Deploy aplikasi di App Engine.
Biaya
Dalam dokumen ini, Anda menggunakan komponen Google Cloud yang dapat ditagih berikut:
Untuk membuat perkiraan biaya berdasarkan proyeksi penggunaan Anda,
gunakan kalkulator harga.
Setelah menyelesaikan tugas yang dijelaskan dalam dokumen ini, Anda dapat menghindari penagihan berkelanjutan dengan menghapus resource yang Anda buat. Untuk mengetahui informasi selengkapnya, lihat Pembersihan.
Sebelum memulai
- Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
-
Di konsol Google Cloud, pada halaman pemilih project, pilih atau buat project Google Cloud.
-
Make sure that billing is enabled for your Google Cloud project.
-
Aktifkan API Firestore.
- Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
-
Di konsol Google Cloud, pada halaman pemilih project, pilih atau buat project Google Cloud.
-
Make sure that billing is enabled for your Google Cloud project.
-
Aktifkan API Firestore.
- Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
- Konfigurasikan gcloud CLI untuk menggunakan project Google Cloud baru Anda:
# Configure gcloud for your project gcloud config set project PROJECT_ID
GantiPROJECT_ID
dengan project ID Google Cloud yang Anda buat atau pilih sebelumnya.
Menyiapkan project
Di jendela terminal, mulai dari direktori pilihan Anda dan buat direktori baru bernama
sessions
. Semua kode untuk tutorial ini ada dalam direktorisessions
.Ubah ke direktori
sessions
:cd sessions
Instal dependensinya:
composer require google/cloud-firestore
Di akhir tutorial ini, struktur file akhir mirip dengan berikut ini:
sessions
├── app.yaml
└── composer.json
├── index.php
Menulis aplikasi
Di jendela terminal, buat file bernama
index.php
dengan konten berikut:
Aplikasi ini menampilkan salam dalam berbagai bahasa untuk setiap pengguna. Pengguna yang kembali akan selalu disambut dalam bahasa yang sama.
Sebelum aplikasi Anda dapat menyimpan preferensi bagi pengguna, Anda memerlukan cara untuk menyimpan informasi tentang pengguna saat ini dalam sebuah sesi. Aplikasi contoh ini menggunakan Firestore untuk menyimpan data sesi.
Anda dapat menggunakan Firestore session handler
untuk menggunakan Firestore untuk sesi PHP.
Diagram berikut mengilustrasikan cara Firestore menangani sesi untuk aplikasi App Engine.
Setelah menetapkan session_set_save_handler
, setiap permintaan memiliki variabel global $_SESSION
yang dapat Anda gunakan untuk mengakses sesi. Data sesi disimpan di Firestore.
Menjalankan proses secara lokal
Mulai server web PHP bawaan:
php -S localhost:8080
Lihat aplikasi di browser web:
Cloud Shell
Di toolbar Cloud Shell, klik Web preview lalu pilih Preview on port 8080.
Komputer lokal
Di browser Anda, buka
http://localhost:8080
Anda akan melihat salah satu dari lima salam: “Hello World”, “Hallo Welt”, “Hola mundo”, “Salut le Monde”, atau “Ciao Mondo”. Bahasa akan berubah jika Anda membuka halaman di browser lain atau dalam mode samaran. Anda dapat melihat dan mengedit data sesi di Konsol Google Cloud.
Untuk menghentikan server HTTP, di jendela terminal, tekan
Control+C
.
Men-deploy dan menjalankan aplikasi di App Engine
Anda dapat menggunakan lingkungan standar App Engine untuk membangun dan men-deploy aplikasi yang berjalan dengan andal dalam beban berat dan dengan data dalam jumlah besar.
Tutorial ini menggunakan lingkungan standar App Engine untuk men-deploy server.
Di jendela terminal, buat file
app.yaml
dan salin perintah berikut:Deploy aplikasi di App Engine:
gcloud app deploy
Untuk melihat aplikasi live, masukkan URL berikut:
https://PROJECT_ID.REGION_ID.r.appspot.com
Ganti kode berikut:
PROJECT_ID
: ID Project Google Cloud AndaREGION_ID
: Kode yang ditetapkan App Engine untuk aplikasi Anda
Salam sekarang dikirimkan oleh server web yang berjalan pada instance App Engine.
Menghapus sesi
PHP menjalankan pembersihan sampah memori (GC) sesi,
yang menghapus sesi lama dan yang telah berakhir
sesuai dengan konfigurasi php.ini
Anda. Pengendali sesi Firestore tidak membersihkan sesi secara default, tetapi Anda dapat mengonfigurasinya untuk melakukannya dengan meneruskan opsi gcLimit
saat membuat pengendali sesi:
Sesi dihapus menggunakan GC sesi berbasis probabilitas, atau saat Anda memanggil
fungsi session_gc
secara eksplisit.
Men-debug aplikasi
Jika Anda tidak dapat terhubung ke aplikasi App Engine, periksa hal-hal berikut:
- Pastikan perintah deployment
gcloud
berhasil diselesaikan dan tidak menghasilkan error apa pun. Jika ada error (misalnya,message=Build failed
), perbaiki, lalu coba deploy aplikasi App Engine lagi. Di Konsol Google Cloud, buka halaman Logs Explorer.
Di menu drop-down Last selected resources, klik App Engine Application, lalu klik All module_id. Anda akan melihat daftar permintaan saat mengunjungi aplikasi. Jika Anda tidak melihat daftar permintaan, konfirmasi bahwa Anda telah memilih All module_id dari menu drop-down. Jika Anda melihat pesan error yang dicetak ke Google Cloud Console, pastikan kode aplikasi Anda cocok dengan kode di bagian tentang penulisan aplikasi web.
Pastikan Firestore API diaktifkan.
Pembersihan
Menghapus project
- Di konsol Google Cloud, buka halaman Manage resource.
- Pada daftar project, pilih project yang ingin Anda hapus, lalu klik Delete.
- Pada dialog, ketik project ID, lalu klik Shut down untuk menghapus project.
Menghapus instance App Engine
- Di konsol Google Cloud, buka halaman Versi untuk App Engine.
- Pilih kotak centang untuk versi aplikasi non-default yang ingin Anda hapus.
- Untuk menghapus versi aplikasi, klik Hapus.