Cài đặt và chạy một trang web viết bằng Symfony trên Linux (Fedora, Ubuntu, Arch)
Bài đăng này đã không được cập nhật trong 3 năm
Giới Thiệu
Trong bài viết này, chúng ta sẽ cùng tìm hiểu cách cài đặt và chạy một trang web viết bằng Symfony phiên bản 5.x trên Linux. Cụ thể là 3 hệ điều hành Linux đang phổ biến Fedora, Ubuntu và Arch.
Trong mỗi distro, chúng ta đều cần cài 4 packages:
- PHP 8.x
- Git
- Composer
- Symfony CLI
Chỉ có cách cài PHP trên distro khác nhau thì sẽ khác nhau, còn lại Git, Composer và Symfony CLI đều như nhau. Như vậy, mình sẽ hướng dẫn các bạn các cài đặt PHP trên mỗi distro trước, sau đó mình sẽ hướng dẫn cách cài đặt Git, Composer và Symfony CLI chung trên cả 3 distro.
Cài PHP
Cài PHP 8.x trên Ubuntu 20.04
Các bạn chạy lần lượt các lệnh sau và nhập mật khẩu nếu được hỏi:
sudo apt install software-properties-common
sudo add-apt-repository ppa:ondrej/php
sudo apt update
sudo apt install php8.0 libapache2-mod-php8.0
sudo systemctl restart apache2
Sau khi cài đặt xong, để kiểm tra xem PHP đã được cài chưa và có cài chính xác version các bạn mong muốn không thì các bạn gõ lệnh:
php --version
Nếu output của bạn gần giống như vậy thì chúng ta đã cài xong PHP (một số thông tin có thể khác nhưng bạn cần lưu ý version phải từ 8 trở lên):
PHP 8.0.9 (cli) (built: Jul 29 2021 12:53:58) ( NTS gcc x86_64 )
Copyright (c) The PHP Group
Zend Engine v4.0.9, Copyright (c) Zend Technologies
Cài PHP 8.x trên Fedora 34
Các bạn chạy lần lượt các lệnh sau và nhập mật khẩu nếu được hỏi:
sudo dnf install https://rpms.remirepo.net/fedora/remi-release-34.rpm
sudo dnf module reset php
sudo dnf module install php:remi-8.0
Sau khi cài đặt xong, để kiểm tra xem PHP đã được cài chưa và có cài chính xác version các bạn mong muốn không thì các bạn gõ lệnh:
php --version
Nếu output của bạn gần giống như vậy thì chúng ta đã cài xong PHP (một số thông tin có thể khác nhưng bạn cần lưu ý version phải từ 8 trở lên):
PHP 8.0.9 (cli) (built: Jul 29 2021 12:53:58) ( NTS gcc x86_64 )
Copyright (c) The PHP Group
Zend Engine v4.0.9, Copyright (c) Zend Technologies
Cài PHP 8.x trên Arch
Lưu ý, với Arch thì bạn cần cập nhật bản mới nhất cho distro bằng lệnh :
sudo pacman -Syyu
Sau đó các bạn chạy lệnh sau:
sudo pacman -S php
Sau khi cài đặt xong, để kiểm tra xem PHP đã được cài chưa và có cài chính xác version các bạn mong muốn không thì các bạn gõ lệnh:
php --version
Nếu output của bạn gần giống như vậy thì chúng ta đã cài xong PHP (một số thông tin có thể khác nhưng bạn cần lưu ý version phải từ 8 trở lên):
PHP 8.0.9 (cli) (built: Jul 29 2021 12:53:58) ( NTS gcc thànhx86_64 )
Copyright (c) The PHP Group
Zend Engine v4.0.9, Copyright (c) Zend Technologies
Cài Git
Trên Ubuntu 20.04
sudo apt install git
Trên Fedora 34
sudo dnf install git
Trên Arch
sudo pacman -S git
Cài Composer
Các bạn chạy lần lượt các lệnh sau:
php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');"
php -r "if (hash_file('sha384', 'composer-setup.php') === '756890a4488ce9024fc62c56153228907f1545c228516cbf63f885e036d37e9a59d27d63f46af1d4d07ee0f76181c7d3') { echo 'Installer verified'; } else { echo 'Installer corrupt'; unlink('composer-setup.php'); } echo PHP_EOL;"
php composer-setup.php
php -r "unlink('composer-setup.php');"
sudo mv composer.phar /usr/local/bin/composer
Cài Symfony CLI
Các bạn chạy lệnh sau để cài Symfony CLI, lưu ý các bạn cần có wget hoặc curl trước khi cài Symfony CLI.
wget https://get.symfony.com/cli/installer -O - | bash
sudo mv /home/username/.symfony/bin/symfony /usr/local/bin/symfony
Bạn cần thay thế username bằng username của các bạn. Ví dụ username của user trên máy mình là lkp, thì câu lệnh thứ 2 sẽ thành:
sudo mv /home/lkp/.symfony/bin/symfony /usr/local/bin/symfony
Khởi tạo dự án bằng Symfony CLI
Để khởi tạo dự án, bạn gõ lệnh:
symfony new projectName --version=version
Lưu ý, bạn cần thay thế projectName thành tên project của mình và version thành phiên bản bạn muốn cài đặt. Ví dụ tên project của mình là todolo và version mình muốn cài là 5.3 thì câu lệnh sẽ thành:
symfony new todolo --version=5.3
Bạn có thể bỏ qua phần version để cài đặt bản mới nhất của Symfony. Ví dụ bản mới nhất thời điểm mình viết bài này là 5.3 nên khi mình gõ lệnh:
symfony new todolo
Thì sẽ tự động khởi tạo dự án Symfony phiên bản 5.3.
Chạy dự án
Để chạy dự án mới khởi tạo các bạn cần truy cập vào dự án mới tạo:
cd new-project
Ví dụ, mình mới tạo dự án tên todolo, thì mình cần chạy lệnh:
cd todolo
Sau đó các bạn gõ lệnh để chạy dự án:
symfony serve
Các bạn sẽ thấy terminal hiện ra những thông tin như thế này:
[WARNING] run "symfony server:ca:install" first if you want to
run the web server with TLS support, or use "--no-tls
" to avoid this warning
Tailing Web Server log file (/home/lkp/.symfony/log/2982355613aafd922c24cff778aecc907ce25a5a.log)
Tailing PHP-FPM log file (/home/lkp/.symfony/log/2982355613aafd922c24cff778aecc907ce25a5a/53fb8ec204547646acb3461995e4da5a54cc7575.log)
[OK] Web server listening
The Web server is using PHP FPM 8.0.9
http://127.0.0.1:8000
[Web Server ] Aug 27 09:21:37 |DEBUG | PHP Reloading PHP versions
[Web Server ] Aug 27 09:21:37 |DEBUG | PHP Using PHP version 8.0.9 (from default version in $PATH)
[Web Server ] Aug 27 09:21:37 |INFO | PHP listening path="/usr/sbin/php-fpm" php="8.0.9" port=37689
[PHP-FPM ] Aug 27 09:21:37 |NOTICE | FPM fpm is running, pid 10546
[PHP-FPM ] Aug 27 09:21:37 |NOTICE | FPM ready to handle connections
[PHP-FPM ] Aug 27 09:21:37 |NOTICE | FPM systemd monitor interval set to 10000ms
Các bạn lưu ý chỗ:
[OK] Web server listening
The Web server is using PHP FPM 8.0.9
http://127.0.0.1:8000
Ở đây có nghĩa là bạn đã chạy dự án thành công. Dự án chạy trên Domain 127.0.0.1 và cổng là 8000. Như vậy, để truy cập dự án, bạn mở browser, gõ vào url: http://127.0.0.1:8000 hoặc localhost:8000. Tada, nếu các bạn thấy màn hình như thế này thì các bạn đã chạy dự án thành công. Các bạn lưu ý có thể đường dẫn thư mục trong hình /home/lkp/Workspace/test/scratch-project sẽ khác với các bạn, miễn sao nó là đường dẫn thư mục đến dự án của các bạn là ok:
Lời kết
Như vậy chúng ta đã cài đặt những pakages cần thiết và chạy dự án viết bằng Symfony trên Linux. Nếu có gặp lỗi, khó khăn hay bất kì thắc mắc gì, các bạn hãy tham gia cộng đồng Symfony Vietnam để trao đổi thêm cũng như là giải quyết những vấn đề bạn đang gặp phải. Chúc các bạn thành công.
All rights reserved