如何在Debian上部署Laravel API

279
2025/3/9 3:32:07
栏目: 智能运维
开发者测试专用服务器限时活动,0元免费领,库存有限,领完即止! 点击查看>>

在Debian上部署Laravel API涉及多个步骤,包括安装必要的软件、配置Web服务器、设置数据库和部署Laravel应用。以下是一个详细的步骤指南:

1. 更新系统

首先,确保你的Debian系统是最新的:

sudo apt update
sudo apt upgrade -y

2. 安装Nginx

Nginx是一个高性能的HTTP和反向代理服务器。安装Nginx:

sudo apt install nginx -y

3. 安装PHP和必要的PHP扩展

Laravel需要PHP和一些特定的PHP扩展。安装这些依赖:

sudo apt install php-fpm php-mysql php-curl php-xml php-mbstring php-zip php-gd -y

4. 配置PHP-FPM

编辑PHP-FPM配置文件以优化性能:

sudo nano /etc/php/7.4/fpm/pool.d/www.conf

找到并修改以下行:

listen = /run/php/php7.4-fpm.sock
listen.owner = www-data
listen.group = www-data

保存并退出编辑器,然后重启PHP-FPM服务:

sudo systemctl restart php7.4-fpm

5. 配置Nginx

创建一个新的Nginx服务器块配置文件:

sudo nano /etc/nginx/sites-available/laravel

添加以下内容:

server {
    listen 80;
    server_name your_domain.com;

    root /var/www/laravel/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/laravel /etc/nginx/sites-enabled/

6. 测试Nginx配置

测试Nginx配置文件是否有语法错误:

sudo nginx -t

如果没有错误,重新加载Nginx服务:

sudo systemctl reload nginx

7. 安装和配置MySQL

安装MySQL服务器:

sudo apt install mysql-server -y

运行安全脚本以设置MySQL:

sudo mysql_secure_installation

按照提示完成设置。

8. 创建数据库和用户

登录到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;

9. 部署Laravel应用

将你的Laravel应用上传到服务器的/var/www/laravel目录。你可以使用FTP、SCP或其他文件传输方法。

进入Laravel项目目录并安装依赖:

cd /var/www/laravel
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

生成应用密钥:

php artisan key:generate

运行数据库迁移:

php artisan migrate

10. 设置文件权限

确保Laravel的storagebootstrap/cache目录可写:

sudo chown -R www-data:www-data /var/www/laravel
sudo chmod -R 755 /var/www/laravel
sudo chmod -R 777 /var/www/laravel/storage
sudo chmod -R 777 /var/www/laravel/bootstrap/cache

11. 配置防火墙

如果你使用的是UFW防火墙,允许HTTP和HTTPS流量:

sudo ufw allow 'Nginx Full'

12. 启动PHP-FPM

确保PHP-FPM服务正在运行:

sudo systemctl start php7.4-fpm
sudo systemctl enable php7.4-fpm

现在,你的Laravel API应该已经成功部署在Debian服务器上,并且可以通过浏览器或API客户端访问。

辰迅云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>

推荐阅读: Node.js日志在Debian如何归档