使用 Git 管理自动化部署
自动化部署是指使用专门的软件工具或脚本来自动执行软件安装与发布过程。它提高了软件交付的速度和可靠性,减少过程中的错误。
Websoft9 遵循 GitOps 思想,使用 Git 管理自动化部署代码。这样使得部署过程更加透明、可追溯、协作和安全,同时提供了强大的工具来支持自动化和集成,这对于现代软件开发和运维实践至关重要。
使用 Git 带来的好处
使用 Git 管理部署代码,通常称为基础设施即代码,Infrastructure as Code,它带来的好处显而易见:
-
版本控制:Git 强大的版本控制能力允许你跟踪和记录部署代码的每一次更改。
-
团队协作:Git 支持多个开发者协同工作,通过分支、请求、审查管理部署代码,从而提高代码质量并减少部署错误。
-
回滚能力:如果新的部署代码引入了问题,Git 允许你轻松地回滚到之前的状态。这种快速回滚能 力在生产环境中至关重要。
-
自动化和集成:Git 可以与持续集成/持续部署(CI/CD)工具链紧密集成,实现自动触发流程,加速整个软件交付。
-
审计和合规:Git 提供了一个不可变的历史记录,满足审计要求和合规性检查。
-
一致性和标准化:使用 Git 确保所有环境(开发、测试、生产)使用相同的部署代码,减少环境之间的差异带来的问题。
-
安全性:Git 仓库可以配置访问控制和权限,防止在服务器上未授权的更改导致的风险操作。
总结来说,使用 Git 管理自部署代码 vs 在服务器直接管理部署代码,前者无疑是更科学的选择。
内置 Gitea 作为 Git 管理工具
Websoft9 控制台集成 Gitea 作为 Git 自动化部署代码的存储平台,并 100% 保持其原生性。
Gitea 是一个开源的自托管Git服务,它是用 Go 语言编写的。它旨在提供一个简单、轻量级和可扩展的方式来设置你自己的 Git 服务。它提供了一个简洁的用户界面,使得用户可以轻松地浏览仓库、提交、分支和更多功能。
Git 部署的工作流程
Websoft9 使用 Git 部署逻辑实际上非常简单,它只有四个步骤:
-
准备好 云服务器
-
准备好 Docker 镜像或源码包等 待部署的软件包
-
增加一个 Git 仓库,仓库主要用于存放安装、编排和配置的自动化部署代码
-
主动或触发式将仓库代码推送到云服务器上执行,开始自动部署
自动创建 Git 仓库
当用户通过 Websoft9 应用商店部署应用时,会为每个应用创建包含自动化部署代码的 Git 仓库。
手动创建 Git 仓库以存储软件包
Gitea 支持用户手工创建仓库:
-
登录 Websoft9 控制台,点击左侧 "仓库" 菜单,进入仓库功能页面
-
点击仓库页面的右上角 "+",创建一个仓库
-
仓库创建页面中,两个需要重点注意的设置项
- 拥有者:建议选择自行增加的仓库用户
- 可见性:私有或公有
-
确认设置项无误后,点击 "创建仓库"
-
根据需求,选择一种软件包的上传或同步方式:
- 仓库的界面中上传文件或压缩包
- 使用 git 客户 端,同步软件源码到远程仓库
-
获取软件包等下载地址或 git clone 地址,用于自动化部署代码中
增加 Git 用户
Git 仓库默认用户 websoft9
主要用于模板化自动部署,故建议增加新的 Git 用户,以用于其他部署场景
-
登录 Websoft9 控制台,进入仓库管理界面
-
在仓库管理界面中,点击左侧 "个人信息与设置" 菜单,进入 管理后台 设置界面
-
依次打开:"身份及认证" > "账户管理" 页面,创建新账号
管理 Git 仓库
Gitea 对仓库提供了全面的操作,包括:设置公开或私有、授权用户访问、Issue 管理、分支管理等
修改和还原 Git 仓库的文件
编辑和修改 Git 仓库的文件,是 Websoft9 持续部署的关键因素,常见的操作有:
- 修改文件内容
- 上传文件
- 获取下载地址
- 还原历史文件
下面介绍通过 Gitea 编辑和复原历史文件的通用步骤:
-
登录 Websoft9 控制台,进入仓库管理界面
-
在仓库列表页面,打开一个所需修改的仓库
-
点击进入任何一个文件详情,便可以对它进行增删改查等操作、
-
进入文件的历史版本,可以方便的进行还原操作
相关参考
- Gitea 官方文档
- gitops.tech
- A beginner's guide to GitOps and how it works- GitLab
- What is GitOps - Red Hat
- Is GitOps the next big thing in DevOps? - Atlassian
- What is GitOps: The Beginner's Guide - Splunk
- What is GitOps? - DigitalOcean
问题与故障
无法连接到 Gitea?
- 删除 Gitea 默认的邮件地址后,会导致 Websoft9 控制台无法自动集成 Gitea,从而不能使用
- 修改默认用户或密码,会导致 Websoft9 控制台无法自动集成 Gitea,从而不能使用