Men-deploy aplikasi Symfony ke Elastic Beanstalk - AWS Elastic Beanstalk

Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.

Men-deploy aplikasi Symfony ke Elastic Beanstalk

Symfony adalah kerangka kerja sumber terbuka untuk mengembangkan aplikasi web dinamisPHP. Tutorial ini memandu Anda melalui proses menghasilkan aplikasi Symfony dan menyebarkannya ke lingkungan. AWS Elastic Beanstalk

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 mendapatkan versi Windows terintegrasi dari Ubuntu dan Bash.

Symfony 4.4.9 membutuhkan PHP 7.1.3 atau yang lebih baru. Ini juga memerlukan PHP ekstensi yang tercantum dalam topik persyaratan teknis dalam dokumentasi instalasi Symfony resmi. Dalam tutorial ini, kami menggunakan PHP 7.2 dan versi platform Elastic Beanstalk yang sesuai. Ikuti petunjuk dalam Menyiapkan lingkungan PHP pengembangan Anda untuk Elastic Beanstalk topik untuk menginstal PHP dan Komposer.

Untuk informasi dukungan dan pemeliharaan Symfony, lihat topik rilis symfony dalam situs web Symfony. Untuk informasi lebih lanjut tentang pembaruan yang terkait dengan dukungan PHP versi untuk Symfony 4.4.9, lihat topik catatan rilis Symfony 4.4.9 di situs web Symfony.

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)
  1. Buka konsol Elastic Beanstalk menggunakan tautan yang telah dikonfigurasi sebelumnya: console.aws.amazon. com/elasticbeanstalk/home#/newApplication? applicationName=tutorial& = environmentType LoadBalanced

  2. Untuk Platform, pilih platform dan cabang platform yang sesuai dengan bahasa yang digunakan oleh aplikasi Anda.

  3. Untuk Kode aplikasi, pilih Aplikasi sampel.

  4. Pilih Tinjau dan Luncurkan.

  5. 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

    Untuk meningkatkan keamanan aplikasi Elastic Beanstalk Anda, domain elasticbeanstalk.com terdaftar di Daftar Akhiran Publik (). PSL

    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-Cookie di 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.

Menginstal Symfony dan menghasilkan sebuah situs web

Composer dapat menginstal Symfony dan membuat proyek kerja dengan satu perintah:

~$ composer create-project symfony/website-skeleton eb-symfony

Composer menginstal Symfony dan dependensinya, dan menghasilkan proyek default.

Jika Anda mengalami masalah saat menginstal Symfony, buka topik instalasi dalam dokumentasi Symfony resmi.

Deploy aplikasi Anda

Pergi ke direktori proyek.

~$ cd eb-symfony

Buat paket sumber berisi file yang dibuat oleh Composer. Perintah berikut membuat paket sumber yang bernama symfony-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-symfony$ zip ../symfony-default.zip -r * .[^.]* -x "vendor/*"

Unggah paket sumber ke Elastic Beanstalk untuk men-deploy Symfony ke lingkungan Anda.

Untuk men-deploy paket sumber
  1. Buka konsol Elastic Beanstalk, dan di daftar Wilayah, pilih konsol Elastic Beanstalk. Wilayah AWS

  2. 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.

  3. Di halaman gambaran umum lingkungan, pilih Unggah dan deploy.

  4. Gunakan kotak dialog di layar untuk mengunggah paket sumber.

  5. Pilih Deploy.

  6. 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.

Mengonfigurasi pengaturan Composer

Saat penerapan selesai, klik tombol URL untuk membuka aplikasi Symfony Anda di browser.

Apa ini? Secara default, Elastic Beanstalk menyajikan akar proyek Anda di jalur akar situs web. Dalam hal ini, meskipun, halaman default (app.php) tersebut berada di satu tingkat di bawah dalam folder web. Anda dapat memverifikasi ini dengan menambahkan /public keURL. Misalnya, http://symfony.us-east-2.elasticbeanstalk.com/public.

Untuk menyajikan aplikasi Symfony di jalur akar, gunakan konsol Elastic Beanstalk untuk mengonfigurasikan akar dokumen bagi situs web.

Untuk mengonfigurasi akar dokumen situs web Anda
  1. Buka konsol Elastic Beanstalk, dan di daftar Wilayah, pilih konsol Elastic Beanstalk. Wilayah AWS

  2. 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.

  3. Di panel navigasi, pilih Konfigurasi.

  4. Dalam kategori konfigurasi Pembaruan, pemantauan, dan pencatatan, pilih Edit.

  5. Untuk Akar dokumen, masukkan /public.

  6. Untuk menyimpan perubahan pilih Terapkan di bagian bawah halaman.

  7. Setelah pembaruan selesai, klik tombol URL untuk membuka kembali situs Anda di browser.

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
  1. Buka konsol Elastic Beanstalk, dan di daftar Wilayah, pilih konsol Elastic Beanstalk. Wilayah AWS

  2. 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.

  3. Pilih Tindakan, lalu pilih Terminate environment.

  4. Gunakan kotak dialog di layar untuk mengonfirmasi pengakhiran lingkungan.

Dengan Elastic Beanstalk, Anda dengan mudah dapat membuat lingkungan baru untuk aplikasi Anda kapan saja.

Langkah selanjutnya

Untuk informasi lebih lanjut tentang Symfony, lihat Apa itu Symfony? di symfony.com.

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.

Dalam tutorial ini, Anda menggunakan konsol Elastic Beanstalk untuk mengonfigurasi opsi komposer. Untuk membuat bagian konfigurasi ini dari sumber aplikasi Anda, Anda dapat menggunakan file konfigurasi seperti berikut.

contoh .ebextensions/composer.config
option_settings: aws:elasticbeanstalk:container:php:phpini: document_root: /public

Untuk informasi selengkapnya, lihat Penyesuaian lingkungan lanjutan dengan file konfigurasi (.ebextensions).

Symfony menggunakan file konfigurasinya sendiri dalam mengonfigurasi koneksi basis data. Untuk petunjuk tentang melakukan koneksi ke basis data dengan Symfony, lihat Menghubungkan ke basis data dengan Symfony.

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.