Laravel Envoy 优雅的 SSH 远程任务执行工具

说明

假设你有一个自己的小项目, 放在一个小 VPS 上, 每一次当你为这个小项目开发完某个功能的时候, 你要上线代码, 一般的操作都会是以下:

  • 打开命令行, SSH 连接到小项目所在的小 VPS 上;
  • 进入代码的文件夹 cd /my/little/project/directory ;
  • 把本地代码更新为最新的 git pull;

手动做这些事情, 久而久之, 你会觉得自己太笨了, 想有所改变.

是的, Laravel Envoy 就是你的解决方案, TA 允许你通过最少的配置, 只需要在本地的命令行下执行如下的一行命令, 就可以把上面所有的事情都做了.

envoy run deploy

很酷吧.

安装

Laravel Envoy 的运行需要 PHP 5.4 以上, 使用 Composer Global 安装.

composer global require "laravel/envoy=~1.0"

注意: 需要把 ~/.composer/vendor/bin 放到你的 PATH 里面

安装完成后测试

➜ envoy --version
Laravel Envoy version 1.0.16

以后要更新的话, 只需要执行以下

composer global update 

初始化并创建 deploy 任务

首先, 在你的 小项目 跟目录下, 执行以下命令进行初始化

➜ envoy init vagrant@192.168.10.10
Envoy file created!

上面的命令会在此文件夹下生成一个 Envoy.blade.php 的文件, 内容如下

@servers(['web' => 'vagrant@192.168.10.10'])

@task('deploy')
    cd /path/to/site
    git pull origin master
@endtask

语法很简单, 这里就不奥数了, 把上面两行改为你一直在手动执行的命令就行了, 命令行下运行

envoy run deploy

一切就是这么简单, envoy 不止可以帮你做简单的部署, 一些重复性很多的一系列操作动作, 都可以利用 envoy 来做到一个命令搞定, 事实上, 部署平台 Laravel Forge 就是由 envoy POWER 的.

Laravel Envoy 项目地址在这 , 更多高级用法请仔细阅读文档.

最后, 再一次的, 感谢 Taylor OtwellLaravel 项目, 是他让 PHP 编程更加有趣.


Practice makes perfect.

本帖已被设为精华帖!
《L01 基础入门》
我们将带你从零开发一个项目并部署到线上,本课程教授 Web 开发中专业、实用的技能,如 Git 工作流、Laravel Mix 前端工作流等。
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 4

可以试试 mina , Ruby 的 Gem

2年前 评论
maliao

请问下,envoy是怎么登录服务器的,在哪里填写key?

2个月前 评论
ziyanziyu

@maliao 配置本地的.ssh/config

2个月前 评论

@maliao 使用envoy的前提是本地机对目标机已实现密钥验证方式登录。
假设目标服务器是lala@192.168.20.20,那先得通过命令ssh-copy-id lala@192.168.20.20将密钥发送到目标机进行验证(过程中会要求输入目标用户的密码),验证成功后能通过ssh lala@192.168.20.20不用输密码即可直接登录目标机才算完成这一前提。

2个月前 评论

请勿发布不友善或者负能量的内容。与人为善,比聪明更重要!

社区文档:

将托管在 packagist.org 和 github.com 的扩展包使用国内 CDN 加速
GitHub Laravel 扩展包 TOP 250
速查表方便快速查询框架功能,支持手机访问,支持中英文版本
Laravel 中文文档,由社区用户翻译和维护,将会保持一直更新
此文档的目的,就是为了提高技术团队的凝聚力、一致性和生产效率。
开发环境的部署,开发者工具的选择,适用于 Mac 和 Windows。
浓缩过后的精华
Laravel Nova 后台管理面板文档的中文翻译
Lumen 中文文档,由社区用户翻译和维护,将会保持一直更新
Laravel 下知名扩展包 Dingo API 的中文文档,Laravel API 开发必知必会