helm-charts/pypiserver/README.md

86 lines
7.2 KiB
Markdown
Raw Normal View History

2021-01-17 01:09:41 +00:00
# PyPi Sever Helm Chart
This chart installs a PyPI server
## Prerequisites Details
- Kubernetes 1.6+
- PV dynamic provisioning support on the underlying infrastructure
## Todo
- Document a setup using a `ReadWriteMany` storage that is resilient and scallable.
- Maybe use part of pypicloud in order to use S3 or GCS backend storage.
## Adding the repo
To add the repo to helm with the name `owkin`:
```bash
$ helm repo add owkin https://owkin.github.io/charts
```
## Installing the Chart
To install the chart with the release name `my-release`:
```bash
$ helm install --name my-release owkin/pypiserver
```
## Upgrading the Charts
Updating the chart is as straightforward as updating the helm release
```bash
$ helm upgrade my-release owkin/pypiserver
```
## Configuration
The following tables lists the configurable parameters of the PyPI server chart and their default values.
| Parameter | Description | Default |
| ---------------------------------- | ---------------------------------------------------------------------------------------- | ----------------------- |
| `replicaCount` | Deployment replica count | `1` |
| `image.repository` | Container image repository | `pypiserver/pypiserver` |
| `image.tag` | Container image name | `v1.3.2` |
| `image.pullPolicy` | Container pull policy | `IfNotPresent` |
| `image.pullSecrets` | Container pull secrets | `[]` |
| `pypiserver.extraArgs` | Additional arguments (beside -P, -p, -a) to be passed to the underyling pypiserver image | `[]` |
| `auth.actions` | Actions requiring authentication (comma separated list) | `update` |
| `auth.credentials` | Map of username / encoded password to write in a htpasswd file | `{}` |
| `ingress.enabled` | Ingress configuration flag | `false` |
| `ingress.labels` | Ingress labels | `{}` |
| `ingress.annotations` | Ingress annotations | `{}` |
| `ingress.path` | Ingress path | `nil` |
| `ingress.hosts` | Ingress hosts | `nil` |
| `ingress.tls` | Ingress TLS configuration | `[]` |
| `service.type` | Service type | `ClusterIP` |
| `service.port` | Service port | `8080` |
| `service.annotations` | Service annotations | `{}` |
| `service.labels` | Service labels | `{}` |
| `service.clusterIP` | Service cluster IP | `""` |
| `service.externalIPs` | Service external IPs | `[]` |
| `service.loadBalancerIP` | Service load balancer IP | `""` |
| `service.loadBalancerSourceRanges` | Service load balancer CIDR ranges | `[]` |
| `service.nodePort` | Service node port | `nil` |
| `persistence.enabled` | Persistence configuration flag | `false` |
| `persistence.storageClass` | Persistence storage class | `nil` |
| `persistence.existingClaim` | Persistent volume claim static name | `nil` |
| `persistence.accessMode` | Persistence access mode | `ReadWriteOnce` |
| `persistence.size` | Persistence volume size | `5Gi` |
| `persistence.mountPropagation` | Mount propagation method | `nil` |
| `securityContext.enabled` | Security context configuration flag | `true` |
| `securityContext.runAsUser` | User ID to run as | `0` |
| `securityContext.runAsGroup` | Group ID to run as | `0` |
| `securityContext.fsGroup` | Filesystem volume owner | `1000` |
| `resources` | Resources configuration bloc | `{}` |
| `nodeSelector` | Node selector of the deployment | `{}` |
| `tolerations` | Tolerations configuration for the deployment | `[]` |
| `affinity` | Affinity of the deployment | `{}` |
| `podLabels` | Extra labels applied to the pod | `{}` |
| `podAnnotations` | Extra annotations applied to the pod | `{}` |
Specify each parameter using the `--set key=value[,key=value]` argument to `helm install`.