【高可用架构】借助Envoy工具发布项目到多台服务器
前言
在上一篇,我们已经成功在开发机上部署了Deploy项目,下面我们继续在开发机上安装Envoy
两台应用服务器的IP
192.168.10.12
192.168.10.18
【高可用架构】系列链接:待部署的架构介绍
演示
安装envoy
全局安装envoy,你也可以安装在当前项目下
composer global require laravel/envoy
在项目的根目录下创建Envoy.blade.php文件,首先我们先来测试一下Envoy是否可以正常工作
# vi Envoy.blade.php
@servers(['app-1' => 'root@192.168.10.12', 'app-2' => 'root@192.168.10.18']) # 定义多个APP服务器
@task('deploy', ['on' => ['app-1', 'app-2']])
cd /var/www #项目所在地
ls -la
@endtask
运行Envoy
envoy run deploy

发现没有envoy命令,这主要是开发机没有配置composer环境变量,大家如果按照【Linux系统】来部署环境,就不会出现这个问题。
设置composer环境变量
# vi ~/.bashrc
PATH=$PATH:/root/.config/composer/vendor/bin
保存后,执行source ~/.bashrc,使其生效
再执行envoy命令

执行成功,可以正常访问两台APP服务器,中途可能需要输入密码,先正常输入,我们后面去解决。
部署项目
在部署项目之前,修改下.gitignore文件
.env #这行去掉
添加初始化任务
# vi Envoy.blade.php
@task('init', ['on' => ['app-1', 'app-2']])
mkdir -p /var/www/ #统一项目地址
cd /var/www/
git clone git@github.com:SexyPhoenix/Deploy.git #部署的github项目,在github项目中复制链接
cd Deploy
composer install --no-dev
chmod -R 0777 storage
@endtask
执行任务
envoy run init
运行成功
更新项目
在开发机上修改Deploy/resources/views/welcome.blade.php文件84行
服务器IP:{{ $server_ip }}
提交修改
git add .
git commit -m 'fix IP name'
git push
修改deploy任务
# vi Envoy.blade.php
@task('deploy', ['on' => ['app-1', 'app-2']])
cd /var/www/Deploy
git pull origin master
@endtask
执行任务
envoy run deploy
两台APP服务器更新成功

免密码登录
在执行任务的时候总是要求输入密码,现在来解决一下这个问题
在开发机上执行下面命令
ssh-copy-id -i ~/.ssh/id_rsa.pub root@192.168.10.18 # 这里只有18机要求密码
这个原理就是将开发机上的公钥注册到18机的authorized_keys里面
【高可用架构】借助Envoy工具发布项目到多台服务器的更多相关文章
- Docker Kubernetes 高可用架构设计
Docker Kubernetes 高可用架构设计 官方方案:保证master端不发生单点故障. 官方使用一台Load Balancer负载均衡代理3台master端,终端与etcd与work Nod ...
- 【高可用架构】开发机上部署Deploy项目(一)
准备 部署项目的细节可以看这个,传送门Centos 7部署Laravel项目 主机IP:192.168.10.17 [高可用架构]系列链接:待部署的架构介绍 演示 部署Deploy composer ...
- 【高可用架构】用Nginx实现负载均衡(三)
前言 在上一篇,已经用Envoy工具统一发布了Deploy项目代码.本篇我们来看看如何用nginx实现负载均衡 负载均衡器IP 192.168.10.11 [高可用架构]系列链接:待部署的架构介绍 演 ...
- [置顶]
来自 Google 的高可用架构理念与实践
转自: https://mp.weixin.qq.com/s?__biz=MzAwMDU1MTE1OQ==&mid=402738153&idx=1&sn=af5e76aad ...
- MySQL 高可用架构之MMM
简介 MMM(Master-Master replication manager for MySQL)是一套支持双主故障切换和双主日常管理的脚本程序.MMM使用Perl语言开发,主要用来监控和管理My ...
- 【转】单表60亿记录等大数据场景的MySQL优化和运维之道 | 高可用架构
此文是根据杨尚刚在[QCON高可用架构群]中,针对MySQL在单表海量记录等场景下,业界广泛关注的MySQL问题的经验分享整理而成,转发请注明出处. 杨尚刚,美图公司数据库高级DBA,负责美图后端数据 ...
- 【亲述】Uber容错设计与多机房容灾方案 - 高可用架构系列
此文是根据赵磊在[QCON高可用架构群]中的分享内容整理而成.转载请事先联系赵磊及相关编辑. 赵磊,Uber高级工程师,08年上海交通大学毕业,曾就职于微软,后加入Facebook主要负责Messen ...
- [转载] 单表60亿记录等大数据场景的MySQL优化和运维之道 | 高可用架构
原文: http://mp.weixin.qq.com/s?__biz=MzAwMDU1MTE1OQ==&mid=209406532&idx=1&sn=2e9b0cc02bdd ...
- (转)MySQL高可用架构之MHA
MySQL高可用架构之MHA 原文:http://www.cnblogs.com/gomysql/p/3675429.html 简介: MHA(Master High Availability)目前 ...
随机推荐
- python中基本运算符
基本运算符 a // b 取整 a % b 取余 a ** b a 的b次方 a == b 判断运算符左右两边值是否相等 a != b 判断运算符左右两边值是否不等 a > b a >= ...
- Rust入坑指南:有条不紊
随着我们的坑越来越多,越来越大,我们必须要对各种坑进行管理了.Rust为我们提供了一套坑务管理系统,方便大家有条不紊的寻找.管理.填埋自己的各种坑. Rust提供给我们一些管理代码的特性: Packa ...
- SpringBootCLI 命令行工具
Spring Boot CLI 是用于快速开发 Spring 应用的命令行工具.用来运行 Groovy (与 Java 风格类似)脚本. spring-cli 似乎不是可以各种diy spring-b ...
- Azure上MySQL的离线备份:将备份拷贝到Azure Blob上
公司在Azure的Iaas虚拟机上部署有好几台MySQL数据库,至于没有选择Azure Database for MySQL,是因为预算有限(钱不够啊!说多了也是泪,坑的还是DBA自己).选择了Iaa ...
- 学习笔记52_mongodb增删改查
使用use db1作为当前数据库 如果没有db1,会自动创建 使用switch db2,当前数据库切换为db2 使用show dbs,显示当前所有数据库 使用show collection ,显示当前 ...
- Django学习day5——创建app
app应用与project项目的区别 一个app实现某个功能,比如博客.公共档案数据库或者简单的投票系统 一个project是配置文件和多个app的集合,这些app组合成整个站点 一个project可 ...
- [转载]2.9 UiPath中断活动Continue的介绍和使用
一.Continue的介绍 跳过当前For Each 循环内的迭代, 结束本次循环,Continue控件只能用于For Each循环中 二.Continue在UiPath中结合For Each循环的使 ...
- layui多级弹框去掉遮罩
var index = layer.open({ type:1, title:'请选择费用代码', area:['1050px','650px'], content:$('#selectFee'), ...
- python内置模块collections介绍
目录 python内置模块collections介绍 1.namedtuple 2.deque 3.defaultdict 4.OrderedDict 5.ChainMap 6.Counter 7.小 ...
- centos6的JDK安装
1. 通过如下命令查看当前操作系统是否存在JDK rpm -qa | grep java 如果出现以下内容说明你的操作系统存在jdk 2.那么依次通过如下命令进行删除它 rpm -e - -nodep ...