GitLab artifacts(流水线产物)使用对象储存 S3(MinIO)
文档
- 作业产物管理
- 作业产物迁移 Rake 任务
说明
GitLab使用的版本是17.9.1S3对象储存使用的是MinIO2025-02-28T09-55-16Z
配置
-
配置前准备
示例 说明 bucket_name gitlab-artifacts Buckets 名称,单独一个 access_key_id gitlab-access-id-xxx 秘钥ID secret_access_key gitlab-secret-key-xxx 秘钥凭证 endpoint http://minio.example.com:9000 MinIO(S3)API 地址(非网页地址) -
修改配置
vim /etc/gitlab/gitlab.rb找到 gitlab_rails[‘artifacts_object_store_enabled’] 附近,修改为下列示例
# gitlab_rails['artifacts_enabled'] = true # gitlab_rails['artifacts_path'] = "/var/opt/gitlab/gitlab-rails/shared/artifacts" # 上传 artifacts 开启对象存储 gitlab_rails['artifacts_object_store_enabled'] = true # 代理访问(隐藏 S3 地址) gitlab_rails['artifacts_object_store_proxy_download'] = true # 对象储存保存的 bucket_name gitlab_rails['artifacts_object_store_remote_directory'] = "gitlab-artifacts" gitlab_rails['artifacts_object_store_connection'] = { # MinIO(S3)无需修改 'provider' => 'AWS', # MinIO(S3)无需修改 'region' => 'eu-west-1', # MinIO(S3)凭证ID 'aws_access_key_id' => 'gitlab-access-id-xxx', # MinIO(S3)凭证秘钥 'aws_secret_access_key' => 'gitlab-secret-key-xxx', # MinIO(S3)API 地址(非网页地址) # 其中 minio.example.com:9000 就是 URL 拼接的 host 'endpoint' => 'http://minio.example.com:9000', # URL 拼接方式 # true:host/bucket_name/object,如:http://minio.example.com:9000/gitlab-artifacts/object # false:bucket_name.host/object,如:http://gitlab-artifacts.minio.example.com:9000/object 'path_style' => true } -
重新配置
sudo gitlab-ctl reconfigure -
执行流水线并上传产物文件测试
- 查看是否上传成功
- 查看对象储存中是否存新增了这个产物文件
-
迁移历史文件(可选)
# 将本地的文件迁移到 S3 中 sudo gitlab-rake gitlab:artifacts:migrate # 将 S3 中的文件迁移到本地文件中 sudo gitlab-rake gitlab:artifacts:migrate_to_local