在软件开发过程中,自动化构建和分发是提高效率和确保软件质量的关键环节。GitLab CI/CD提供了一个强大的平台,允许开发者在代码提交后自动执行一系列任务,如构建、测试、打包和部署。
一:准备GitLab仓库
首先,你需要在GitLab上创建一个新的仓库,用于存放你的应用程序代码、依赖文件以及CI/CD配置文件。
- 登录GitLab,点击"New project"创建一个新项目。
- 填写项目名称、描述和可见性设置,然后点击"Create project"。
二:准备应用程序文件
在你的GitLab仓库中,准备一个目录(如myapp
),用于存放你的应用程序文件、库文件、配置文件等。同时,创建一个install.sh
脚本,该脚本将包含解压后需要执行的安装命令。
install.sh
脚本示例:
bash
#!/bin/bash
# 安装脚本
echo "开始安装 MyApp..."
mkdir -p /opt/myapp
cp -r * /opt/myapp/
# 如果需要,设置可执行文件权限
# chmod +x /opt/myapp/your-executable
# 添加环境变量(可选)
echo 'export PATH="/opt/myapp/bin:$PATH"' >> /etc/profile.d/myapp.sh
echo "MyApp已安装到/opt/myapp"
echo "安装完成!"
确保install.sh
脚本具有执行权限:
bash
chmod +x install.sh
三:编写.gitlab-ci.yml文件
在GitLab仓库的根目录下,创建一个名为.gitlab-ci.yml
的文件,该文件定义了CI/CD的流水线。
.gitlab-ci.yml
文件示例:
yaml
stages:
- build
build_run_package:
stage: build
image: ubuntu:latest
script:
- apt-get update && apt-get install -y wget
# 下载并安装Makeself(这里假设下载最新版本,实际使用时请替换为具体版本)
- wget https://github.com/megastep/makeself/releases/download/latest/makeself-latest.run
- chmod +x makeself-latest.run
- ./makeself-latest.run --skip-install # 注意:--skip-install 可能不是所有版本都支持,根据实际情况调整
- mv makeself.sh /usr/local/bin/makeself
# 打包成.run文件
- mkdir build
- /usr/local/bin/makeself ./myapp build/myapp.run "MyApp Installer" ./myapp/install.sh
artifacts:
paths:
- build/myapp.run
expire_in: 1 week
注意:--skip-install
选项在某些版本的Makeself中可能不可用。如果不可用,你可能需要直接运行./makeself-latest.run
来安装Makeself,并在之后的命令中使用makeself
而不是/usr/local/bin/makeself
(如果它已被添加到PATH中)。
四:提交代码并触发CI/CD
- 将你的应用程序文件、
install.sh
脚本和.gitlab-ci.yml
文件提交到GitLab仓库。 - 推送这些更改到你的GitLab仓库的远程分支(通常是
main
或master
)。
GitLab将自动检测到新的提交,并触发CI/CD流水线。你可以在GitLab仓库的"CI/CD">"Pipelines"页面查看流水线的状态和结果。
五:下载和使用.run安装包
当CI/CD流水线成功完成后,你可以在流水线的"Jobs"页面中找到构建详情,并下载生成的myapp.run
文件。将该文件复制到目标系统上,并执行以下命令进行安装:
bash
chmod +x myapp.run
./myapp.run
按照提示完成安装过程。