diff --git a/cesnet-central/playbooks/k8s.yaml b/cesnet-central/playbooks/k8s.yaml
index 72f1ddaf58743dfcdf3884b6d8754ca1b4cd3ebd..d0e9cb888f1ab491194e057213f1b75f9cf2f2ec 100644
--- a/cesnet-central/playbooks/k8s.yaml
+++ b/cesnet-central/playbooks/k8s.yaml
@@ -25,6 +25,7 @@
           - atop
           - cron-apt
           - fail2ban
+          - git
           - mc
           - vim
           - postfix
@@ -262,6 +263,44 @@
         KUBECONFIG: /etc/kubernetes/admin.conf
         PATH: /sbin:/bin:/usr/sbin:/usr/bin:/usr/local/bin
       when: true
+    - name: Git clone local-path-provisioner
+      git:
+        repo: https://github.com/rancher/local-path-provisioner.git
+        dest: "/root/git-local-path-provisioner"
+        clone: yes
+        update: no
+        version: v0.0.26
+    - name: Local path provisioner configuration
+      copy:
+        dest: /tmp/local-path-provisioner.yaml
+        mode: 0644
+        content: |
+          storageClass:
+            defaultClass: false
+            defaultVolumeType: hostPath
+            name: local-path
+          nodePathMap:
+            - node: DEFAULT_PATH_FOR_NON_LISTED_NODES
+              paths:
+                - /scratch
+    - name: Local path provisioner deployment
+      vars:
+        config: >-
+          --namespace local-path-storage
+          -f /tmp/local-path-provisioner.yaml
+          local-path-storage
+          /root/git-local-path-provisioner/deploy/chart/local-path-provisioner/
+      shell: |-
+        helm status --namespace local-path-storage local-path-storage
+        if [ $? -ne 0 ]; then
+            helm install {{ config }}
+        else
+            helm upgrade {{ config }}
+        fi
+      environment:
+        KUBECONFIG: /etc/kubernetes/admin.conf
+        PATH: /sbin:/bin:/usr/sbin:/usr/bin:/usr/local/bin
+      when: true
     - name: Helm repo add ingress-nginx
       shell: |-
         helm repo add ingress-nginx https://kubernetes.github.io/ingress-nginx