0
Fork 0
mirror of https://github.com/verdaccio/verdaccio.git synced 2024-12-16 21:56:25 -05:00
verdaccio/docker-examples/kubernetes-helm-example
Juan Picado 04b19262d0 docs: relocate docker-examples to 5.x (#1990)
* docs: relocate docker-examples to 5.x

* chore: update readme

* chore: remove license

we have already one at root
2021-04-09 17:54:24 +02:00
..
media docs: relocate docker-examples to 5.x (#1990) 2021-04-09 17:54:24 +02:00
README.md docs: relocate docker-examples to 5.x (#1990) 2021-04-09 17:54:24 +02:00

Kubernetes using Helm

Prerequisites

  • Kubernetes cluster running
  • Read Verdaccio Helm readme.

Install Helm

brew install kubernetes-helm

Initialize helm.

➜ helm init --service-account default
Creating /Users/user/.helm
Creating /Users/user/.helm/repository
Creating /Users/user/.helm/repository/cache
Creating /Users/user/.helm/repository/local
Creating /Users/user/.helm/plugins
Creating /Users/user/.helm/starters
Creating /Users/user/.helm/cache/archive
Creating /Users/user/.helm/repository/repositories.yaml
Adding stable repo with URL: https://kubernetes-charts.storage.googleapis.com
Adding local repo with URL: http://127.0.0.1:8879/charts
$HELM_HOME has been configured at /Users/user/.helm.

Tiller (the Helm server-side component) has been installed into your Kubernetes Cluster.

Please note: by default, Tiller is deployed with an insecure 'allow unauthenticated users' policy.
For more information on securing your installation see: https://docs.helm.sh/using_helm/#securing-your-helm-installation
Happy Helming!

Let's update the helm repo

➜ helm repo update
Hang tight while we grab the latest from your chart repositories...
...Skip local chart repository
...Successfully got an update from the "stable" chart repository
Update Complete. ⎈ Happy Helming!⎈

Let's install verdaccio

➜ helm install stable/verdaccio
NAME:   joking-porcupine
LAST DEPLOYED: Tue May  1 17:15:22 2018
NAMESPACE: default
STATUS: DEPLOYED

RESOURCES:
==> v1/Pod(related)
NAME                                         READY  STATUS             RESTARTS  AGE
joking-porcupine-verdaccio-594ff959b4-rr4nq  0/1    ContainerCreating  0         0s

==> v1/ConfigMap
NAME                        DATA  AGE
joking-porcupine-verdaccio  1     0s

==> v1/PersistentVolumeClaim
NAME                        STATUS  VOLUME                                    CAPACITY  ACCESS MODES  STORAGECLASS  AGE
joking-porcupine-verdaccio  Bound   pvc-78008a6a-4d52-11e8-86f2-080027bd643e  8Gi       RWO           standard      0s

==> v1/Service
NAME                        TYPE       CLUSTER-IP      EXTERNAL-IP  PORT(S)   AGE
joking-porcupine-verdaccio  ClusterIP  10.100.245.159  <none>       4873/TCP  0s

==> v1beta1/Deployment
NAME                        DESIRED  CURRENT  UP-TO-DATE  AVAILABLE  AGE
joking-porcupine-verdaccio  1        1        1           0          0s

NOTES:
1. Get the application URL by running these commands:
  export POD_NAME=$(kubectl get pods --namespace default -l "app=verdaccio,release=vested-lobster" -o jsonpath="{.items[0].metadata.name}")
  kubectl port-forward $POD_NAME 8080:4873
  echo "Visit http://127.0.0.1:8080 to use your application"

alt verdaccio

Then, follow the notes.

We export the application

export POD_NAME=$(kubectl get pods --namespace default -l "app=verdaccio,release=veering-gorilla" -o jsonpath="{.items[0].metadata.name}")

and we expose the port

➜ kubectl port-forward $POD_NAME 8080:4873
Forwarding from 127.0.0.1:8080 -> 4873
Forwarding from [::1]:8080 -> 4873

Verdaccio is up and running.

http://127.0.0.1:8080/#/

Publishing a Package

Let's log in.

➜ npm adduser --registry  http://127.0.0.1:8080
Username: user
Password: ***
Email: (this IS public) user@domain.com
Logged in as user on http://127.0.0.1:8080/.

and now we can publish

➜ npm publish --registry http://127.0.0.1:8080
+ @kubernetes/hellonode-example@1.0.0

alt verdaccio

Scale

Check the pod name (if you do not include --name) on install helm, kubernetes generate a random name.

➜ kubectl get pods
NAME                                         READY     STATUS    RESTARTS   AGE
veering-gorilla-verdaccio-666d9488bc-n9p27   1/1       Running   0          11m

Let's scale

➜ kubectl scale deployment veering-gorilla-verdaccio --replicas=3
deployment.extensions "veering-gorilla-verdaccio" scaled

alt verdaccio

Problems

I had this issue trying to install verdaccio helm, to solve it I just run a command and all works perfectly.

Registered user can't login

If you are facing this issue please read the following link https://github.com/verdaccio/verdaccio/issues/943#issuecomment-427670085

Connection refused

➜ helm install stable/verdaccio
Error: Get http://localhost:8080/api/v1/namespaces/kube-system/configmaps?labelSelector=OWNER%!D(MISSING)TILLER: dial tcp 127.0.0.1:8080: connect: connection refused

Run the following script to solve it.

kubectl -n kube-system patch deployment tiller-deploy -p '{"spec": {"template": {"spec": {"automountServiceAccountToken": true}}}}'

Tiller pod is missing

➜ helm install stable/verdaccio
Error: could not find a ready tiller pod

Run this to fix it.

helm init --upgrade