Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.
Menyebarkan PHP aplikasi Cake ke Elastic Beanstalk
Kue PHP adalah open source, MVC kerangka kerja untukPHP. Tutorial ini memandu Anda melalui proses menghasilkan PHP proyek Cake, menerapkannya ke lingkungan Elastic Beanstalk, dan mengonfigurasinya untuk terhubung ke instance database Amazon. RDS
Bagian-bagian
Prasyarat
Tutorial ini mengasumsikan Anda memiliki pengetahuan tentang operasi Elastic Beanstalk dasar dan konsol Elastic Beanstalk. Jika belum, ikuti petunjuk di Memulai dengan Elastic Beanstalk untuk meluncurkan lingkungan Elastic Beanstalk pertama Anda.
Untuk mengikuti prosedur di panduan ini, Anda memerlukan terminal atau shell baris perintah untuk menjalankan perintah. Perintah ditampilkan dalam daftar yang diawali dengan simbol prompt ($) dan nama direktori saat ini, bila perlu.
~/eb-project$ this is a command
this is output
Di Linux dan macOS, Anda dapat menggunakan shell dan manajer paket pilihan Anda. Pada Windows Anda dapat menginstal Windows Subsystem untuk Linux untuk
Kue PHP 4 membutuhkan PHP 7.2 atau lebih baru. Ini juga memerlukan PHP ekstensi yang tercantum dalam dokumentasi PHPinstalasi Kue
Meluncurkan lingkungan Elastic Beanstalk
Gunakan konsol Elastic Beanstalk untuk membuat lingkungan Elastic Beanstalk. Pilih PHPplatform dan terima pengaturan default dan kode sampel.
Untuk meluncurkan lingkungan (konsol)
-
Untuk Platform, pilih platform dan cabang platform yang sesuai dengan bahasa yang digunakan oleh aplikasi Anda.
-
Untuk Kode aplikasi, pilih Aplikasi sampel.
-
Pilih Tinjau dan Luncurkan.
-
Tinjau opsi yang tersedia. Pilih opsi tersedia yang ingin Anda gunakan, dan saat Anda siap, pilih Buat aplikasi.
Pembuatan lingkungan membutuhkan waktu sekitar 5 menit dan membuat sumber daya berikut:
-
EC2instance — Mesin virtual Amazon Elastic Compute Cloud (AmazonEC2) yang dikonfigurasi untuk menjalankan aplikasi web pada platform yang Anda pilih.
Setiap platform menjalankan satu set perangkat lunak, file konfigurasi dan penulisan tertentu untuk mendukung versi bahasa, kerangka kerja, kontainer web tertentu, atau kombinasi dari semua ini. Sebagian besar platform menggunakan Apache atau NGINX sebagai proxy terbalik yang berada di depan aplikasi web Anda, meneruskan permintaan ke sana, menyajikan aset statis, dan menghasilkan akses dan log kesalahan.
-
Grup keamanan instans — Grup EC2 keamanan Amazon yang dikonfigurasi untuk memungkinkan lalu lintas masuk pada port 80. Sumber daya ini memungkinkan HTTP lalu lintas dari penyeimbang beban mencapai EC2 instance yang menjalankan aplikasi web Anda. Secara default, lalu lintas tidak diizinkan di port lain.
-
Penyeimbang beban – Penyeimbang beban Elastic Load Balancing yang dikonfigurasi untuk mendistribusikan permintaan ke instans yang menjalankan aplikasi Anda. Penyeimbang beban juga menghilangkan kebutuhan untuk mengekspos instans Anda langsung ke internet.
-
Grup keamanan penyeimbang beban - Grup EC2 keamanan Amazon yang dikonfigurasi untuk memungkinkan lalu lintas masuk di port 80. Sumber daya ini memungkinkan HTTP lalu lintas dari internet mencapai penyeimbang beban. Secara default, lalu lintas tidak diizinkan di port lain.
-
Grup Auto Scaling – Grup Auto Scaling yang dikonfigurasi untuk menggantikan instans jika diakhiri atau menjadi tidak tersedia.
-
Bucket Amazon S3 – Lokasi penyimpanan untuk kode sumber, log, dan artifact lainnya yang dibuat saat Anda menggunakan Elastic Beanstalk.
-
CloudWatch Alarm Amazon — Dua CloudWatch alarm yang memantau beban pada instans di lingkungan Anda dan yang dipicu jika beban terlalu tinggi atau terlalu rendah. Saat alarm terpicu, grup Auto Scaling Anda akan menaikkan atau menurunkan skala sebagai respons.
-
AWS CloudFormation stack - Elastic AWS CloudFormation Beanstalk digunakan untuk meluncurkan sumber daya di lingkungan Anda dan menyebarkan perubahan konfigurasi. Sumber daya ditentukan di sebuah templat yang dapat Anda lihat di Konsol AWS CloudFormation
. -
Nama domain — Nama domain yang merutekan ke aplikasi web Anda dalam formulir
subdomain
.region
.elasticbeanstalk.com.Keamanan domain
Jika Anda perlu mengatur cookie sensitif di nama domain default untuk aplikasi Elastic Beanstalk Anda, kami sarankan Anda menggunakan cookie
__Host-
dengan awalan untuk meningkatkan keamanan. Praktik ini melindungi domain Anda dari upaya pemalsuan permintaan lintas situs (). CSRF Untuk informasi selengkapnya, lihat halaman Set-Cookiedi Jaringan Pengembang Mozilla.
Semua sumber daya ini dikelola oleh Elastic Beanstalk. Ketika Anda mengakhiri lingkungan, Elastic Beanstalk mengakhiri semua sumber daya yang dimuatnya.
catatan
Bucket Amazon S3 yang dibuat Elastic Beanstalk dibagi antar lingkungan dan tidak dihapus selama pengakhiran lingkungan. Untuk informasi selengkapnya, lihat Menggunakan Elastic Beanstalk dengan Amazon S3.
Instal Cake PHP dan buat situs web
Komposer dapat menginstal Cake PHP dan membuat proyek kerja dengan satu perintah:
~$ composer create-project --prefer-dist cakephp/app eb-cake
Composer menginstal Cake PHP dan sekitar 20 dependensi, dan menghasilkan proyek default.
Jika Anda mengalami masalah saat menginstal CakePHP, kunjungi topik instalasi di dokumentasi resmi: http://book.cakephp.org/4.0/en/installation.html
Men-deploy aplikasi Anda
Buat paket sumber berisi file yang dibuat oleh Composer. Perintah berikut membuat paket sumber yang bernama cake-default.zip
. Paket sumber tidak termasuk file dalam folder vendor
, yang memerlukan banyak ruang dan tidak perlu men-deploy aplikasi Anda ke Elastic Beanstalk.
eb-cake zip ../cake-default.zip -r * .[^.]* -x "vendor/*"
Unggah bundel sumber ke Elastic Beanstalk untuk menyebarkan Cake ke lingkungan AndaPHP.
Untuk men-deploy paket sumber
Buka konsol Elastic Beanstalk, dan di daftar Wilayah, pilih konsol Elastic
Beanstalk. Wilayah AWS -
Di panel navigasi, pilih Lingkungan, dan kemudian pilih nama lingkungan Anda dari daftar.
catatan
Jika Anda memiliki banyak lingkungan, gunakan bilah pencarian untuk memfilter daftar lingkungan.
-
Di halaman gambaran umum lingkungan, pilih Unggah dan deploy.
-
Gunakan kotak dialog di layar untuk mengunggah paket sumber.
-
Pilih Deploy.
-
Ketika penyebaran selesai, Anda dapat memilih situs URL untuk membuka situs web Anda di tab baru.
catatan
Untuk mengoptimalkan paket sumber selanjutnya, inisialisasi repositori Git dan gunakan perintah git
archive untuk membuat paket sumber. Proyek Symfony default berisi file .gitignore
yang meminta Git untuk mengecualikan folder vendor
dan file lain yang tidak diperlukan untuk deployment.
Ketika proses selesai, klik tombol URL untuk membuka PHP aplikasi Cake Anda di browser.
Sejauh ini, baik-baik saja. Selanjutnya Anda akan menambahkan database ke lingkungan Anda dan mengkonfigurasi Cake PHP untuk terhubung ke sana.
Menambahkan basis data ke lingkungan Anda
Luncurkan instans RDS database Amazon di lingkungan Elastic Beanstalk Anda. Anda dapat menggunakan SQL database MySQL,SQLServer, atau Postgre dengan Cake on Elastic PHP Beanstalk. Untuk contoh ini, kita akan menggunakan PostgreSQL.
Untuk menambahkan instans Amazon RDS DB ke lingkungan Elastic Beanstalk Anda
Buka konsol Elastic Beanstalk, dan di daftar Wilayah, pilih konsol Elastic
Beanstalk. Wilayah AWS -
Di panel navigasi, pilih Lingkungan, dan kemudian pilih nama lingkungan Anda dari daftar.
catatan
Jika Anda memiliki banyak lingkungan, gunakan bilah pencarian untuk memfilter daftar lingkungan.
Pada panel navigasi, pilih Konfigurasi.
-
Dalam Basis Data, Pilih Edit.
-
Untuk Mesin DB, pilih postgres.
-
Ketik nama pengguna utama dan kata sandi. Elastic Beanstalk akan memberikan nilai-nilai ini ke aplikasi Anda menggunakan properti lingkungan.
-
Untuk menyimpan perubahan pilih Terapkan di bagian bawah halaman.
Membuat instans basis data membutuhkan waktu sekitar 10 menit. Sementara itu, Anda dapat memperbarui kode sumber untuk membaca informasi koneksi dari lingkungan. Elastic Beanstalk menyediakan detail koneksi menggunakan variabel lingkungan seperti RDS_HOSTNAME
yang dapat Anda akses dari aplikasi Anda.
Konfigurasi database Cake PHP adalah dalam file bernama app.php
dalam config
folder dalam kode proyek Anda. Buka file ini dan tambahkan beberapa kode yang membaca variabel lingkungan dari $_SERVER
dan menetapkannya ke variabel lokal. Masukkan baris yang disorot dalam contoh di bawah ini setelah baris pertama (<?php
):
contoh ~/Eb- .php cake/config/app
<?php
if (!defined('RDS_HOSTNAME')) {
define('RDS_HOSTNAME', $_SERVER['RDS_HOSTNAME']);
define('RDS_USERNAME', $_SERVER['RDS_USERNAME']);
define('RDS_PASSWORD', $_SERVER['RDS_PASSWORD']);
define('RDS_DB_NAME', $_SERVER['RDS_DB_NAME']);
}
return [
...
Koneksi basis data dikonfigurasi lebih lanjut di app.php
. Temukan bagian berikut ini dan ubah konfigurasi sumber data default dengan nama driver yang cocok dengan mesin basis data Anda (Mysql
, Sqlserver
, atau Postgres
), dan atur variabel host
, username
, password
dan database
untuk membaca nilai-nilai yang sesuai dari Elastic Beanstalk:
contoh ~/Eb- .php cake/config/app
...
/**
* Connection information used by the ORM to connect
* to your application's datastores.
* Drivers include Mysql Postgres Sqlite Sqlserver
* See vendor\cakephp\cakephp\src\Database\Driver for complete list
*/
'Datasources' => [
'default' => [
'className' => 'Cake\Database\Connection',
'driver' => 'Cake\Database\Driver\Postgres
',
'persistent' => false,
'host' => RDS_HOSTNAME
,
/*
* CakePHP will use the default DB port based on the driver selected
* MySQL on MAMP uses port 8889, MAMP users will want to uncomment
* the following line and set the port accordingly
*/
//'port' => 'non_standard_port_number',
'username' => RDS_USERNAME
,
'password' => RDS_PASSWORD
,
'database' => RDS_DB_NAME
,
/*
* You do not need to set this flag to use full utf-8 encoding (internal default since CakePHP 3.6).
*/
//'encoding' => 'utf8mb4',
'timezone' => 'UTC',
'flags' => [],
'cacheMetadata' => true,
'log' => false,
...
Ketika instans DB telah menyelesaikan peluncuran, paketkan dan deploy aplikasi yang telah diperbarui ke lingkungan Anda:
Untuk memperbarui lingkungan Elastic Beanstalk
-
Buat paket sumber baru:
~/eb-cake$
zip ../cake-v2-rds.zip -r * .[^.]* -x "vendor/*"
Buka konsol Elastic Beanstalk, dan di daftar Wilayah, pilih konsol Elastic
Beanstalk. Wilayah AWS -
Di panel navigasi, pilih Lingkungan, dan kemudian pilih nama lingkungan Anda dari daftar.
catatan
Jika Anda memiliki banyak lingkungan, gunakan bilah pencarian untuk memfilter pada daftar lingkungan.
-
Pilih Unggah dan Deploy.
-
Pilih Jelajahi dan unggah
cake-v2-rds.zip
. -
Pilih Deploy.
Men-deploy versi baru dari aplikasi Anda membutuhkan waktu kurang dari satu menit. Ketika deployment selesai, refresh halaman web lagi untuk memverifikasi bahwa koneksi basis data berhasil:
Pembersihan
Jika Anda sudah selesai bekerja dengan Elastic Beanstalk, Anda dapat mengakhiri lingkungan Anda. Elastic Beanstalk AWS menghentikan semua sumber daya yang terkait dengan lingkungan Anda, seperti instans EC2 Amazon, instans database, penyeimbang beban, grup keamanan,dan alarm.
Untuk mengakhiri lingkungan Elastic Beanstalk Anda dari konsol
Buka konsol Elastic Beanstalk, dan di daftar Wilayah, pilih konsol Elastic
Beanstalk. Wilayah AWS -
Di panel navigasi, pilih Lingkungan, dan kemudian pilih nama lingkungan Anda dari daftar.
catatan
Jika Anda memiliki banyak lingkungan, gunakan bar pencarian untuk memfilter daftar lingkungan.
-
Pilih Tindakan, lalu pilih Terminate environment.
-
Gunakan kotak dialog di layar untuk mengonfirmasi pengakhiran lingkungan.
Dengan Elastic Beanstalk, Anda dengan mudah dapat membuat lingkungan baru untuk aplikasi Anda kapan saja.
Selain itu, Anda dapat mengakhiri sumber daya basis data yang Anda buat di luar lingkungan Elastic Beanstalk Anda. Saat menghentikan instans Amazon RDS DB, Anda dapat mengambil snapshot dan mengembalikan data ke instance lain nanti.
Untuk mengakhiri instans RDS DB Anda
-
Buka RDSkonsol Amazon
. -
Pilih Basis data.
-
Pilih instans DB Anda.
-
Pilih Tindakan, dan lalu pilih Hapus.
-
Pilih apakah akan membuat snapshot, dan kemudian memilih Hapus.
Langkah selanjutnya
Untuk informasi lebih lanjut tentang CakePHP, baca buku di book.cakephp.org
Ketika aplikasi terus dikembangkan, Anda mungkin akan menginginkan sebuah cara untuk mengelola lingkungan dan men-deploy aplikasi Anda tanpa membuat file .zip secara manual dan mengunggahnya ke konsol Elastic Beanstalk. Elastic Beanstalk Command Line Interface CLI (EB easy-to-use) menyediakan perintah untuk membuat, mengkonfigurasi, dan menyebarkan aplikasi ke lingkungan Elastic Beanstalk dari baris perintah.
Menjalankan instans Amazon RDS DB di lingkungan Elastic Beanstalk Anda sangat bagus untuk pengembangan dan pengujian, tetapi ini mengikat siklus hidup database Anda dengan lingkungan Anda. Lihat Menambahkan instans Amazon RDS DB ke lingkungan PHP Elastic Beanstalk Anda untuk petunjuk dalam menghubungkan ke basis data yang berjalan di luar lingkungan Anda.
Terakhir, jika Anda berencana menggunakan aplikasi Anda di lingkungan produksi, Anda akan ingin mengonfigurasi nama domain khusus untuk lingkungan Anda dan mengaktifkan HTTPS koneksi yang aman.