debian

如何在Debian上部署Laravel RESTful API

小樊
51
2025-09-23 19:15:04
栏目: 智能运维

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

1. 更新系统

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

sudo apt update
sudo apt upgrade -y

2. 安装Nginx

Nginx是一个高性能的HTTP和反向代理服务器。我们将使用它来托管我们的Laravel应用。

sudo apt install nginx -y

3. 安装PHP

Laravel需要PHP以及一些PHP扩展。你可以使用以下命令安装PHP及其扩展:

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

4. 配置PHP-FPM

编辑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

5. 配置Nginx

创建一个新的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/

6. 重启Nginx

重启Nginx以应用新的配置:

sudo systemctl restart 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/yourdomain.com目录。你可以使用Git、FTP或其他文件传输方法。

10. 安装Composer依赖

在Laravel项目目录中运行以下命令以安装Composer依赖:

cd /var/www/yourdomain.com
composer install --no-dev --optimize-autoloader

11. 配置环境变量

复制.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

12. 生成应用密钥

生成Laravel应用密钥:

php artisan key:generate

13. 运行迁移

运行数据库迁移以创建必要的表:

php artisan migrate

14. 配置队列(可选)

如果你需要使用队列,可以配置它:

php artisan queue:work

15. 启动Laravel应用

最后,启动Laravel应用以确保一切正常运行:

php artisan serve --host=0.0.0.0 --port=80

现在,你的Laravel RESTful API应该可以通过浏览器访问了。如果你遇到任何问题,请检查Nginx和PHP-FPM的日志文件以获取更多信息。

0
看了该问题的人还看了