- Requirements
- Design Choices
- Configuration
- Installation command line options
- Chart configuration examples
- Using the Community Edition of this chart
- External Services
Using the GitLab-Migrations chart
The migrations
sub-chart provides a single migration Job that handles seeding/migrating the GitLab database. The chart runs using the GitLab Rails codebase.
After migrating, this Job also edits the application settings in the database to turn off writes to authorized keys file. In the charts we are only supporting use of the GitLab Authorized Keys API with the SSH AuthorizedKeysCommand
instead of support for writing to an authorized keys file.
Requirements
This chart depends on Redis, and PostgreSQL, either as part of the complete GitLab chart or provided as external services reachable from the Kubernetes cluster this chart is deployed onto.
Design Choices
The migrations
creates a new migrations Job each time the chart is deployed. In order to prevent job name collisions, we append the chart revision, and a random alpha-numeric value to the Job name each time is created. The purpose of the random text is described further in this section.
For now we also have the jobs remain as objects in the cluster after they complete. This is so we can observe the migration logs. Currently this means these Jobs persist even after a helm uninstall
. This is one of the reasons why we append random text to the Job name, so that future deployments using the same release name don’t cause conflicts. Once we have some form of log-shipping in place, we can revisit the persistence of these objects.
The container used in this chart has some additional optimizations that we are not currently using in this Chart. Mainly the ability to quickly skip running migrations if they are already up to date, without needing to boot up the rails application to check. This optimization requires us to persist the migration status. Which we are not doing with this chart at the moment. In the future we will introduce storage support for the migrations status to this chart.
Configuration
The migrations
chart is configured in two parts: external services, and chart settings.
Installation command line options
Table below contains all the possible charts configurations that can be supplied to helm install
command using the --set
flags
Parameter | Description | Default |
---|---|---|
common.labels
| Supplemental labels that are applied to all objects created by this chart. | {}
|
image.repository
| Migrations image repository | registry.gitlab.com/gitlab-org/build/cng/gitlab-toolbox-ee
|
image.tag
| Migrations image tag | |
image.pullPolicy
| Migrations pull policy | Always
|
image.pullSecrets
| Secrets for the image repository | |
init.image.repository
| initContainer image repository | registry.gitlab.com/gitlab-org/build/cng/gitlab-base
|
init.image.tag
| initContainer image tag | master
|
init.image.containerSecurityContext
| init container securityContext overrides | {}
|
enabled
| Migrations enable flag | true
|
tolerations
| Toleration labels for pod assignment | []
|
affinity
| Affinity rules for pod assignment | {}
|
annotations
| Annotations for the job spec | {}
|
podAnnotations
| Annotations for the pob spec | {}
|
podLabels
| Supplemental Pod labels. Will not be used for selectors. | |
redis.serviceName
| Redis service name | redis
|
psql.serviceName
| Name of Service providing PostgreSQL | release-postgresql
|
psql.password.secret
| psql secret | gitlab-postgres
|
psql.password.key
| key to psql password in psql secret | psql-password
|
psql.port
| Set PostgreSQL server port. Takes precedence over global.psql.port
| |
resources.requests.cpu
| GitLab Migrations minimum CPU | 250m
|
resources.requests.memory
| GitLab Migrations minimum memory | 200Mi
|
securityContext.fsGroup
| Group ID under which the pod should be started | 1000
|
securityContext.runAsUser
| User ID under which the pod should be started | 1000
|
securityContext.fsGroupChangePolicy
| Policy for changing ownership and permission of the volume (requires Kubernetes 1.23) | |
containerSecurityContext.runAsUser
| Override container securityContext under which the container is started | 1000
|
serviceAccount.annotations
| ServiceAccount annotations | {}
|
serviceAccount.automountServiceAccountToken
| Indicates whether or not the default ServiceAccount access token should be mounted in pods | false
|
serviceAccount.create
| Indicates whether or not a ServiceAccount should be created | false
|
serviceAccount.enabled
| Indicates whether or not to use a ServiceAccount | false
|
serviceAccount.name
| Name of the ServiceAccount. If not set, the full chart name is used | |
extraInitContainers
| List of extra init containers to include | |
extraContainers
| List of extra containers to include | |
extraVolumes
| List of extra volumes to create | |
extraVolumeMounts
| List of extra volumes mounts to do | |
extraEnv
| List of extra environment variables to expose | |
extraEnvFrom
| List of extra environment variables from other data sources to expose | |
bootsnap.enabled
| Enable the Bootsnap cache for Rails | true
|
priorityClassName
| Priority class assigned to pods. |
Chart configuration examples
extraEnv
extraEnv
allows you to expose additional environment variables in all containers in the pods.
Below is an example use of extraEnv
:
extraEnv:
SOME_KEY: some_value
SOME_OTHER_KEY: some_other_value
When the container is started, you can confirm that the environment variables are exposed:
env | grep SOME
SOME_KEY=some_value
SOME_OTHER_KEY=some_other_value
extraEnvFrom
extraEnvFrom
allows you to expose additional environment variables from other data sources in all containers in the pods.
Below is an example use of extraEnvFrom
:
extraEnvFrom:
MY_NODE_NAME:
fieldRef:
fieldPath: spec.nodeName
MY_CPU_REQUEST:
resourceFieldRef:
containerName: test-container
resource: requests.cpu
SECRET_THING:
secretKeyRef:
name: special-secret
key: special_token
# optional: boolean
CONFIG_STRING:
configMapKeyRef:
name: useful-config
key: some-string
# optional: boolean
image.pullSecrets
pullSecrets
allow you to authenticate to a private registry to pull images for a pod.
Additional details about private registries and their authentication methods can be found in the Kubernetes documentation.
Below is an example use of pullSecrets
:
image:
repository: my.migrations.repository
pullPolicy: Always
pullSecrets:
- name: my-secret-name
- name: my-secondary-secret-name
serviceAccount
This section controls if a ServiceAccount should be created and if the default access token should be mounted in pods.
Name | Type | Default | Description |
---|---|---|---|
annotations
| Map | {}
| ServiceAccount annotations. |
automountServiceAccountToken
| Boolean | false
| Controls if the default ServiceAccount access token should be mounted in pods. You should not enable this unless it is required by certain sidecars to work properly (for example, Istio). |
create
| Boolean | false
| Indicates whether or not a ServiceAccount should be created. |
enabled
| Boolean | false
| Indicates whether or not to use a ServiceAccount. |
name
| String | Name of the ServiceAccount. If not set, the full chart name is used. |
affinity
For more information, see affinity
.
Using the Community Edition of this chart
By default, the Helm charts use the Enterprise Edition of GitLab. If desired, you can instead use the Community Edition. Learn more about the difference between the two.
In order to use the Community Edition, set image.repository
to registry.gitlab.com/gitlab-org/build/cng/gitlab-toolbox-ce
External Services
Redis
redis:
host: redis.example.com
serviceName: redis
port: 6379
sentinels:
- host: sentinel1.example.com
port: 26379
password:
secret: gitlab-redis
key: redis-password
host
The hostname of the Redis server with the database to use. This can be omitted in lieu of serviceName
. If using Redis Sentinels, the host
attribute needs to be set to the cluster name as specified in the sentinel.conf
.
serviceName
The name of the service
which is operating the Redis database. If this is present, and host
is not, the chart will template the hostname of the service (and current .Release.Name
) in place of the host
value. This is convenient when using Redis as a part of the overall GitLab chart. This will default to redis
port
The port on which to connect to the Redis server. Defaults to 6379
.
password
The password
attribute for Redis has two sub keys:
-
secret
defines the name of the KubernetesSecret
to pull from -
key
defines the name of the key in the above secret that contains the password.
sentinels
The sentinels
attribute allows for a connection to a Redis HA cluster.
The sub keys describe each Sentinel connection.
-
host
defines the hostname for the Sentinel service -
port
defines the port number to reach the Sentinel service, defaults to26379
Note: The current Redis Sentinel support only supports Sentinels that have
been deployed separately from the GitLab chart. As a result, the Redis
deployment through the GitLab chart should be disabled with redis.install=false
.
The Secret containing the Redis password will need to be manually created
before deploying the GitLab chart.
PostgreSQL
psql:
host: psql.example.com
serviceName: pgbouncer
port: 5432
database: gitlabhq_production
username: gitlab
preparedStatements: false
password:
secret: gitlab-postgres
key: psql-password
host
The hostname of the PostgreSQL server with the database to use. This can be omitted if postgresql.install=true
(default non-production).
serviceName
The name of the service which is operating the PostgreSQL database. If this is present, and host
is not, the chart will template the hostname of the service in place of the host
value.
port
The port on which to connect to the PostgreSQL server. Defaults to 5432
.
database
The name of the database to use on the PostgreSQL server. This defaults to gitlabhq_production
.
preparedStatements
If prepared statements should be used when communicating with the PostgreSQL server. Defaults to false
.
username
The username with which to authenticate to the database. This defaults to gitlab
password
The password
attribute for PostgreSQL has to sub keys:
-
secret
defines the name of the KubernetesSecret
to pull from -
key
defines the name of the key in the above secret that contains the password.