利用php + Laravel如何实现部署自动化详解
前言本文主要给大家介绍了关于利用php + Laravel如何实现部署自动化的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。 所谓自动化部署, 我的理解就是在用户保证代码质量的前提下,将代码能够快速的自动部署到目标服务器上的一种手段. 实现原理本地推送代码 -> 代码库 -> webhook 通知服务端 -> 自动拉取代码库代码 生成并且部署公钥具体步骤参照 1) 生成公钥2) 在 coding 中添加公钥输出部署公玥 在git 管理端部分部署公钥 3) 配置 config 文件编辑 ~/.ssh/config 文件 4) 测试是否可以链接到 git@git.coding.net 服务器 RSA key fingerprint is 98:ab:2b:30:60:00:82:86:bb:85:db:87:22:c4:4f:b1.
Are you sure you want to continue connecting (yes/no)? 这里我们根据提示输入 yesWarning: Permanently added 'git.coding.net,123.59.85.184' (RSA) to the list of known hosts. Coding 提示: Hello duoli,You've connected to Coding.net via SSH. This is a deploy key. duoli,你好,你已经通过 SSH 协议认证 Coding.net 服务,这是一个部署公钥 设置 webhook让代码库接收到通知的时候通知服务端接收代码更新. 这种 webhook 的方式来接收可以部署的请求,这里的请求使用的是 post 方法 php 接收部署因为 php 脚本代码执行的时候会可能有服务的中断(例如执行时间),不一定符合实际,所以计划使用脚本来调用. 收到请求 -> 存入队列 -> 脚本监听处理队列 由于使用 laravel 框架,收到通知之后,存入队列,因为队列使用的是命令行监听,所以命令行执行的时候不会出现中断情况. 在此之前需要配置运行代码的用户有权限能够访问到 git 的服务器. 也就是如果你的代码以 www-data 运行,需要使用 www-data 的角色来访问 git@git.coding.net 服务器. 否则也不能实现部署,原因是 密钥不符合而无权限获取内容. 1) 队列代码 设置 app/Jobsuse IlluminateContractsBusSelfHandling;
use IlluminateContractsQueueShouldQueue; use SymfonyComponentProcessProcess; class WebDeploy extends Job implements SelfHandling,ShouldQueue private $shellPath; /**
/**
2) 触发队列3) 部署 shell 脚本/dev/null 2>&1
if [ $? -eq 0 ];then
echo "OK"
else
/usr/bin/git fetch -f
/usr/bin/git reset --hard
/usr/bin/git pull origin ${branch}
fi
4) 使用supervisor 来监听队列执行,监听队列任务文件位置 /etc/supervisord.d/project.ini 注意要点 之前和同事研究自动化部署花费很长时间,对于PHP能否胜任这个功能还是存在一点疑惑的,之前在局域网进行部署的时候能够实现代码的部署,但是在其余时间测试的时候则均是失败. 本次换了这种方式找到了一种方式来运行脚本. 理论上不会存在执行不成功的时候,直到看到了如下的报错: /webdata/www/sour-lemon.com
ERR > Could not create directory '/usr/share/httpd/.ssh'.
ERR > Host key verification failed.
ERR > fatal: Could not read from remote repository. Please make sure you have the correct access rights and the repository exists.
因为当前 shell 运行的用户是 apache,所以在调用的时候会以 apache 的身份去调用这个请求,故而出现了 Could not create directory '/usr/share/httpd/.ssh',所以就考虑用 apache 权限去设置 ssh 的自动化部署. 由于 apache 用户是处于不允许登陆状态,需要首先允许其登录,然后再设置相应的 ssh key. 更改文件 /etc/passwd 允许用户登录 然后再切换到 apache 用户来进行 ssh key 设定,这样经过测试,通过. 总结以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对编程之家的支持。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |