测试自动化,持续集成和连续交付在社区中很普遍。这使多种服务试图使过程更加愉快,并且对于开发人员来说是压倒性的,因此他们可以专注于交付软件,而不是构建/配置工具来实现这一目标。这些服务之一是SmaphoreCi。 >在本文中,我们将介绍如何使用我们自己的部署脚本和工具在成功测试后继续部署过程。
>
演示应用程序
我们将使用500px应用程序,该应用程序从市场上加载照片。它是使用Laravel构建的,您可以在此处阅读有关其建筑过程的完整文章,并在Github上找到仓库。
>要配置部署策略,我们需要转到项目页面,然后单击设置部署。
<span><span><?php </span></span><span> </span><span><span>require_once "recipe/common.php"; </span></span><span> </span><span><span>set('ssh_type', 'native'); </span></span><span><span>set('default_stage', 'staging'); </span></span><span><span>env('deploy_path', '/var/www'); </span></span><span><span>env('composer_options', 'install --no-dev --prefer-dist --optimize-autoloader --no-progress --no-interaction'); </span></span><span><span>set('copy_dirs', [ </span></span><span> <span>'app/commands', </span></span><span> <span>'app/config', </span></span><span> <span>'app/controllers', </span></span><span> <span>'app/database', </span></span><span> <span>'app/lang', </span></span><span> <span>'app/models', </span></span><span> <span>'app/src', </span></span><span> <span>'app/start', </span></span><span> <span>'app/tests', </span></span><span> <span>'app/views', </span></span><span> <span>'app/filters.php', </span></span><span> <span>'app/routes.php', </span></span><span> <span>'bootstrap', </span></span><span> <span>'public', </span></span><span> <span>'composer.json', </span></span><span> <span>'composer.lock', </span></span><span> <span>'artisan', </span></span><span> <span>'.env', </span></span><span><span>]); </span></span><span> </span><span><span>set('shared_dirs', [ </span></span><span> <span>'app/storage/cache', </span></span><span> <span>'app/storage/logs', </span></span><span> <span>'app/storage/meta', </span></span><span> <span>'app/storage/sessions', </span></span><span> <span>'app/storage/views', </span></span><span><span>]); </span></span><span><span>set('writable_dirs', get('shared_dirs')); </span></span><span><span>set('http_user', 'www-data'); </span></span><span> </span><span><span>server('digitalocean', '174.138.78.215') </span></span><span> <span>->identityFile() </span></span><span> <span>->user('root') </span></span><span> <span>->stage('staging'); </span></span><span> </span><span><span>task('deploy:upload', function() { </span></span><span> <span>$files = get('copy_dirs'); </span></span><span> <span>$releasePath = env('release_path'); </span></span><span> </span><span> <span>foreach ($files as $file) </span></span><span> <span>{ </span></span><span> <span>upload($file, "<span><span>{$releasePath}</span>/<span>{$file}</span>"</span>); </span></span><span> <span>} </span></span><span><span>}); </span></span><span> </span><span><span>task('deploy:staging', [ </span></span><span> <span>'deploy:prepare', </span></span><span> <span>'deploy:release', </span></span><span> <span>'deploy:upload', </span></span><span> <span>'deploy:shared', </span></span><span> <span>'deploy:writable', </span></span><span> <span>'deploy:symlink', </span></span><span> <span>'deploy:vendors', </span></span><span> <span>'current',// print current release number </span></span><span><span>])->desc('Deploy application to staging.'); </span></span><span> </span><span><span>after('deploy:staging', 'success'); </span></span>
选择自动部署后,SmaphoreCi将使我们能够指定部署命令。手动和自动之间的区别在于,在每次成功的测试后都会触发自动部署,而手动将使我们部署任何成功的提交。
>
>我们可以选择将deverer.phar在我们的存储库中作为phar文件包含,也可以使用作曲家要求它。无论哪种方式,这些命令都会相似。
如果我们选择使用SSH部署该应用程序,SmaphoreCi使我们能够将我们的SSH专用密钥存储在其服务器上并在部署阶段提供。
>
键将在〜/.ssh/id_rsa下可用,因此可以将sidentityFile()放在默认值下。>
推动部署
<span><span><?php </span></span><span> </span><span><span>require_once "recipe/common.php"; </span></span><span> </span><span><span>set('ssh_type', 'native'); </span></span><span><span>set('default_stage', 'staging'); </span></span><span><span>env('deploy_path', '/var/www'); </span></span><span><span>env('composer_options', 'install --no-dev --prefer-dist --optimize-autoloader --no-progress --no-interaction'); </span></span><span><span>set('copy_dirs', [ </span></span><span> <span>'app/commands', </span></span><span> <span>'app/config', </span></span><span> <span>'app/controllers', </span></span><span> <span>'app/database', </span></span><span> <span>'app/lang', </span></span><span> <span>'app/models', </span></span><span> <span>'app/src', </span></span><span> <span>'app/start', </span></span><span> <span>'app/tests', </span></span><span> <span>'app/views', </span></span><span> <span>'app/filters.php', </span></span><span> <span>'app/routes.php', </span></span><span> <span>'bootstrap', </span></span><span> <span>'public', </span></span><span> <span>'composer.json', </span></span><span> <span>'composer.lock', </span></span><span> <span>'artisan', </span></span><span> <span>'.env', </span></span><span><span>]); </span></span><span> </span><span><span>set('shared_dirs', [ </span></span><span> <span>'app/storage/cache', </span></span><span> <span>'app/storage/logs', </span></span><span> <span>'app/storage/meta', </span></span><span> <span>'app/storage/sessions', </span></span><span> <span>'app/storage/views', </span></span><span><span>]); </span></span><span><span>set('writable_dirs', get('shared_dirs')); </span></span><span><span>set('http_user', 'www-data'); </span></span><span> </span><span><span>server('digitalocean', '174.138.78.215') </span></span><span> <span>->identityFile() </span></span><span> <span>->user('root') </span></span><span> <span>->stage('staging'); </span></span><span> </span><span><span>task('deploy:upload', function() { </span></span><span> <span>$files = get('copy_dirs'); </span></span><span> <span>$releasePath = env('release_path'); </span></span><span> </span><span> <span>foreach ($files as $file) </span></span><span> <span>{ </span></span><span> <span>upload($file, "<span><span>{$releasePath}</span>/<span>{$file}</span>"</span>); </span></span><span> <span>} </span></span><span><span>}); </span></span><span> </span><span><span>task('deploy:staging', [ </span></span><span> <span>'deploy:prepare', </span></span><span> <span>'deploy:release', </span></span><span> <span>'deploy:upload', </span></span><span> <span>'deploy:shared', </span></span><span> <span>'deploy:writable', </span></span><span> <span>'deploy:symlink', </span></span><span> <span>'deploy:vendors', </span></span><span> <span>'current',// print current release number </span></span><span><span>])->desc('Deploy application to staging.'); </span></span><span> </span><span><span>after('deploy:staging', 'success'); </span></span>
如果出现问题,我们可以单击失败的部署过程,然后查看日志以进一步调查问题。
>由于未启用了MCRypt扩展名,因此上述屏幕截图是失败的提交。
注意:SmaphoreCi提供的另一个整洁的技巧是向构建服务器sshing以查看出了什么问题。
其他部署工具
>我们此处使用的相同过程可以应用于任何其他部署工具。例如,Laravel Envoy可能是这样的配置:
CI/CD工具是开发人员的工作流程的一个很好的改进,当然可以帮助团队将新代码集成到生产系统中。 Semaphoreci是我推荐的绝佳选择,它易于使用界面及其出色的支持。如果您有任何评论或疑问,请在下面发布它们!
>为CI/CD配置Laravel涉及设置您的测试环境,为应用程序编写测试,设置构建过程以及设置部署过程。您可以使用PHPUNIT进行测试,用于管理依赖的作曲家以及Laravel Envoy或Deployer之类的工具以自动化部署任务。您还需要选择一个CI/CD平台,例如Semaphoreci或Gitlab CI/CD,并配置它以运行测试,构建应用程序并部署应用程序。
>
> SemaphoreCi在Laravel部署中的作用是什么?测试和部署Laravel应用程序的过程。您可以在Semaphoreci中设置管道来运行测试,构建应用程序并部署应用程序。 Semaphoreci支持包括PHP和Laravel在内的各种语言和框架,并且它与许多流行的工具(例如Laravel Envoy and Deployer)集成在一起。
>>我可以在同一项目中使用Laravel Envoy和Deployer吗?
是的,您可以在同一项目中同时使用Laravel Envoy和Deployer。但是,通常不必使用这两个工具,因为它们具有类似的目的。您可以选择最适合您需求的一种。如果您喜欢带有刀片语法的更简单的工具,则可以选择Envoy。如果您喜欢一个更高级的工具,并支持许多不同的框架,则可以选择Deployer。以上是如何将Laravel Envoy或Deployer与SmaphoreCi一起使用?的详细内容。更多信息请关注PHP中文网其他相关文章!