IT Administrators use RStudio Package Manager to control and manage R and Python packages that Data Scientists need to create and share data products.
This chart is "beta" quality. It will likely undergo breaking changes without warning as it moves towards stability.
As a result, please:
- Ensure you "pin" the version of the Helm chart that you are using. You can do
this using the
helm dependency
command and the associated "Chart.lock" files or the--version
flag. IMPORTANT: This protects you from breaking changes - Before upgrading, to avoid breaking changes, use
helm diff upgrade
to check for breaking changes - Pay close attention to
NEWS.md
for updates on breaking changes, as well as documentation below on how to use the chart
To install the chart with the release name my-release
at version 0.3.3:
helm repo add rstudio https://helm.rstudio.com
helm install my-release rstudio/rstudio-pm --version=0.3.3
This chart requires the following in order to function:
- A license key, license file, or address of a running license server. See the
license
configuration below. - A Kubernetes PersistentVolume that contains the data directory for RSPM.
- If
sharedStorage.create
is set, a PVC that relies on the default storage class will be created to generate the PersistentVolume. Most Kubernetes environments do not have a default storage class that you can use withReadWriteMany
access mode out-of-the-box. In this case, we recommend you disablesharedStorage.create
and create your ownPersistentVolume
andPersistentVolumeClaim
, then mount them into the container by specifying thepod.volumes
andpod.volumeMounts
parameters, or by specifying yourPersistentVolumeClaim
usingsharedStorage.name
andsharedStorage.mount
. - If you cannot use a
PersistentVolume
to properly mount your data directory, you'll need to mount your data in the container by using a regular Kubernetes Volume, specified inpod.volumes
andpod.volumeMounts
. - Alternatively, S3 storage can be used. See the next section for details.
- If
Package Manager can be configured to store data in S3 buckets (see the Admin Guide
for more details). When configured this way, AWS access credentials are required. You must set the awsAccessKeyId
and awsSecretAccessKey
chart values
to ensure that RSPM will be able to authenticate with your configured S3 buckets.
Configuring Package Manager to use S3 requires modifying the .gfcg
configuration file as explained below. A sample chart values configuration might look like the following:
awsAccessKeyId: your-access-key-id
awsSecretAccessKey: your-secret-access-key
config:
Storage:
Default: s3
S3Storage:
Bucket: your-s3-bucket
- In most places, we opt to pass helm values over configmaps. We translate these into the valid
.gcfg
file format required by rstudio-pm.
The configuration values all take the form of usual helm values so you can set the database password with something like:
... --set config.Postgres.Password=mypassword ...
The Helm config
values are converted into the rstudio-pm.gcfg
service configuration file via go-templating.
Key | Type | Default | Description |
---|---|---|---|
args | bool | false |
args is the pod's run arguments. By default, it uses the container's default |
awsAccessKeyId | bool | false |
awsAccessKeyId is the access key id for s3 access, used also to gate file creation |
awsSecretAccessKey | string | nil |
awsSecretAccessKey is the secret access key, needs to be filled if access_key_id is |
command | bool | false |
command is the pod's run command. By default, it uses the container's default |
config | object | {"HTTP":{"Listen":":4242"},"Launcher":{"AdminGroup":"root","ServerUser":"root"},"Metrics":{"Enabled":true}} |
config is a nested map of maps that generates the rstudio-pm.gcfg file |
extraObjects | list | [] |
Extra objects to deploy (value evaluated as a template) |
fullnameOverride | string | "" |
the full name of the release (can be overridden) |
image.imagePullPolicy | string | "IfNotPresent" |
the imagePullPolicy for the main pod image |
image.imagePullSecrets | list | [] |
an array of kubernetes secrets for pulling the main pod image from private registries |
image.repository | string | "rstudio/rstudio-package-manager" |
the repository to use for the main pod image |
image.tag | string | "" |
the tag to use for the main pod image |
ingress.annotations | object | {} |
|
ingress.enabled | bool | false |
|
ingress.hosts | string | nil |
|
ingress.ingressClassName | string | "" |
The ingressClassName for the ingress resource. Only used for clusters that support networking.k8s.io/v1 Ingress resources |
ingress.tls | list | [] |
|
initContainers | bool | false |
the initContainer spec that will be used verbatim |
license.file | object | {"contents":false,"mountPath":"/etc/rstudio-licensing","mountSubPath":false,"secret":false,"secretKey":"license.lic"} |
the file section is used for licensing with a license file |
license.file.contents | bool | false |
contents is an in-line license file |
license.file.mountPath | string | "/etc/rstudio-licensing" |
mountPath is the place the license file will be mounted into the container |
license.file.mountSubPath | bool | false |
mountSubPath is whether to mount the subPath for the file secret. -- It can be preferable not to enable this, because then updates propagate automatically |
license.file.secret | bool | false |
secret is an existing secret with a license file in it |
license.file.secretKey | string | "license.lic" |
secretKey is the key for the secret to use for the license file |
license.key | string | nil |
key is the license to use |
license.server | bool | false |
server is the : for a license server |
livenessProbe | object | {"enabled":false,"failureThreshold":10,"httpGet":{"path":"/__ping__","port":4242},"initialDelaySeconds":10,"periodSeconds":5,"timeoutSeconds":2} |
livenessProbe is used to configure the container's livenessProbe |
nameOverride | string | "" |
the name of the chart deployment (can be overridden) |
pod.annotations | object | {} |
annotations is a map of keys / values that will be added as annotations to the pods |
pod.env | list | [] |
env is an array of maps that is injected as-is into the "env:" component of the pod.container spec |
pod.serviceAccountName | bool | false |
serviceAccountName is a string representing the service account of the pod spec |
pod.volumeMounts | list | [] |
volumeMounts is an array of maps that is injected as-is into the "volumeMounts" component of the pod spec |
pod.volumes | list | [] |
volumes is an array of maps that is injected as-is into the "volumes:" component of the pod spec |
readinessProbe | object | {"enabled":true,"failureThreshold":3,"httpGet":{"path":"/__ping__","port":4242},"initialDelaySeconds":3,"periodSeconds":3,"successThreshold":1,"timeoutSeconds":1} |
readinessProbe is used to configure the container's readinessProbe |
replicas | int | 1 |
replicas is the number of replica pods to maintain for this service |
resources | object | {"limits":{"cpu":"2000m","enabled":false,"ephemeralStorage":"200Mi","memory":"4Gi"},"requests":{"cpu":"100m","enabled":false,"ephemeralStorage":"100Mi","memory":"2Gi"}} |
resources define requests and limits for the rstudio-pm pod |
rstudioPMKey | bool | false |
rstudioPMKey is the rstudio-pm key used for the RStudio Package Manager service |
service.annotations | object | {} |
Annotations for the service, for example to specify an internal load balancer |
service.clusterIP | string | "" |
The cluster-internal IP to use with service.type ClusterIP |
service.loadBalancerIP | string | "" |
The external IP to use with service.type LoadBalancer, when supported by the cloud provider |
service.nodePort | bool | false |
The explicit nodePort to use for service.type NodePort. If not provided, Kubernetes will choose one automatically |
service.port | int | 80 |
The Service port. This is the port your service will run under. |
service.type | string | "ClusterIP" |
The service type, usually ClusterIP (in-cluster only) or LoadBalancer (to expose the service using your cloud provider's load balancer) |
serviceMonitor.additionalLabels | object | {} |
additionalLabels normally includes the release name of the Prometheus Operator |
serviceMonitor.enabled | bool | false |
Whether to create a ServiceMonitor CRD for use with a Prometheus Operator |
serviceMonitor.namespace | string | "" |
Namespace to create the ServiceMonitor in (usually the same as the one in which the Operator is running). Defaults to the release namespace |
sharedStorage.accessModes | list | ["ReadWriteMany"] |
accessModes defined for the storage PVC (represented as YAML) |
sharedStorage.create | bool | false |
whether to create the persistentVolumeClaim for shared storage |
sharedStorage.mount | bool | false |
Whether the persistentVolumeClaim should be mounted (even if not created) |
sharedStorage.name | string | "" |
The name of the pvc. By default, computes a value from the release name |
sharedStorage.path | string | "/var/lib/rstudio-pm" |
the path to mount the sharedStorage claim within the pod |
sharedStorage.requests.storage | string | "10Gi" |
the volume of storage to request for this persistent volume claim |
sharedStorage.storageClassName | bool | false |
storageClassName - the type of storage to use. Must allow ReadWriteMany |
startupProbe | object | {"enabled":false,"failureThreshold":30,"httpGet":{"path":"/__ping__","port":4242},"initialDelaySeconds":10,"periodSeconds":10,"timeoutSeconds":1} |
startupProbe is used to configure the container's startupProbe |
startupProbe.failureThreshold | int | 30 |
failureThreshold * periodSeconds should be strictly > worst case startup time |
strategy.rollingUpdate.maxSurge | string | "100%" |
|
strategy.rollingUpdate.maxUnavailable | int | 0 |
|
strategy.type | string | "RollingUpdate" |
|
versionOverride | string | "" |
A Package Manager version to override the "tag" for the RStudio Package Manager image. Necessary until helm/helm#8194 |
Autogenerated from chart metadata using helm-docs v1.5.0