聊聊怎么用GitHub Actions自动部署Laravel项目

聊聊怎么用GitHub Actions自动部署Laravel项目

怎么用GitHub Actions自动部署Laravel项目?在本文中,我将逐步介绍如何在 VPS 上免费自动部署您的 Laravel 应用程序。

场景设置…#

我是一个部署在 VPS 上的 Laravel 项目的小团队的一员。我们的每个团队成员都将从事一项特定的任务,当它准备好投入生产时,总是需要有人访问服务器来部署正在推送到我们的 GitHub Repo 的每个更改。

这对我们所有人来说都是一项非常重复和令人不快的任务,需要在我们的规模和预算范围内找到解决方案,这就是我们求助于强大的 Github Actions 来自动化我们的工作流程的时候。

让我们深入了解我们的工作流程设置指南的简化版本。

假设#

在本指南中,我假设您检查了以下几点。

你有一个配置好的 Linux 服务器,它能够运行 Laravel 应用程序,并且上面安装了 Git。

你有一个 Laravel 应用程序 Github 存储库。你可以按照我上一篇文章的前 2 部分在这里 free-serverless-laravel-deployment。

这个怎么运作#

在典型的工作流程中,开发人员将为给定任务创建一个新分支,并向 main/master 分支发出拉取请求,或自行在 main/master 分支上进行更改 (不可取) 并推送。

pull request 和 push 都是我们可以通过 Github Actions 订阅的给定分支上的事件。因此,我们可以定义一组指令,当给定事件在我们的仓库上发生时应该执行这些指令。这些指令可能正在运行我们的 TestsBuilds, 和 Deployments

创建部署脚本

我们要做的第一件事是创建一个部署脚本,其中包含部署和运行我们的应用程序所需的所有命令。

在应用程序的根目录中创建一个名为 .scripts 的文件夹。

在 .scripts 目录中创建一个名为 deploy.sh 的文件,其内容如下。

#!/bin/bashset -eecho "Deployment started ..."# Enter maintenance mode or return true# if already is in maintenance mode(php artisan down) || true# Pull the latest version of the appgit pull origin production# Install composer dependenciescomposer install --no-dev --no-interaction --prefer-dist --optimize-autoloader# Clear the old cachephp artisan clear-compiled# Recreate cachephp artisan optimize# Compile npm assetsnpm run prod# Run database migrationsphp artisan migrate --force# Exit maintenance modephp artisan upecho "Deployment finished!"

请参阅脚本的注释以了解我们在每一行上所做的事情。

创建工作流

Github 操作工作流是一组指令,其中包含可以在我们上面提到的事件上触发的不同任务作业和步骤。

仓库的工作流存储在应用程序根目录的 .github/workflows 中。

在 .github/workflows 文件夹中创建一个名为 deploy.yml 的文件,其中包含以下内容。

name: Deploy# Trigger the workflow on push and # pull request events on the production branchon:  push:    branches:      - production  pull_request:    branches:      - production# Authenticate to the the server via ssh # and run our deployment script jobs:  deploy:    runs-on: ubuntu-latest    steps:      - uses: actions/checkout@v2      - name: Deploy to server        uses: appleboy/ssh-action@master        with:          host: ${{ secrets.HOST }}          username: ${{ secrets.USERNAME }}          port: ${{ secrets.PORT }}          key: ${{ secrets.SSHKEY }}          script: "cd /var/www/html && ./.scripts/deploy.sh"

提交新创建的文件

现在我们已经为我们的自动化创建了所有必要的文件,让我们使用以下命令提交它们。

$ git add deploy.sh deploy.yml $ git commit -m "Deployment automation"

创建部署分支并推送到 Github

如果您注意到我们的 deploy.sh 和 deploy.yml 文件,我们提到了一个名为 production 的分支。我们将使用此分支添加通过 push 或 pull request 可用于生产的提交。

使用以下 git 命令为您的存储库创建此分支并将它们推送到 GitHub。

$ git checkout -b production $ git push -u origin production

设置 ssh 密钥

是时候在我们的服务器和 Github 之间建立连接了。

为此,我们首先需要在我们的服务器上生成一个新的 ssh 密钥对。

在您的服务器上运行此命令以生成 ssh 密钥。

$ ssh-keygen -t rsa -b 4096 -C "email@example.com"

当提示输入文件名和密码时,只需按 Enter 并接受默认值。

