在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的日志文件以获取更多信息。