0

0

Laravel如何部署到服务器_线上部署Laravel项目的完整流程与步骤

尼克

尼克

发布时间:2025-12-19 08:44:43

|

572人浏览过

|

来源于php中文网

原创

部署Laravel项目需先配置服务器环境,安装Nginx、MySQL、PHP及扩展,再克隆代码并安装依赖;接着配置.env文件为生产环境,设置应用密钥;然后配置Nginx站点指向public目录,设置权限与存储链接;执行数据库迁移与种子数据;配置Cron任务与队列监听;启用HTTPS加密;最后清除缓存以优化性能,确保安全与稳定运行。

laravel如何部署到服务器_线上部署laravel项目的完整流程与步骤

Laravel 项目部署到线上服务器并不是简单地上传代码,而是一个涉及环境配置、安全设置和性能优化的完整流程。以下是将 Laravel 项目从本地部署到生产服务器的标准步骤,适用于大多数 Linux 服务器(如 Ubuntu + Nginx + MySQL + PHP 环境)。

1. 准备服务器环境

确保你的服务器具备运行 Laravel 所需的基础环境:

  • 操作系统:推荐使用 Ubuntu 20.04/22.04 或 CentOS 7/8
  • Web 服务器:Nginx 或 Apache(推荐 Nginx)
  • PHP 版本:Laravel 要求 PHP >= 8.1,建议安装 PHP 8.1 或更高版本
  • 数据库:MySQL 或 MariaDB
  • 扩展支持:确保安装了必要的 PHP 扩展,如 opensslpdombstringtokenizerxmlcurlgdzip
  • 工具:Composer、Git

在 Ubuntu 上可使用以下命令快速安装:

sudo apt update
sudo apt install nginx mysql-server php-fpm php-cli php-mysql php-curl php-gd php-mbstring php-xml php-zip git composer

2. 上传或克隆 Laravel 项目代码

将你的 Laravel 项目上传到服务器,通常放在 /var/www/your-project 目录下。

  • 通过 Git 克隆(推荐):
    cd /var/www
    git clone https://github.com/yourname/your-laravel-project.git your-project
  • 或使用 FTP/SFTP 上传压缩包后解压

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

cd /var/www/your-project
composer install --optimize-autoloader --no-dev

--no-dev 参数会跳过开发依赖,提升生产环境安全性与性能。

3. 配置环境文件 .env

复制示例环境文件并根据服务器信息修改:

cp .env.example .env

编辑 .env 文件:

APP_ENV=production
APP_DEBUG=false
APP_URL=https://yourdomain.com

DB_HOST=localhost DB_DATABASE=your_db_name DB_USERNAME=your_db_user DB_PASSWORD=your_db_password

生成应用密钥:

php artisan key:generate

4. 配置 Web 服务器(以 Nginx 为例)

创建 Nginx 配置文件:

sudo nano /etc/nginx/sites-available/your-project

写入以下内容(注意路径和域名):

server {
    listen 80;
    server_name yourdomain.com;
    root /var/www/your-project/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:/var/run/php/php8.1-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/your-project /etc/nginx/sites-enabled/
sudo nginx -t
sudo systemctl reload nginx

5. 设置权限和存储链接

Laravel 需要对某些目录有写权限:

SCNet智能助手
SCNet智能助手

SCNet超算互联网平台AI智能助手

下载
sudo chown -R www-data:www-data /var/www/your-project
sudo chmod -R 755 /var/www/your-project/storage
sudo chmod -R 755 /var/www/your-project/bootstrap/cache

创建存储软链接(用于访问上传文件):

php artisan storage:link

6. 执行数据库迁移与种子(如有)

运行迁移:

php artisan migrate --force

如果需要填充测试数据:

php artisan db:seed --force

--force 是为了在生产环境中强制执行,避免交互确认。

7. 配置定时任务与队列(可选)

如果你使用了 Laravel 的任务调度功能,在服务器上添加 Cron 条目:

crontab -e

添加以下行:

* * * * * cd /var/www/your-project && php artisan schedule:run >> /dev/null 2>&1

对于队列监听(如使用 Redis):

php artisan queue:work --daemon &

建议使用 Supervisor 管理队列进程。

8. 启用 HTTPS(强烈建议)

使用 Let's Encrypt 免费证书:

sudo certbot --nginx -d yourdomain.com

之后会自动配置 SSL 并重定向 HTTP 到 HTTPS。

9. 清除缓存与优化(可选但推荐)

部署完成后运行以下命令提升性能:

php artisan config:cache
php artisan route:cache
php artisan view:cache

注意:只在生产环境执行这些命令,开发时应清除缓存调试。

基本上就这些。整个流程走完后,你的 Laravel 项目就已经成功部署上线。关键点在于环境一致性、安全配置和正确的文件权限管理。不复杂但容易忽略细节。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2489

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1586

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1482

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

952

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1414

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1234

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1445

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1305

2023.11.13

php与html混编教程大全
php与html混编教程大全

本专题整合了php和html混编相关教程,阅读专题下面的文章了解更多详细内容。

3

2026.01.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Laravel---API接口
Laravel---API接口

共7课时 | 0.6万人学习

PHP自制框架
PHP自制框架

共8课时 | 0.6万人学习

PHP面向对象基础课程(更新中)
PHP面向对象基础课程(更新中)

共12课时 | 0.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号