在Debian上部署Laravel RESTful API涉及多個步驟,包括安裝必要的軟件、配置Web服務器、設置數據庫以及部署Laravel應用。以下是一個詳細的步驟指南:
首先,確保你的Debian系統是最新的:
sudo apt update
sudo apt upgrade -y
Nginx是一個高性能的HTTP和反向代理服務器。我們將使用它來托管我們的Laravel應用。
sudo apt install nginx -y
Laravel需要PHP以及一些PHP擴展。你可以使用以下命令安裝PHP及其擴展:
sudo apt install php-fpm php-mysql php-curl php-json php-xml php-gd php-mbstring -y
編輯PHP-FPM配置文件以確保它與Nginx一起工作:
sudo nano /etc/php/7.4/fpm/pool.d/www.conf
找到以下行并取消注釋:
;listen = /run/php/php7.4-fpm.sock
改為:
listen = /run/php/php7.4-fpm.sock
創建一個新的Nginx服務器塊配置文件來托管你的Laravel應用:
sudo nano /etc/nginx/sites-available/yourdomain.com
添加以下內容(根據你的域名和項目路徑進行調整):
server {
listen 80;
server_name yourdomain.com www.yourdomain.com;
root /var/www/yourdomain.com/public;
index index.php index.html index.htm;
location / {
try_files $uri $uri/ /index.php?$query_string;
}
location ~ \.php$ {
include snippets/fastcgi-php.conf;
fastcgi_pass unix:/run/php/php7.4-fpm.sock;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
location ~ /\.ht {
deny all;
}
}
保存并退出編輯器,然后創建一個符號鏈接以啟用該配置:
sudo ln -s /etc/nginx/sites-available/yourdomain.com /etc/nginx/sites-enabled/
重啟Nginx以應用新的配置:
sudo systemctl restart nginx
安裝MySQL數據庫服務器:
sudo apt install mysql-server -y
運行安全腳本以設置MySQL的安全選項:
sudo mysql_secure_installation
登錄到MySQL并創建一個新的數據庫和用戶:
sudo mysql -u root -p
在MySQL shell中執行以下命令:
CREATE DATABASE laravel_db;
CREATE USER 'laravel_user'@'localhost' IDENTIFIED BY 'your_password';
GRANT ALL PRIVILEGES ON laravel_db.* TO 'laravel_user'@'localhost';
FLUSH PRIVILEGES;
EXIT;
將你的Laravel應用代碼上傳到服務器的/var/www/yourdomain.com
目錄。你可以使用Git、FTP或其他文件傳輸方法。
在Laravel項目目錄中運行以下命令以安裝Composer依賴:
cd /var/www/yourdomain.com
composer install --no-dev --optimize-autoloader
復制.env.example
文件并編輯它以配置你的環境變量:
cp .env.example .env
nano .env
根據你的數據庫配置更新以下行:
DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_PORT=3306
DB_DATABASE=laravel_db
DB_USERNAME=laravel_user
DB_PASSWORD=your_password
生成Laravel應用密鑰:
php artisan key:generate
運行數據庫遷移以創建必要的表:
php artisan migrate
如果你需要使用隊列,可以配置它:
php artisan queue:work
最后,啟動Laravel應用以確保一切正常運行:
php artisan serve --host=0.0.0.0 --port=80
現在,你的Laravel RESTful API應該可以通過瀏覽器訪問了。如果你遇到任何問題,請檢查Nginx和PHP-FPM的日志文件以獲取更多信息。