这将在您的根目录 .ssh/ 文件夹中创建 2 个 ssh 密钥,公钥和私钥。

现在使用以下命令将新生成的 ssh 私钥添加到 ssh-agent。

$ eval "$(ssh-agent -s)"$ ssh-add ~/.ssh/id_rsa

让我们使用以下命令将我们的公钥添加到我们服务器上的 authorized_keys 文件中。

$ cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys

复制 ssh 密钥到 Github

我们的上述设置将允许:-

1。 Github Actions 向我们的服务器验证自己并运行我们的 deploy.sh 脚本。

为此,我们必须让 Github 知道如何对我们的服务器进行身份验证。

当我们准备好上面的 ssh 密钥时,它将与服务器的 HOST, ssh PORT, ssh 私钥的 KEY, 以及服务器的 USERNAME 一起提供给 GitHub。

为此,请在浏览器上访问您的 Github 帐户并打开您的仓库。

点击 settings,如下图

Github setting

在侧边栏菜单上单击secrets

GitHub Copilot GitHub Copilot

GitHub AI编程工具,实时编程建议

GitHub Copilot 48 查看详情 GitHub Copilot

github add button

在 Action Secret 页面上,单击 new repository secret。

add button

在new secret页面上,逐个添加以下密钥。

HOST

HOST 是您的服务器 IP 地址,在名称字段中输入 HOST 关键字,在值中输入您的服务器 IP 地址。

PORT

PORT 是您的 ssh 端口。在名称中使用 PORT 关键字并在值中使用 22 以使用默认 ssh 端口。

SSHKEY

SSHKEY 是我们在服务器上生成的私有 ssh 密钥。通常您不会与任何人共享您的私人 ssh 密钥,但由于我们正在进行自动化,因此这是必需的。

使用 SSHKEY 关键字作为名称字段。

要复制您的私钥值,请转到您的服务器并运行以下命令。

$ cat ~/.ssh/id_rsa

这将在您的终端上打印您的私人 ssh 密钥,将其复制并粘贴到值字段中。

USERNAME

最后一个是您要进行身份验证的 USERNAME 。

为此,您可以在服务器上运行 whoami 并获取值。然后在名称字段中使用 USERNAME 关键字并在值中添加过去。

完成后,您的秘密应该看起来像这样

github secrets

2。我们的服务器向 Github 进行身份验证并获取我们存储库中的最新提交。

为了让 Github 允许访问我们的服务器,我们必须提供我们之前生成的 ssh 公钥。

如果我们有多个仓库,我们可以在帐户级别提供公钥,但如果它只是一个仓库,我们可以在仓库中提供它,并且只允许访问我们帐户上的那个仓库。

为此,请再次转到您的仓库设置并单击部署密。

deploy keys

添加部署密钥..

add deploy keys

给它起一个有助于记住服务器的标题,例如 PROD_SERVER

Image description

对于关键字段值,转到您的服务器并使用以下命令打印您的公钥并复制它。

$ cat ~/.ssh/id_rsa.pub

不要检查允许写访问,只需单击添加密钥按钮。

最后一件事是更改我们服务器上的远程源以使用 SSH 而不是 HTTPS 并执行获取以获取服务器上的新提交。

为此,请转到您的 Github 存储库并单击 code 按钮并复制 ssh 选项卡上的链接。

Image description

然后在您的服务器上转到您部署的应用程序目录,最常见的是 /var/html/www 并运行以下命令。

git remote set-url origin git@github.com:USERNAME/REPOSITORY.gitgit fetch

将 URL 替换为您复制的 URL。

好了,我的朋友们,你现在有了 Laravel 应用程序部署自动化。 创建一个测试提交并将其推送到您的 production 分支,以见证奇迹发生。

您可以通过为您的测试构建、暂存环境等添加更多工作流来为它疯狂……

原文地址:https://dev.to/kenean50/automate-your-laravel-app-deployment-with-github-actions-2g7j译文地址:https://learnku.com/laravel/t/69131

【相关推荐:laravel视频教程】

以上就是聊聊怎么用GitHub Actions自动部署Laravel项目的详细内容,更多请关注php中文网其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/624330.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月11日 08:06:33
下一篇 2025年11月11日 08:07:14

