ก่อนอื่นก่อนใด ก่อนที่จะ Deploy Symfony สิ่งที่เราจำเป็นต้องมีเลยคือ Composer
Install Composer
สำหรับการติดตั้ง composer สามาดูได้จากบทความที่ผมเคยเขียนไปครั้งก่อนได้เลย การติดตั้ง Composer ใน Linux โดยเราจำเป็นต้องใช้ composer ในการติดตั้ง dependencies ต่างๆ ใน project ของเรา
Example Project
ผมมี Symfony Project เปล่าๆ ที่จะเอามาลอง Deploy https://github.com/bdsach/hello-symfony ให้เรา Clone repo นี้ไปไว้ใน directory html
Clone
ให้ทำการ Clone โดยใช้คําสั่ง git clone
git clone https://github.com/bdsach/hello-symfony.git html
data:image/s3,"s3://crabby-images/38b47/38b47ae37b7970a2257cbc12e6be5a196eaa3410" alt="Clone Project"
หากใครติดปัญหาเรื่อง permission แบบนี้ ให้เปลี่ยน owner ก่อน ด้วยคำสั่ง
chown
data:image/s3,"s3://crabby-images/4ecfe/4ecfe9ddb68affa68d48219d01dcb2f784b42981" alt="Clone Project With Permission Denied"
sudo chown -R bandit:bandit /var/www
ถ้าขึ้นแบบนี้ ก็ถือ เป็นการ Clone สําเร็จ
data:image/s3,"s3://crabby-images/d419d/d419d48a121573c1773d9cc0cac67f72023ad59f" alt="Clone Project"
Install Dependencies
เมื่อ Clone project สำเร็จ ก็มาถึงการติดตั้ง dependencies โดยใช้คําสั่ง composer install
data:image/s3,"s3://crabby-images/9c45f/9c45f72ee2159b57438fbfa292fe5a04c4e0fe0c" alt="Composer Install"
แล้วก็รอ
data:image/s3,"s3://crabby-images/da87e/da87e10ba1f9570d901dce308837f600760a69df" alt="Composer Install"
Sites config
หลังจากที่ติดตั้ง dependencies เสร็จแล้ว ก็ก็จะมาแก้ไฟล์ sites-available
ของเราเล็กน้อย
data:image/s3,"s3://crabby-images/a3108/a31080952694ad08919394b70f6661f2c175a27e" alt="Edit Sites Available"
สาเหตุที่เราจะต้องแก้ เพราะว่า symfony จะต้องชี้ไปที่ directory public เราก็แค่เติม public
ไว้ด้านหลัง ตรงบรรทัด root เสร็จแล้วก็กดบันทึก
data:image/s3,"s3://crabby-images/89096/89096ef723d284bef39053576416fc2406c72adc" alt="Edit Sites Available"
จากนั้นทำการ reload nginx ด้วยคำสั่ง
sudo systemctl reload nginx
data:image/s3,"s3://crabby-images/4fd07/4fd07907ff77da3e62120787ebfdc142ced7a1b4" alt="systemctl reload nginx"
Setup Database
สำหรับ Database ผมจะใช้ MariaDB
Install MariaDB
มาเริ่มด้วยการติดตั้ง MariaDB ก่อนเลย ตามคำสั่งด้านล่างนี้ได้เลย
ว่าแล้วก็ update apt สักรอบ
sudo apt update
data:image/s3,"s3://crabby-images/5ff77/5ff777cf35f2cd9057b14213bb3243e14aff4d11" alt="update apt"
จากนั้นก็ได้เวลาทำการติดตั้ง MariaDB
sudo apt install mariadb-server
data:image/s3,"s3://crabby-images/7a231/7a2314c6a3c084642bf6c35ea7821adaf6ab6cdf" alt="Install MariaDB"
จากนั้นก็ start service MariaDB
sudo systemctl start mariadb.service
Config MariaDB
ทีนี้ก็ได้เวลาตั้งค่า MariaDB โดยผมจะตั้งค่าแบบง่ายๆ เลย คือ set password ให้ root แล้วใช้ root ในการ connect (ไม่ใช่วิธีที่ดี จริงๆ ควรจะสร้าง user ขึ้นมาใหม่ เพราะฉะนั้น ถ้าใช้งานจริง อย่าทำตาม 🤪)
sudo mysql_secure_installation
เมื่อพิมพ์คำสั่งเสร็จ ก็จะแสดงผลดังนี้ โดยผมจะ enter ไปเลย
data:image/s3,"s3://crabby-images/5c9a1/5c9a14fdb61008909ccdafe9b398d26e8978654c" alt="mysql_secure_installation - enter current root password"
เพราะเริ่มต้น root จะยังไม่มี password
ตอบ n
data:image/s3,"s3://crabby-images/aa13b/aa13b6a228ffbc55c0a0346ec5b114e48a7d0067" alt="mysql_secure_installation - unix socket authentication"
ตรงนี้ตอบ n
data:image/s3,"s3://crabby-images/0296a/0296aec0fe977e9072ddaf028328d2a86b739c02" alt="mysql_secure_installation - change root password?"
ตรงนี้ตอบ Y จากนั้นกรอก password สำหรับ root
ในตัวอย่างนี้ผมจะตั้ง password คือ example ให้จำ password ไว้ด้วย เพราะเราต้องใช้ user และ password ในการกำหนดใน .env.local
เพื่อเชื่อมต่อกับ Database
data:image/s3,"s3://crabby-images/80ccd/80ccd2ae54d241e5f9db9f455fb22ec775f24db2" alt="mysql_secure_installation - new password"
กรอก password อีกครั้งเพื่อยืนยัน
data:image/s3,"s3://crabby-images/0a4a0/0a4a058e3fd8b1ed7d934bc0fdedbe00d9755ab3" alt="mysql_secure_installation - re-type new password"
ตอบ y เพื่อลบการใช้งาน anonymous users
data:image/s3,"s3://crabby-images/e1a9c/e1a9c20bde49100c32b06e9fc9dadcc6d201428d" alt="mysql_secure_installation - remove anonymous users?"
ตอบ y เพื่อ disallow root login remotely
data:image/s3,"s3://crabby-images/33231/33231a6cfcc4cbc5d9c72a70f8aec53b6678bde1" alt="mysql_secure_installation - disallow root login remotely?"
ตอบ y เพื่อลบ database test
data:image/s3,"s3://crabby-images/41b91/41b91e05b17e7e4eb5550547789041c8f5c72fca" alt="mysql_secure_installation - remove test database and access to it?"
ตอบ y เพื่อ reload สิทธ์การใช้งาน
data:image/s3,"s3://crabby-images/f02e1/f02e16889b9850752ba2c6c3bd0b4f5e023d0b9d" alt="mysql_secure_installation - reload privilege tables now?"
เสร็จแล้วลองเช็ค status ดูหน่อยเพื่อความชัวร์ ด้วยคำสั่ง
sudo systemctl status mariadb.service
data:image/s3,"s3://crabby-images/335d1/335d1a091246b2a0648194a356ed2b8c3a5458f0" alt="mariadb service status"
ถ้าขึ้นหน้าจอแบบนี้ก็เป็นอันใช้ได้
data:image/s3,"s3://crabby-images/a36fc/a36fc09f7f31e071b8d3cf6681c71f35c12444c4" alt="mariadb service status"
Set .env
ทำการสร้างไฟล์ .env.local
แล้วเพิ่ม DATABASE_URL
ในไฟล์ .env.local
โดย user จะเป็น root และ password จะเป็น example
ตามที่เรากำหนดไว้ตอนที่เราติดตั้ง MariaDB (สำหรับใครตั้ง password เป็นอะไรก็ใส่ให้ถูก)
DATABASE_URL="mysql://root:[email protected]/hello-symfony-db?serverVersion=10.5.19-MariaDB&charset=utf8mb4"
data:image/s3,"s3://crabby-images/a9baf/a9baf314d677c186e75164b84f0be522c1b77515" alt="create .env.local file and add DATABASE_URL"
สร้าง Database ด้วยคําสั่ง
php bin/console doctrine:database:create
data:image/s3,"s3://crabby-images/70476/7047699015534d326bb6ed500a787d418094144b" alt="Create Database"
Migrate Database ด้วยคําสั่ง
php bin/console doctrine:migrations:migrate
data:image/s3,"s3://crabby-images/42419/424195e136f184fc11880325eb2f60c8b03683d8" alt="Migrate Database"
เสร็จไปเรียบร้อยสำหรับ Database
Try CRUD
เราลองมาเปิดดูที่หน้าเว็บสักหน่อย ว่าหน้าตาจะเป็นยังไง สำหรับ Project ก็จะเป็น CRUD ง่ายๆ
คือเป็นเว็บสำหรับบันทึกข้อมูลพนักงานแบบง่ายๆ ส่วนทำอะไรได้บ้างนั้น ก็สามารถ แสดง เพิ่ม แก้ไข ลบ พนักงานได้
data:image/s3,"s3://crabby-images/67ae1/67ae161b78ed5942e55f45824c72457e0b268b1f" alt="Homepage of Project"
สามารถกดปุ่ม Create new เพื่อเพิ่มข้อมูลพนักงานได้
data:image/s3,"s3://crabby-images/a5aa1/a5aa137d39ed80813d20ff96acab8a061abcea95" alt="Create new employee"
หลังจากบันทึก มีข้อมูลขึ้นมา ก็เป็นอันใช้ได้
data:image/s3,"s3://crabby-images/983b8/983b8ac278a33058cd6812c1a9039fc83b66bc4b" alt="Homepage of Project with data"
Set Domain
ในตัวอย่างนี้ ผมจด Domain อยู่ที่ Cloudflare ผมก็แค่เอาเลข IP Address ที่ได้จาก DigitalOcean มาใส่ ตามรูปนี้ ก็เป็นอันใช้ได้
data:image/s3,"s3://crabby-images/f6693/f66931a19771829889f8ee65ca8e576dae85b791" alt="Add Domain"
ปกติแล้วขั้นตอนการ set domain จะใช้ เวลา 1 - 2 วัน อย่างช้า แต่ปกติจากที่ผม set ไม่เกินชั่วโมงก็ใช้ได้ละ
ลองเข้าเว็บเราผ่าน Domain ก็เป็นอันใช้ได้ แต่จะเห็นว่าหน้าชื่อเว็บเราขึ้น Not Secure เพราะเรายังไม่มี SSL นั่นเอง
data:image/s3,"s3://crabby-images/0942d/0942d36346a2d3d6b24b39a45d95e1a171035a98" alt="Visit homepage with Domain"
Add SSL certificate
ถือว่าเป็นเรื่องที่ดี ที่เราสามารถใช้ SSL ได้แบบฟรีจาก letsencrypt ว่าแล้วก็มาลองติดตั้งกันเลย
โดยเราจะใช้ certbot ในการใส่ SSL Certificate ให้เรา
Install
เริ่มจากการติดตั้ง certbot กันก่อนเลย
sudo apt install certbot python3-certbot-nginx
ตอบ y เพื่อยืนยันการติดตั้ง
data:image/s3,"s3://crabby-images/5d54d/5d54d6165086ac75aa330e86645814722c0dd46d" alt="Install certbot"
Allowing HTTPS Through the Firewall
ทำการ allow Nginx Full
และลบการ allow Nginx HTTP
ด้วยคําสั่ง
sudo ufw allow 'Nginx Full'
sudo ufw delete allow 'Nginx HTTP'
data:image/s3,"s3://crabby-images/c04b4/c04b417d4a3c5ba60fad3b02aec48ea75a15eb16" alt="allow Nginx Full and delete allow Nginx HTTP"
ลองเช็ค status อีกครั้ง ด้วยคําสั่ง
sudo ufw status
จะเห็นว่า Nginx HTTP จะหายไป และแทนที่ด้วย Nginx Full
data:image/s3,"s3://crabby-images/b655e/b655e5da79b0983c29b99ec7270862b65ada6379" alt="ufw status"
Obtaining an SSL Certificate
ต่อมาใช้ certbot เพื่อตั้งค่า SSL ด้วยคำสั่ง
ตรงนี้ใครใช้ domain ไหน ก็ใส่ domain ของตัวเองได้เลย
sudo certbot --nginx -d demo-symfony.9mza.net
จากนั้นกรอก email address เสร็จแล้วกด Enter
data:image/s3,"s3://crabby-images/eebf7/eebf7eee3cfc8290bff55495419f67862658d945" alt="register SSL certificate with email address"
ตอบ y เพื่อยอมรับเงื่อนไขการใช้งาน
data:image/s3,"s3://crabby-images/30047/30047936729beb7abcb976d5709053e41886cf5a" alt=""
ตอบ y อีกครั้ง
data:image/s3,"s3://crabby-images/ecb27/ecb270ab7f8daeeaa8d57d8a666e1c33569a06f0" alt="Request SSL Certificate"
ถ้าขึ้นแบบนี้ ก็เป็นอันเรียบร้อยสำหรับการใส่ SSL Certificate
data:image/s3,"s3://crabby-images/b4160/b4160777573b2b814eb7873355ef36855fa0a943" alt="Register SSL Certificate Successful"
data:image/s3,"s3://crabby-images/d13bf/d13bf799c1e7aebcc3479c26b6c3e1d1ae9c75ff" alt="Review SSL Certificate"
จากนั้นลองเข้ามาดูเว็บของเราใหม่ จะเห็นว่าข้อความ not secure จะหายไปแล้ว พร้อมมีรูปกุญแจ ก็เป็นอันเรียบร้อยสำหรับการใส่ SSL Certificate แล้ว
data:image/s3,"s3://crabby-images/10ea2/10ea266fdb36680c55df6928c5faa5d66c2bf7dd" alt="Homepage with SSL Certificate"
Production Environment
มาถึงขั้นตอนสุดท้ายละ ก็คือการทำให้ Symfony อยู่บน Production Environment ถ้าสั่งเกตจะเห็นแทบ Debug ด้านล่าง ซึ่งเราจะเอามันออกไปด้วยการเปลี่ยนเป็น Production Environment นั่นเอง
ก่อนอื่นเลยเรามาเช็ค symfony-requirements กันก่อน (ซึ่งจริงๆ เราควรจะทำเป็นอันดับแรก แต่ผมลืม 😅 ก็เลยเอาไว้ท้ายๆ เลยละกัน)
โดยเราจะ cd เข้าไปที่ project ของเรา แล้วต้องติดตั้ง symfony-requirements
composer require symfony/requirements-checker
จากนั้น ใช้คําสั่ง
php vendor/bin/requirements-checker
เพื่อเช็ค requirements ของ Symfony ว่าทุกอย่างติดตั้งครบตามที่ Symfony ต้องการ
data:image/s3,"s3://crabby-images/c5889/c5889bc835525bc1fae2670c8b01b45cabab1c2a" alt="Symfony Requirements Checker"
จากนั้นทำการ dump env เป็น prod
ด้วยคำสั่งนี้
ขั้นตอนนี้ก็คือการเปลี่ยนเปลี่ยน environment ของ Symfony เป็น Production นั่นเอง
composer dump-env prod
ถ้าสำเร็จจะขึ้นข้อความแบบนี้
data:image/s3,"s3://crabby-images/abca7/abca75bba242d365dd452f4131b34d639a1893d2" alt="dump .env prod"
จากนั้นทำการ install dependencies ใหม่ โดยรอบนี้เราจะไม่ติดตั้ง dev dependencies แล้ว
composer install --no-dev --optimize-autoloader
data:image/s3,"s3://crabby-images/a18d3/a18d3855e09f9135016556727b0e61d94bee8f83" alt="dump .env prod"
ลองเข้าเว็บจะขึ้นหน้าจอ error แบบนี้
data:image/s3,"s3://crabby-images/0f29e/0f29e2d227b530eab54dcd8651596f4a5e46d951" alt="Symfony Error 500"
ก็ไม่ต้องตกใจไป
ให้พิมพ์คำสั่งนี้เพื่อ ล้าง cache
APP_ENV=prod APP_DEBUG=0 php bin/console cache:clear
data:image/s3,"s3://crabby-images/92f09/92f092d6342db4650bdb2242f685911c5990a549" alt="clear prod cache"
จากนั้นเพิ่ม permission ใน var/prod ด้วยคำสั่ง
sudo chmod -R 777 var/cache/prod/
data:image/s3,"s3://crabby-images/84bf0/84bf0c46e3d2149093e4e93e494f9c825b3cecf0" alt="Add Permission to var/cache/prod/"
ลองเข้าเว็บดูอีกที
data:image/s3,"s3://crabby-images/55e04/55e048cd05ddda5aad35c2f848dd2f17e823f30e" alt="Symfony with Production"
ก็เป็นอันใช้ได้ ก็จะเห็นว่าไม่ error และ แถบ debug ได้หายไปแล้ว
ก็หวังว่าบทความนี้จะช่วยสำหรับใครที่กำลังมองหาวิธีการ deploy Symfony บน Digital Ocean กันนะครับ สงสัยตรงไหนพิมพ์ไว้ด้านล่างได้เลยนะครับ