【高可用架构】借助Envoy工具发布项目到多台服务器(二)
程序员文章站
2023-03-26 20:18:19
前言 在上一篇,我们已经成功在开发机上部署了Deploy项目,下面我们继续在开发机上安装Envoy 两台应用服务器的IP 192.168.10.12 192.168.10.18 【高可用架构】系列链接: "待部署的架构介绍" 演示 安装envoy 全局安装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里面
上一篇: 分布式事物之综合案例分析
下一篇: 学习重构(5)-简化条件表达式