1
0
mirror of https://github.com/woodpecker-ci/woodpecker.git synced 2025-01-11 17:18:09 +02:00

Support for k8s serviceAccount and nodeSelector (#1842)

Add the possiblity to specify the Kubernetes serviceAccount and/or
nodeSelector to be used on individual steps for Kubernetes executor
This commit is contained in:
Ovidiu Calbajos 2023-06-12 17:00:59 +03:00 committed by GitHub
parent b5b3b95721
commit 609ba481b5
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 58 additions and 8 deletions

View File

@ -40,9 +40,23 @@ Additional labels to apply to worker pods. Must be a YAML object, e.g. `{"exampl
Additional annotations to apply to worker pods. Must be a YAML object, e.g. `{"example.com/test-annotation":"test-value"}`. Additional annotations to apply to worker pods. Must be a YAML object, e.g. `{"example.com/test-annotation":"test-value"}`.
## Resources ## Job specific configuration
### Resources
The kubernetes backend also allows for specifying requests and limits on a per-step basic, most commonly for CPU and memory. The kubernetes backend also allows for specifying requests and limits on a per-step basic, most commonly for CPU and memory.
See the [kubernetes documentation](https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/) for more information on using resources.
### serviceAccountName
Specify the name of the ServiceAccount which the build pod will mount. This serviceAccount must be created externally.
See the [kubernetes documentation](https://kubernetes.io/docs/concepts/security/service-accounts/) for more information on using serviceAccounts.
### nodeSelector
Specify the label which is used to select the node where the job should be executed. Labels defined here will be appended to a list already containing "kubernetes.io/arch".
By default the pod will use "kubernetes.io/arch" inferred from top-level "platform" setting which is deducted from the agents' environment variable CI_SYSTEM_ARCH. To overwrite this, you need to specify this label in the nodeSelector section.
See the [kubernetes documentation](https://kubernetes.io/docs/concepts/scheduling-eviction/assign-pod-node/#nodeselector) for more information on using nodeSelector.
Example pipeline configuration: Example pipeline configuration:
```yaml ```yaml
@ -55,12 +69,13 @@ steps:
- go test - go test
backend_options: backend_options:
kubernetes: kubernetes:
serviceAccountName: 'my-service-account'
resources: resources:
requests: requests:
memory: 128Mi memory: 128Mi
cpu: 1000m cpu: 1000m
limits: limits:
memory: 256Mi memory: 256Mi
nodeSelector:
beta.kubernetes.io/instance-type: p3.8xlarge
``` ```
See the [kubernetes documentation](https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/) for more information on using resources.

View File

@ -80,6 +80,11 @@ func Pod(namespace string, step *types.Step, labels, annotations map[string]stri
} }
} }
var ServiceAccountName string
if step.BackendOptions.Kubernetes.ServiceAccountName != "" {
ServiceAccountName = step.BackendOptions.Kubernetes.ServiceAccountName
}
podName, err := dnsName(step.Name) podName, err := dnsName(step.Name)
if err != nil { if err != nil {
return nil, err return nil, err
@ -97,6 +102,10 @@ func Pod(namespace string, step *types.Step, labels, annotations map[string]stri
NodeSelector := map[string]string{"kubernetes.io/arch": strings.Split(platform, "/")[1]} NodeSelector := map[string]string{"kubernetes.io/arch": strings.Split(platform, "/")[1]}
for key, val := range step.BackendOptions.Kubernetes.NodeSelector {
NodeSelector[key] = val
}
pod := &v1.Pod{ pod := &v1.Pod{
ObjectMeta: metav1.ObjectMeta{ ObjectMeta: metav1.ObjectMeta{
Name: podName, Name: podName,
@ -105,9 +114,10 @@ func Pod(namespace string, step *types.Step, labels, annotations map[string]stri
Annotations: annotations, Annotations: annotations,
}, },
Spec: v1.PodSpec{ Spec: v1.PodSpec{
RestartPolicy: v1.RestartPolicyNever, RestartPolicy: v1.RestartPolicyNever,
HostAliases: hostAliases, HostAliases: hostAliases,
NodeSelector: NodeSelector, NodeSelector: NodeSelector,
ServiceAccountName: ServiceAccountName,
Containers: []v1.Container{{ Containers: []v1.Container{{
Name: podName, Name: podName,
Image: step.Image, Image: step.Image,

View File

@ -2,7 +2,9 @@ package types
// KubernetesBackendOptions defines all the advanced options for the kubernetes backend // KubernetesBackendOptions defines all the advanced options for the kubernetes backend
type KubernetesBackendOptions struct { type KubernetesBackendOptions struct {
Resources Resources `json:"resouces,omitempty"` Resources Resources `json:"resouces,omitempty"`
ServiceAccountName string `json:"serviceAccountName,omitempty"`
NodeSelector map[string]string `json:"nodeSelector,omitempty"`
} }
// Resources defines two maps for kubernetes resource definitions // Resources defines two maps for kubernetes resource definitions

View File

@ -116,6 +116,8 @@ func (c *Compiler) createProcess(name string, container *yaml_types.Container, s
Limits: container.BackendOptions.Kubernetes.Resources.Limits, Limits: container.BackendOptions.Kubernetes.Resources.Limits,
Requests: container.BackendOptions.Kubernetes.Resources.Requests, Requests: container.BackendOptions.Kubernetes.Resources.Requests,
}, },
ServiceAccountName: container.BackendOptions.Kubernetes.ServiceAccountName,
NodeSelector: container.BackendOptions.Kubernetes.NodeSelector,
}, },
} }

View File

@ -20,7 +20,9 @@ type BackendOptions struct {
} }
type KubernetesBackendOptions struct { type KubernetesBackendOptions struct {
Resources Resources `yaml:"resources,omitempty"` Resources Resources `yaml:"resources,omitempty"`
ServiceAccountName string `yaml:"serviceAccountName,omitempty"`
NodeSelector map[string]string `yaml:"nodeSelector,omitempty"`
} }
type Resources struct { type Resources struct {

View File

@ -521,6 +521,25 @@
"type": "string" "type": "string"
} }
}, },
"step_backend_kubernetes_service_account": {
"description": "serviceAccountName to be use by job. Read more: https://woodpecker-ci.org/docs/administration/backends/kubernetes",
"type": "object",
"properties": {
"requests": {
"$ref": "#/definitions/step_kubernetes_service_account_object"
},
"limits": {
"$ref": "#/definitions/step_kubernetes_service_account_object"
}
}
},
"step_kubernetes_service_account_object": {
"description": "A list of kubernetes resource mappings",
"type": "object",
"additionalProperties": {
"type": "string"
}
},
"services": { "services": {
"description": "Read more: https://woodpecker-ci.org/docs/usage/services", "description": "Read more: https://woodpecker-ci.org/docs/usage/services",
"type": "object", "type": "object",