イントロダクションIntroduction
Laravel Envoy(使節)はリモートサーバー間で共通のタスクを実行するために、美しく最小限の記法を提供します。デプロイやArtisanコマンドなどのタスクをBlade記法により簡単に準備できます。EnvoyはMacとLinuxのオペレーションシステムのみサポートしています。Laravel Envoy[https://github.com/laravel/envoy] provides a clean, minimal syntax for defining common tasks you run on your remote servers. Using Blade style syntax, you can easily setup tasks for deployment, Artisan commands, and more. Currently, Envoy only supports the Mac and Linux operating systems.
インストールInstallation
最初にEnvoyをComposerのglobal
require
コマンドでインストールします。First, install Envoy using the
Composer global require
command:
composer global require "laravel/envoy=~1.0"
グローバルComposerライブラリは、時々パッケージバージョンのコンフリクトを起こすため、composer
global
require
コマンドの代替として、cgr
の使用を考慮してください。cgr
ライブラリのインストール方法は、GitHubで見つけられます。Since global Composer libraries
can sometimes cause package version conflicts, you
may wish to consider using cgr
, which
is a drop-in replacement for the composer
global require
command. The
cgr
library's installation instructions
can be found on
GitHub[https://github.com/consolidation-org/cgr].
Note:
envoy
コマンドを端末で実行するときにenvoy
の実行ファイルが見つかるように、~/.composer/vendor/bin
ディレクトリに実行パスを通しておくのを忘れないでください。{note} Make sure to place the~/.composer/vendor/bin
directory in your PATH so theenvoy
executable is found when running theenvoy
command in your terminal.
Envoyの更新Updating Envoy
インストールしたEnvoyをアップデートするためにも、Composerを使用します。composer
global
update
コマンドの実行により、インストール済みのグローバルComposerパッケージがすべてアップデートされます。You may also use Composer to keep
your Envoy installation up to date. Issuing the
composer global update
command will
update all of your globally installed Composer
packages:
composer global update
タスク記述Writing Tasks
Envoyの全タスクはプロジェクトルートのEnvoy.blade.php
ファイルの中で定義します。最初に例を見てください。All of your Envoy tasks should be
defined in an Envoy.blade.php
file in
the root of your project. Here's an example to get
you started:
@servers(['web' => ['user@192.168.1.1']])
@task('foo', ['on' => 'web'])
ls -la
@endtask
見ての通り、@servers
の配列をファイルの最初で定義し、タスク定義のon
オプションでそれらのサーバーを参照できるようにしています。@task
定義の中には、タスクが実行されるときにサーバーで実行するBASHコードを記述します。As you can see, an array of
@servers
is defined at the top of the
file, allowing you to reference these servers in the
on
option of your task declarations.
Within your @task
declarations, you
should place the Bash code that should run on your
server when the task is executed.
サーバのIPアドレスを127.0.0.1
にすることで、強制的にスクリプトをローカルで実行できます。You can force a script to run
locally by specifying the server's IP address as
127.0.0.1
:
@servers(['localhost' => '127.0.0.1'])
準備Setup
タスクを実行する前に、PHPコードを評価する必要がある場合もあります。変数を宣言するために@setup
ディレクティブを使用し、他のタスクが実行される前に通常のPHPを動作させます。Sometimes, you may need to
execute some PHP code before executing your Envoy
tasks. You may use the @setup
directive
to declare variables and do other general PHP work
before any of your other tasks are
executed:
@setup
$now = new DateTime();
$environment = isset($env) ? $env : "testing";
@endsetup
タスク実行前に他のPHPライブラリを読み込む必要がある場合は、Envoy.blade.php
ファイルの先頭で、@include
ディレティブを使用してください。If you need to require other PHP
files before your task is executed, you may use the
@include
directive at the top of your
Envoy.blade.php
file:
@include('vendor/autoload.php')
@task('foo')
# ...
@endtask
変数Variables
必要であれば、コマンドラインを使い、Envoyタスクへオプション値を渡すことができます。If needed, you may pass option values into Envoy tasks using the command line:
envoy run deploy --branch=master
オプションはBladeの"echo"記法により、タスク中からアクセスできます。もちろん、if
文も使用できますし、タスク内で繰り返しも可能です。例としてgit
pull
コマンドを実行する前に、$branch
の存在を確認してみましょう。You may access the options in
your tasks via Blade's "echo" syntax. Of
course, you may also use if
statements
and loops within your tasks. For example, let's
verify the presence of the $branch
variable before executing the git pull
command:
@servers(['web' => '192.168.1.1'])
@task('deploy', ['on' => 'web'])
cd site
@if ($branch)
git pull origin {{ $branch }}
@endif
php artisan migrate
@endtask
ストーリーStories
ストーリーにより、選択した小さなタスクを大きなタスクにまとめることができます。名前を付け、一連のタスクを一つにまとめます。一例としてタスク名をリストすることにより、deploy
ストーリーを定義し、git
とcomposer
タスクを実行してみます。Stories group a set of tasks
under a single, convenient name, allowing you to
group small, focused tasks into large tasks. For
instance, a deploy
story may run the
git
and composer
tasks by
listing the task names within its
definition:
@servers(['web' => '192.168.1.1'])
@story('deploy')
git
composer
@endstory
@task('git')
git pull origin master
@endtask
@task('composer')
composer install
@endtask
ストーリーを書き上げたら、通常のタスクと同じように実行します。Once the story has been written, you may run it just like a typical task:
envoy run deploy
複数サーバMultiple Servers
Envoyでは、複数のサーバーに渡りタスクを実行するのも簡単です。最初に追加のサーバーを@servers
ディレクティブで指定してください。各サーバーには一意な名前を割り当ててください。追加サーバーを定義したら、タスクのon
配列にサーバーをリストするだけです。Envoy allows you to easily run a
task across multiple servers. First, add additional
servers to your @servers
declaration.
Each server should be assigned a unique name. Once
you have defined your additional servers, list each
of the servers in the task's on
array:
@servers(['web-1' => '192.168.1.1', 'web-2' => '192.168.1.2'])
@task('deploy', ['on' => ['web-1', 'web-2']])
cd site
git pull origin {{ $branch }}
php artisan migrate
@endtask
並列実行Parallel Execution
デフォルトでタスクは各サーバーで順番に実行されます。つまり最初のサーバーで実行を終えたら、次のサーバーで実行されます。タスクを複数サーバーで並列実行したい場合は、タスク宣言にparallel
オプションを追加してください。By default, tasks will be
executed on each server serially. In other words, a
task will finish running on the first server before
proceeding to execute on the second server. If you
would like to run a task across multiple servers in
parallel, add the parallel
option to
your task declaration:
@servers(['web-1' => '192.168.1.1', 'web-2' => '192.168.1.2'])
@task('deploy', ['on' => ['web-1', 'web-2'], 'parallel' => true])
cd site
git pull origin {{ $branch }}
php artisan migrate
@endtask
タスク実行Running Tasks
Envoy.blade.php
ファイルのタスクやストーリーを実行するには、実行したいタスクかストーリーの名前を指定し、Envoyのrun
コマンドを実行します。Envoyはタスクを実行し、タスク実行中にサーバからの出力を表示します。To run a task or story that is
defined in your Envoy.blade.php
file,
execute Envoy's run
command, passing
the name of the task or story you would like to
execute. Envoy will run the task and display the
output from the servers as the task is
running:
envoy run task
タスク実行の確認Confirming Task Execution
サーバ上の特定タスク実行前に、確認のプロンプトを出したい場合は、タスク宣言でconfirm
ディレクティブを追加してください。このオプションは、破壊的な操作を行う場合に特に便利です。If you would like to be prompted
for confirmation before running a given task on your
servers, you should add the confirm
directive to your task declaration. This option is
particularly useful for destructive
operations:
@task('deploy', ['on' => 'web', 'confirm' => true])
cd site
git pull origin {{ $branch }}
php artisan migrate
@endtask
通知Notifications
SlackSlack
Envoyは各タスク実行後の、Slackへの通知もサポートしています。@slack
ディレクティブは、SlackフックURLとチャンネル名を引数に取ります。WebフックURLは、Slackコントロールパネルで"Incoming
WebHooks"統合を作成することにより、作成されます。WebフックURL全体を@slack
ディレクティブへ渡してください。Envoy also supports sending
notifications to Slack[https://slack.com]
after each task is executed. The @slack
directive accepts a Slack hook URL and a channel
name. You may retrieve your webhook URL by creating
an "Incoming WebHooks" integration in your
Slack control panel. You should pass the entire
webhook URL into the @slack
directive:
@finished
@slack('webhook-url', '#bots')
@endfinished
チャンネル引数には以下のどちらかを指定します。You may provide one of the following as the channel argument: