【高可用架构】借助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)目前 ...
随机推荐
- GUI编程(Tkinter) 笔记分享
Python GUI编程(Tkinter) Python 提供了多个图形开发界面的库,几个常用 Python GUI 库如下: Tkinter: Tkinter 模块(Tk 接口)是 Python 的 ...
- SVM详细笔记及总结
本文精品,如有疑问欢迎留言or微信咨询:523331232
- 机器学习 AI 谷歌ML Kit 与苹果Core ML
概述 移动端所说的AI,通常是指"机器学习". 定义:机器学习其实就是研究计算机怎样模拟人类的学习行为,以获取新的知识或技能,并重新组织已有的知识结构使之不断改善自身.从实践的意义 ...
- Python监控SQL Server数据库服务器磁盘使用情况
本篇博客总结一下Python采集SQL Server数据库服务器的磁盘使用信息,其实这里也是根据需求不断推进演化的一个历程,我们监控服务器的磁盘走了大概这样一个历程: 1:使用SQL Server作业 ...
- git 命令归纳版
1.克隆: 单纯的克隆名字: git clone [url] 自定义新建项目名称: git clone [url] [项目名字] 2.跟踪文件: git add [文件名] 3.添加忽略文件 ...
- 参观路线——并查集+dfs
题目描述 Lambdaland由N个城市组成,任两个城市间都有一条道路相连. 下个月TBL准备参观Lambdaland.他将从城市1开始,以深度优先搜索顺序参观能所有遍历到的城市. 由于TBL是一位 ...
- 「Luogu 1525」关押罪犯
更好的阅读体验 Portal Portal1: Luogu Portal2: LibreOJ Description \(S\)城现有两座监狱,一共关押着\(N\)名罪犯,编号分别为\(1 - N\) ...
- flask-sqlalchemy 迁移数据(生成数据库表)与 查询数据
1, 生成表 db.Model主要用于数据库的增删改查操作, 构建表交给db.Table完成 安装 pip install flask-migrate from datetime import dat ...
- C#/.Net开发入门篇(1)——开发工具安装
众所周知,工欲善其事必先利其器,要想砍柴快一定得有把好刀,那么要想代码写的有效率.质量高一个趁手的编辑器是必不可少的,写代码不可能就用系统自带的文本编辑器(如果是大佬当我没说),这里我推荐各位使用微软 ...
- 学习下ElasticSearch
ElasticSearch基础概念 Elasticsearch的Head插件安装 Elasticsearch在Centos 7上的安装常见的问题 使用场景:比如分库的情况下,你想统计所有数据的报表,就 ...