在Linux服务器上部署Laravel API涉及多个步骤,包括安装必要的软件、配置Web服务器、设置数据库连接等。以下是一个基本的指南:
首先,确保你的系统包是最新的:
sudo apt update
sudo apt upgrade -y
Laravel需要PHP 7.3或更高版本。你可以使用以下命令安装PHP及其常用扩展:
sudo apt install php php-cli php-fpm php-json php-common php-mysql php-zip php-gd php-mbstring php-curl php-xml php-pear php-bcmath
Composer是PHP的依赖管理工具:
curl -sS https://getcomposer.org/installer | php
sudo mv composer.phar /usr/local/bin/composer
你可以选择安装Nginx或Apache作为Web服务器。这里以Nginx为例:
sudo apt install nginx
sudo systemctl start nginx
sudo systemctl enable nginx
编辑Nginx配置文件,通常位于/etc/nginx/sites-available/default
:
sudo nano /etc/nginx/sites-available/default
添加以下内容(根据你的项目路径进行调整):
server {
listen 80;
server_name your_domain.com;
root /path/to/your/laravel/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/php7.4-fpm.sock; # 根据你的PHP版本调整
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
location ~ /\.ht {
deny all;
}
}
保存并退出编辑器,然后测试Nginx配置:
sudo nginx -t
重新加载Nginx以应用更改:
sudo systemctl reload nginx
将你的Laravel项目克隆到服务器上的一个目录中:
cd /var/www
git clone https://github.com/your-username/your-laravel-project.git
进入项目目录并使用Composer安装依赖:
cd your-laravel-project
composer install --no-dev --optimize-autoloader
确保Laravel项目的storage
和bootstrap/cache
目录可写:
sudo chown -R www-data:www-data /var/www/your-laravel-project
sudo chmod -R 755 /var/www/your-laravel-project
sudo chmod -R 777 /var/www/your-laravel-project/storage
sudo chmod -R 777 /var/www/your-laravel-project/bootstrap/cache
使用MySQL或PostgreSQL创建一个新的数据库:
sudo mysql -u root -p
在MySQL shell中:
CREATE DATABASE your_database_name;
CREATE USER 'your_database_user'@'localhost' IDENTIFIED BY 'your_database_password';
GRANT ALL PRIVILEGES ON your_database_name.* TO 'your_database_user'@'localhost';
FLUSH PRIVILEGES;
EXIT;
.env
文件编辑Laravel项目的.env
文件,配置数据库连接:
DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_PORT=3306
DB_DATABASE=your_database_name
DB_USERNAME=your_database_user
DB_PASSWORD=your_database_password
php artisan migrate
php artisan optimize
如果你使用队列,可以启动队列监听器:
nohup php artisan queue:work --sleep=3 --tries=3 &
确保你的防火墙允许HTTP和HTTPS流量:
sudo ufw allow 'Nginx Full'
现在,你的Laravel API应该已经成功部署在Linux服务器上,并且可以通过浏览器或API客户端访问。