相关推荐

  • .NET控制台应用程序开发:不仅仅是“Hello World”

    现代.NET控制台程序可处理文件、调用API、读取配置、执行定时任务,支持命令行参数解析、配置文件管理、日志记录与外部服务调用,结合合理结构可成为高效工具。 很多人接触 .NET 的第一行代码都是从控制台程序的 “Hello World” 开始的。这确实是个不错的起点,但如果…

    2025年12月17日
    000
  • 编写防御性C# XML解析代码 预防常见的注入和格式攻击

    答案:C#处理XML时需禁用DTD和外部实体,防止XXE及Billion Laughs攻击。1. 使用XmlReader并设置DtdProcessing.Prohibit、XmlResolver=null;2. 限制MaxCharactersFromEntities和MaxCharactersInD…

    2025年12月17日
    000
  • .NET怎么在程序中执行一个外部exe文件

    使用System.Diagnostics.Process类可执行外部exe文件,通过Process.Start启动进程,支持简单调用和ProcessStartInfo配置参数、工作目录、窗口行为及输出重定向,需注意路径、权限和异常处理。 在 .NET 程序中执行外部 exe 文件,最常用的方式是使用…

    2025年12月17日
    000
  • .NET怎么将字节数组(byte[])和字符串相互转换_字节数组字符串互转技巧

    答案是:在.NET中,字符串与字节数组互转需选择合适编码,推荐UTF-8;文本转换使用Encoding.UTF8.GetBytes()和GetString(),非文本数据应通过Convert.ToBase64String()和FromBase64String()进行安全转换,避免乱码或数据丢失。 在…

    2025年12月17日
    000
  • .NET怎么将一个匿名对象转换为强类型对象

    答案:匿名对象无法直接转换为强类型,但可通过反射、序列化或第三方库实现属性映射。使用反射可遍历属性并复制值,适用于通用场景;JSON序列化通过序列化再反序列化实现,代码简洁但需类型兼容;高性能需求可选AutoMapper或表达式树缓存优化性能。 在 .NET 中,匿名对象本身是编译时生成的内部类,无…

    2025年12月17日
    000
  • .NET Web API如何使用Swagger生成API文档

    在 .NET Web API 中集成 Swagger 可自动生成可交互的 API 文档。首先通过 NuGet 安装 Swashbuckle.AspNetCore 包,然后在 Program.cs 中添加 AddEndpointsApiExplorer() 和 AddSwaggerGen() 服务,并…

    2025年12月17日
    000
  • .NET Web API如何进行模型验证

    在 .NET Web API 中,模型验证通过数据注解和 ModelState 实现,1. 使用 Required、StringLength 等特性标注模型属性;2. 框架在绑定后自动验证并填充 ModelState;3. 在 Action 中通过 ModelState.IsValid 判断结果,失…

    2025年12月17日
    000
  • Z在c语言中表示的数值 大写Z在c语言中的ASCII码值

    大写字母z在c语言中的ascii码值是90。了解ascii码值对编程重要,因为它帮助理解字符的底层表示,并在排序、比较、转换等操作中发挥作用。 大写字母Z在C语言中的ASCII码值是90。 现在,让我们深入探讨一下在C语言中如何使用ASCII码值,以及为什么了解ASCII码值对编程来说非常重要。 在…

    2025年12月17日
    000
  • 在c语言中怎么用 换行符 在c语言中的使用场景

    在 c 语言中, 用于创建新行,广泛应用于格式化输出和文件处理。1) 格式化输出:如打印日志和生成报告。2) 文件处理:如读取csv文件。3) 跨平台开发需注意不同系统对换行符的处理。 在 C 语言中,换行符 是一个非常常见且重要的字符,它用于在输出时创建新行。简单来说, 告诉编译器在输出时跳到下一…

    2025年12月17日
    000
  • .NET的AssemblyVersionCompatibility枚举如何设置兼容性?

    AssemblyVersionCompatibility枚举定义CLR处理程序集版本兼容性的策略,其值如MayChangeMinorVersions要求主版本匹配且次版本可升级,SameMajorVersion允许主版本相同下的任意次版本、内部版本和修订号,SameVersion则要求完全匹配,而S…

    2025年12月17日
    000
  • php与c语言有什么联系和区别?

    php与c语言之间有什么联系和区别?下面本篇文章就给大家简单介绍一下php与c语言之间联系和区别,希望对你们有所帮助。 php与c语言之间的联系 PHP语言的内核就是C语言写成的,其语法大量借鉴C语言、Java和Perl的语法。 php与c语言之间的区别 下面给大家介绍php与c语言之间的一些区别:…

    2025年12月17日
    000
  • c语言之后学什么?

    有朋友在学完c语言后困惑之后该怎么办?小编想说其实只要你c语言基础打得好,学习其他语言都不是事儿,主要看你未来想从事哪方面的工作,下面我将就每几个领域和大家说说,以后可以学哪些。 想未来从事嵌入式开发的,可以学习ARM嵌入式等; 想未来从事软件、游戏开发的,也可以学习C++、openGL等; 想未来…

    2025年12月17日
    000
  • RSS订阅中的作者信息格式

    RSS和Atom中作者信息通过或标签标识,包含姓名、邮箱及网站链接,支持多作者;正确设置有助于提升内容可信度、便于追踪与SEO。 RSS订阅中的作者信息格式,主要用于标识文章的作者,让读者知道是谁写的,方便追踪特定作者的内容。格式通常包含作者姓名、邮箱,有时还会包含作者的网站链接。 作者信息的常见格…

    2025年12月17日
    000
  • 如何优化XML网络传输

    优化XML网络传输需从压缩、结构精简和协议升级入手。首先,Gzip压缩可减少60%-80%数据量;其次,简化标签名、去除冗余命名空间与空白字符能降低XML“体重”;再者,采用SAX或XMLPullParser流式解析替代DOM,可显著提升大文件处理效率;同时,预编译XPath/XSLT、缓存解析结果…

    2025年12月17日
    000
  • RSS订阅如何过滤重复内容

    RSS去重核心是利用guid、link或内容哈希识别唯一性,结合已处理记录实现过滤。主流阅读器如Inoreader和Feedly通过后端比对guid/link进行自动去重;自建方案可用Python脚本解析RSS并以数据库存储条目标识,通过定时任务抓取新内容并生成去重后的输出流。 RSS订阅中遇到重复…

    2025年12月17日
    000
  • 如何实现XML数据脱敏

    XML数据脱敏需先识别敏感信息,再结合业务需求选择替换、掩码、删除或加密等策略,利用XPath精准定位,并通过DOM、SAX或XSLT技术实现,同时兼顾结构复杂性、性能、数据一致性与合规性要求。 实现XML数据脱敏,核心在于精准识别XML文档中的敏感信息,并根据业务需求和合规性要求,运用合适的脱敏策…

    2025年12月17日
    000
  • XML格式的地理信息系统标准

    GML是GIS数据互操作的核心标准,作为OGC定义的XML编码框架,它通过标准化的Schema实现地理要素的结构化描述与跨系统交换,在WFS服务中充当数据传输“桥梁”,支持复杂语义与拓扑关系表达;尽管因冗余性导致性能开销大,面临GeoJSON等轻量格式挑战,但在政府数据共享、专业领域及长期归档中仍具…

    2025年12月17日
    000
  • XML模式演化兼容性处理

    XML模式演化兼容性需在结构变化时确保新旧代码互操作,通过默认值、忽略未知元素、版本控制、转换层等策略实现平滑过渡。 XML模式演化兼容性处理,说白了,就是当你的XML结构发生变化时,如何保证旧的代码还能正常工作,或者说至少不崩溃。这可不是一件简单的事情,因为XML的灵活性也带来了复杂性。 XML模…

    2025年12月17日
    000
  • 如何用XSL-FO格式化XML输出

    XSL-FO通过XSLT将XML转换为布局描述文件,再经FO处理器生成PDF等固定格式,实现数据与表现分离,适用于高精度、复杂排版的文档自动化。 用XSL-FO格式化XML输出,本质上并不是直接“格式化”XML本身,而是将XML数据作为输入,通过一个转换过程,生成一个描述了最终文档布局和内容的中间格…

    2025年12月17日
    000
  • XML中如何使用正则解析XML_XML使用正则解析XML的技巧与方法

    不建议用正则解析XML因其难以处理嵌套结构、属性变化和上下文相关语法,易出错;仅在结构简单、格式固定时可临时使用正则快速提取数据,如日志中的特定标签内容。 用正则表达式解析XML并不是推荐的做法,因为XML具有复杂的嵌套结构和语法规则,而正则在处理嵌套、命名空间、属性变化等方面容易出错。但如果你面对…

    2025年12月17日
    000

发表回复

登录后才能评论
关注微信