Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/papertank/envoy-deploy
Laravel Envoy Deployment
https://github.com/papertank/envoy-deploy
laravel-envoy
Last synced: 3 months ago
JSON representation
Laravel Envoy Deployment
- Host: GitHub
- URL: https://github.com/papertank/envoy-deploy
- Owner: papertank
- License: mit
- Created: 2015-03-17T20:08:53.000Z (almost 10 years ago)
- Default Branch: master
- Last Pushed: 2022-11-14T10:58:03.000Z (about 2 years ago)
- Last Synced: 2024-07-31T12:08:09.675Z (6 months ago)
- Topics: laravel-envoy
- Language: Blade
- Size: 57.6 KB
- Stars: 422
- Watchers: 10
- Forks: 85
- Open Issues: 0
-
Metadata Files:
- Readme: readme.md
- License: LICENSE
Awesome Lists containing this project
- favorite-link - 使用开源 Laravel Envoy 工具提供基本的“零停机”部署。
README
# Laravel Envoy Deploy
This repository includes an Envoy.blade.php script that is designed to provide a basic "zero-downtime" deployment option using the open-source [Laravel Envoy](https://laravel.com/docs/envoy) tool.
## Requirements
This Envoy script is designed to be used with Laravel 7+ projects and can be used within the Laravel root, or downloaded separately and included in your Laravel project.
## Installation
Your must have Envoy installed using the Composer global command:
composer global require "laravel/envoy"
### Standalone
To download and run out-with your Laravel project, clone this directory and do a composer install.
### Laravel
#### Laravel 9+
To use within an existing Laravel 8+ project, you simply need to download the version 5 `Envoy.blade.php` file to your project root:
```
wget https://raw.githubusercontent.com/papertank/envoy-deploy/master/Envoy.blade.php
```#### Laravel 7+
To use within an existing Laravel 7+ project, you simply need to download the version 4 `Envoy.blade.php` file to your project root:
```
wget https://raw.githubusercontent.com/papertank/envoy-deploy/v4/Envoy.blade.php
```#### Laravel 5-6
To use within an existing Laravel 5 or 6 project, you simply need to download the version 2 `Envoy.blade.php` file to your project root:
```
wget https://raw.githubusercontent.com/papertank/envoy-deploy/v2/Envoy.blade.php
```## Setup
### Config
Envoy Deploy uses [DotEnv](https://github.com/vlucas/phpdotenv) to fetch your server and repository details. If you are installing within a Laravel project, there will already be a `.env` file in the root, otherwise simply create one.
The following configuration items are required:
- `DEPLOY_SERVER`
- `DEPLOY_REPOSITORY`
- `DEPLOY_PATH`For example, deploying the standard Laravel repository on a Forge server, we might use:
```
[email protected]
DEPLOY_REPOSITORY=https://github.com/laravel/laravel.git
DEPLOY_PATH=/home/forge/example.com
DEPLOY_HEALTH_CHECK=https://example.forge.com
```The `DEPLOY_PATH` (server path) should already be created in your server and must be a blank directory.
### Host
Envoy Deploy uses symlinks to ensure that your server is always running from the latest deployment. As such you need to setup your Apache or Nginx host to point towards the `host/current/public` directory rather than simply `host/public`.
For example:
```
server {
listen 80;
server_name example.com;
root /home/forge/example.com/current/public;location / {
try_files $uri $uri/ /index.php?$query_string;
}location ~ \.php$ {
fastcgi_split_path_info ^(.+\.php)(/.+)$;
fastcgi_pass unix:/var/run/php/php7.4-fpm.sock;
fastcgi_index index.php;
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME $realpath_root$fastcgi_script_name;
fastcgi_param DOCUMENT_ROOT $realpath_root;
}location ~ /\.ht {
deny all;
}
}
```## Usage
### Init
When you're happy with the config, run the init task on your local machine by running the following.
envoy run init
You only need to run the init task once.
The init task creates a `.env` file in your root path (from your `.env.example` file), so make sure and update the environment variables appropriately. Once you have run the init task, you should proceed to run the deploy task (below).
### Deploy
Each time you want to deploy simply run the deploy task on your local machine in the repository direcory
envoy run deploy
You can specify the Laravel environment (e.g. for artisan:migrate command) and git branch as options
envoy run deploy --branch=develop --env=development
### Deploy with Cleanup
If you could like to deploy your repository and cleanup any old deployments at the same time, you can run
envoy run deploy --cleanup
This will run the deploy script and then delete any old deployments older than 48 hours, leaving at least 4.
You can also run the cleanup script independently (without deploying) using
envoy run deployment_cleanup
### Deploy with Maintenance Mode
Although this script is designed to use zero-downtime deployments, you can activate Laravel's maintenance mode while deploying by using the down option:
envoy run deploy --down
### Health Check
If you would like to perform a health check (for 200 response) after deploying, simply add your site's URL in the .env file:
```
DEPLOY_HEALTH_CHECK=https://example.forge.com
```### Rollback
To rollback to the previous deployment (e.g. when a health check fails), you can simply run
envoy run rollback
## Commands
#### `envoy run init`
Initialise server for deployments
Options
--env=ENVIRONMENT The environment to use. (Default: "production")
--branch=BRANCH The git branch to use. (Default: "master")#### `envoy run deploy`
Run new deployment
Options
--env=ENVIRONMENT The environment to use. (Default: "production")
--branch=BRANCH The git branch to use. (Default: "master")
--cleanup Whether to cleanup old deployments
--down Enable maintenance mode#### `envoy run deployment_cleanup`
Delete any old deployments, leaving just the last 4.
#### `envoy run rollback`
In case the health check does not work, you can rollback and it will use the previous deploy.
## How it Works
Your `$path` directory will look something like this after you init and then deploy.
releases/
current -> ./releases/20220103125914
storage/
.envAs you can see, the *current* directory is symlinked to the latest deployment folder
Inside one of your deployment folders looks like the following (excluded some laravel folders for space)
app/
artisan
boostrap/
composer.json
.env -> ../.env
storage -> ../storage
vendor/The deployment folder .env file and storage directory are symlinked to the parent folders in the main (parent) path.
## Optional Features
### Restart Queue Workers
If you use Laravel's queue daemon, you should set the following environment variable to `true` to automatically run `php artisan artisan queue:restart`
```
DEPLOY_RESTART_QUEUE=true
```Alternatively, if you use [Laravel Horizon](https://laravel.com/docs/9.x/horizon) for your Redis queue management, you should set the value to `horizon` to automatically `php artisan horizon:terminate`
```
DEPLOY_RESTART_QUEUE="horizon"
```### Reload PHP FPM
If you use something like OPCache, you should reload the PHP FPM service at the end of each deployment.
Simply update the following environment variable to your PHP-FPM service name, which will automatically run `sudo -S service php8.1-fpm reload`
```
DEPLOY_PHP_FPM="php8.1-fpm"
```### Multiple PHP Versions
If you use multiple PHP versions on your server (e.g. with Laravel Forge) and are not with the default version, you should update your environment variables to specify the version and binaries. For example:
```
DEPLOY_PHP_CMD="/usr/bin/php7.4"
DEPLOY_COMPOSER_CMD="/usr/bin/php7.4 /usr/local/bin/composer"
DEPLOY_PHP_FPM="php7.4-fpm"
```### Laravel Mix / NPM
If you use Laravel mix / npm dependencies in your project, you should add the (disabled by default) `deployment_npm` task to the deploy story. For example:
```
@story('deploy')
deployment_start
deployment_links
deployment_composer
deployment_npm
deployment_migrate
deployment_cache
deployment_symlink
deployment_reload
deployment_finish
health_check
deployment_option_cleanup
@endstory
```If you only use Laravel mix for asset compilation and don't use any node scripts after deployment, you can update your deployment script to remove the node_modules folder and save some disk space on old deployments:
```
@task('deployment_npm')
echo "Installing npm dependencies..."
cd {{ $release }}
npm install --no-audit --no-fund --no-optional
echo "Running npm..."
npm run {{ $env }} --silent
rm -rf {{ $release }}/node_modules
@endtask
```## Disclaimer
Before using on live server, it is best to test on a local VM (like [Laravel Homestead](https://laravel.com/docs/8.x/homestead)) first.
## Changes
V5.0
- Added $php and $composer variables to allow binary paths to be updated.
- Added $releases variable for /releases path.
- Added optional $php_fpm variable (DEPLOY_PHP_FPM env variable) to reload FPM service.
- Added --down option to enable maintenance mode.
- Added deployment_reload task.
- Added $restartQueue variable (DEPLOY_RESTART_QUEUE env variable) to restart queue / horizon.V4.1
- Added fastcgi_param SCRIPT_FILENAME and DOCUMENT_ROOT variables (for better nginx symlink handling).V4.0
- Added optional deployment_npm task (disabled by default).
- Tidied up deployments into releases folder.
- Removed deploy_cleanup story to simplify - use 'envoy run deploy --cleanup'.
- Removed storage/public link and replaced with 'php artisan storage:link' command.V3.0
- Updated DotEnv to "^4.0" for Laravel 7 compatibility.V2.2
- Added `health_check` task and config.
- Added `rollback` task to update current to previous deployment.
- Updated `cleanup` to delete old deploys and leave last 4.
- Removed `deployment_optimize` task (no longer needed for Laravel 5 projects).
- Updated `deployment_composer` to use `--prefer-dist --optimize-autoloader` options.V2.1 - Updated init to only initialize (rather than deploy).
v2.0 - Switched to using DotEnv (removing `envoy.config.php`) and cleaned up tasks/stories.
v1.0.1 - Added `cleanup` task and `deploy_cleanup` macro after changing cleanup command.
## Contributing
Please submit improvements and fixes :)
## Credits
* [Servers for Hackers](https://serversforhackers.com/video/enhancing-envoy-deployment) for inspiration
* [@noeldiaz on Laracasts](https://laracasts.com/@noeldiaz) for deployment cleanups idea
* [Harmen Stoppels](https://serversforhackers.com/video/enhancing-envoy-deployment#comment-1900893160) for cloning HEAD only
* [Jordi Puigdellívol @badchoice](https://github.com/BadChoice) for V2.2 updates (health check and rollback).## Author
[Papertank Limited](http://papertank.co.uk)