Skip to content

Production-ready zero-downtime deployment script for Laravel

License

Notifications You must be signed in to change notification settings

ChrisBrenton/deploy-laravel

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

21 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Deploy Laravel

Production-ready zero-downtime deployment script for Laravel.

Install

Visit the link below for the download and the installation guide:

Requirements:

  • Laravel 5 or higher
  • Ubuntu 16.04 or higher / CentOS7 or higher

Installing this deployment script can typically be done in less than 10 minutes. Make sure you follow the installation guide linked above, it helps you configure the script and it prevents any pitfalls (like the pitfall of having stored user uploaded files in the public directory).

Features

This deployment script follows all deployment best practices (except running your tests). A quick overview:

  • CI/CD starts running when you push a new commit to the main branch
  • CI/CD builds and bundles your application
  • The bundle is uploaded to your server
  • When everything is ready the new release is activated (zero-downtime)
  • Laravel's optimization commands are run by the before and after activation hooks.
  • File permissions are set correctly for the new release (if necessary)
  • OPCache is flushed by calling opcache_reset()

Migrating from a different way of deploying

This deployment script is compatible with Deployer and Laravel Envoyer. If you have already deployed your application with Deployer or Laravel Envoyer then you can switch to this deployment script without making any changes.

If your application has already been deployed with git clone, FTP or Laravel Forge quick deploy, then you only have to change your Apache2/Nginx webroot from public to current/public. How to make this change is explained in the installation guide.

About

Production-ready zero-downtime deployment script for Laravel

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Shell 90.5%
  • PHP 9.5%