简介
当你准备部署你的 Laravel
应用到生产环境时,请确保几个重要的注意点以保证你的应用能尽可能高效的运行。本文中我们将会覆盖几个重点来确保你的 Laravel
应用部署得当。
服务器配置
Nginx
如果你想要部署你的应用到 Nginx
服务器上,你可能会用到下面这个配置文件作为一个开始来配置你的 Web
服务器。很有可能,这个文件需要根据你的服务器配置来做一些自定义的修改。如果你需要协助来管理你的服务器,可以考虑使用 Laravel Forge:
server {
listen 80;
server_name example.com;
root /example.com/public;
add_header X-Frame-Options "SAMEORIGIN";
add_header X-XSS-Protection "1; mode=block";
add_header X-Content-Type-Options "nosniff";
index index.html index.htm index.php;
charset utf-8;
location / {
try_files $uri $uri/ /index.php?$query_string;
}
location = /favicon.ico { access_log off; log_not_found off; }
location = /robots.txt { access_log off; log_not_found off; }
error_page 404 /index.php;
location ~ \.php$ {
fastcgi_pass unix:/var/run/php/php7.2-fpm.sock;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $realpath_root$fastcgi_script_name;
include fastcgi_params;
}
location ~ /\.(?!well-known).* {
deny all;
}
}
改进
自动加载器改进
当你准备往生产环境部署应用时,确保你优化了你的Composer类的自定加载映射,这样可以使Composer可以很快的找到正确的加载文件去加载给定的类:
composer install --optimize-autoloader --no-dev
小提示:除了优化自动加载器, 你还应该确保在你的项目代码仓库中包含了composer.lock
这个文件。当你的项目代码中有composer.lock
这个文件时,便可以更快的安装项目中需要的依赖项。
优化配置加载
当你将应用程序部署到生产环境时,你应当确保在你部署过程中运行 config:cache
Artisan 命令:
php artisan config:cache
此命令将所有 Laravel 的配置文件合并到一个缓存文件,这次极大地减少了框架在加载配置值时必须对文件系统进行访问的次数。
{note} 如果在你部署过程中执行config:cache
命令,你应当确保你仅从你的配置文件中调用env
函数。一旦配置被缓存,.env
文件将不被加载并且对env
函数的所有调用将返回null
。
优化路由加载
如果你想构建具有许多路由的大型应用程序,你应当确保在你部署的过程中运行 route:cache
Artisan 命令:
php artisan route:cache
此命令将为所有路由注册缩减到一个缓存文件中的单个方法调用,从而在注册数百个路由时提高了路由注册的性能。
{note} 由于此功能使用 PHP 序列化,你仅能缓存专门使用基于控制器路由的应用程序路由。PHP 不能序列化闭包路由。
使用 Forge 部署
如果你还没有准备好管理自己的服务器配置,或者不熟悉配置对运行强大的 Laravel 应用程序所需的各种服务,Laravel Forge 是一个好的选择。
Laravel Forge 能在各种基础设施提供商(如:DigitalOcean,Linode,AWS 等等)上创建服务器。另外,Forge 安装和管理构建强大 Laravel 应用程序所需的所有工具,比如:Nginx,MySQL,Redis,Memcached,Beanstalk 等等。