- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
concurrent = 3
[[runners]]
..
executor = "shell"
和
concurrent = 3
[[runners]]
...
executor = "shell"
[[runners]]
...
executor = "shell"
[[runners]]
...
executor = "shell"
在全局并发= 3
的单个运行器上有3个相同类型的执行器(workers
)?或者具有全局 concurrent = 3
的单个执行器可以安全地并行执行多个作业吗?
runners.limit
与 runners.request_concurrency
和 concurrent
谢谢
最佳答案
Gitlab's documentation on runners describes them as:
(...) isolated (virtual) machines that pick up jobs through the coordinator API of GitLab CI
因此,每个运行程序都是一个独立的进程,负责拾取作业执行请求并根据预定义的配置处理它们。作为一个独立的进程,每个运行器都能够创建“子进程”(也称为机器)来运行作业。
当您在 config.toml
中定义 [[runner]]
section 时,您正在配置一个运行器并设置它如何处理作业执行请求。在您的问题中,您提到了其中两个“如何处理作业执行请求”设置:
limit
:“限制可以同时处理的作业数量”。换句话说,运行程序可以创建多少个“子进程”以便同时执行作业;request_concurrency
:“限制来自 GitLab 的新作业的并发请求数量”。换句话说,运行程序可以同时从 GitLab CI 作业队列中获取多少个作业执行请求。此外,还有一些settings that apply to a machine globally 。在您的问题中您提到了其中之一:
并发
:“限制全局可以同时运行的作业数量。这是使用所有定义的运行器的作业数量的最大上限”。换句话说,它限制了可以同时运行作业的“子进程”的最大数量。因此,请记住运行程序及其子流程之间的差异以及特定运行程序设置和全局机器设置之间的差异:
不同之处在于,在您的第一个示例中,您有一个运行者,而在您的第二个示例中,您有三个运行者强>。值得一提的是,在这两个示例中,您的机器仅允许同时运行 3 个作业。
单个运行器不仅可以安全地同时运行多个作业,而且还可以控制您希望它处理的作业数量(使用前面提到的限制
设置)。
此外,在同一台机器上运行类似的运行者也没有问题。如何定义运行器的配置取决于您和您的基础设施能力。
另外,请注意 an executor
仅定义如何运行您的工作。它不是定义运行者的唯一事物,也不是“ worker ”的同义词。起作用的是您的运行者及其子流程。
总结一下:您可以在同一台机器上定义一个或多个工作人员。每个过程都是一个孤立的过程。运行程序的限制
是运行程序进程可以创建多少个子进程来同时运行作业。运行程序的 request_concurrency
是运行程序可以处理来自 Gitlab CI 作业队列的请求数量。最后,将值设置为“并发”将限制机器中运行的一个或多个运行程序可以同时在机器上执行的作业数量。
为了更好地理解,我强烈建议您阅读 Autoscaling algorithm and parameters 。
最后,我想您可能会发现这个关于如何 run runners in parallel on the same server 的问题有用。
关于gitlab - gitlab runner 并发如何工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54534387/
我有一些关于 Gitlab Server 和 Gitlab Runner 的问题。 必须安装 GitLab Runner 才能执行 CI/CD 部署吗? 必须为 GitLab Runner 安装 Gi
我正在docker上运行gitlab/gitlab-ce容器。然后,在其中,我想通过提供docker作为运行器来运行gitlab-runner服务。而我运行的每个命令(例如docker ps,dock
刚刚在全新的高性能服务器上安装了全新的 6.8 Gitlab。 在考虑忘记我的存储库历史记录(评论、问题等...)之前,有人知道一种将存储库数据从 Gitlab 服务器导出到另一个 Gitlab 服务
我读了这篇比较 https://about.gitlab.com/pricing/self-managed/feature-comparison/在 Gitlab 上,很多事情还不清楚。我想问一下在某
我的配置文件: external_url "http://192.168.3.23" # note the use of a dotted ip gitlab_rails['gitlab_email
GitLab 支持多种 Push Options .有什么方法可以在 Web 用户界面或其他方式中检查管道或作业中使用了哪些推送选项?特别是,哪些 ci.variable 推送选项与作业或管道相关联?
所以,我试图在子目录上安装 gitlab。许多在线文章都表明现在可以这样做。 我安装了 omnibus-gitlab,但它似乎不包含使 gitlab 在 application.rb 等子目录中运行所
我当前的设置是我有一个安装了 gitlab (gitlabVM) 的 Ubuntu VM。 Gitlab 通过 8888 端口在 nginx 上运行 我的路由器配置如下: 外部 4322 -> git
我最近通过 Gitlab 更新了,但是备份文件是旧版本,新版本不兼容。所以我想将 Gitlab 回滚到以前的版本。怎么做? 最佳答案 GitLab 升级过程应该升级数据库(并且其他文件应该兼容)。 但
我在不同的网络上有两个单独的 git-lab 实例。我可以为他们每个人使用相同的运行者吗?假设,两个 git-lab 实例都可以访问带有运行器的服务器。是否可以为我的两个 git-lab 实例使用一个
我刚刚将我们的存储库从 github 转换为内部 gitlab。我首先获得了一个裸本地存储库,并且已经能够将一个新的 master 引入 gitlab。 在我的本地存储库中, git tag 显示了我
我看过这个:`git clone project2` in gitlab-ci.yml?以及一堆类似答案的类似帖子,暗示应该使用 Git 子模块。 如果不讨论 Git 中的子模块是否运行良好的争论,就
谁能帮我在 git lab 中自动生成发行说明。有什么方法可以执行此操作。 请让我知道。 谢谢 最佳答案 您可以使用 API 列出里程碑中的所有问题,请参阅 https://docs.gitlab.c
GitLab为与特定项目合作的“团队成员”提供项目访问级别“ guest ”,“报告者”,“开发者”和“大师”。 “主人”和“客人”是不言自明的,但是其他人对我的范围和粒度并不十分清楚。这些级别之间有
我已经在 CentOS 6.6 上安装了 Gitlab Omnibus gitlab-7.4.3_omnibus.5.1.0.ci-1.el6.x86_64.rpm。我创建了一些项目并且运行良好,但我
我想知道在 2GB 内存和 2 个处理核心的情况下,GitLab 中允许的存储库和用户数量是否有上限。 最佳答案 这主要在GitLab requirements中指定。文档(如 CPU section
我很长一段时间都是 Bitbucket 的重度用户,但由于 GL 拥有先进的强大功能,我转向了 GitLab。 但是 Bitbucket 有一个令人惊叹的功能,我在 GitLab 中找不到……“下载”
在 GitLab 中,“聊天”选项卡始终显示没有事件用户: 如何启用它? 最佳答案 几年前,Gitlab 收购了一家公司,该公司生产 Slack 替代聊天系统,名为 Mattermost。您的 Git
在我的项目设置中我看到: 可用于任何项目的公共(public)部署 key (15) Rewind CFMM Ansible Deployment LRM Puppet Test gitlab-run
当我尝试创建 new project 时在 GitLab使用模板我提供了三个选项 * Ruby on Rails * Spring * NodeJSExpress 除了现有模板之外,是否可以添加自定义
我是一名优秀的程序员,十分优秀!