K8s Native: Persistent Volumes
How to tap into Kubernetes persistent volumes for your Orka environment.
For security reasons, Orka does not let you configure persistent volumes yourself. The MacStadium team needs to do that for you. However, when a persistent volume is configured for your environment, you can create persistent volume claims and deploy pods that consume the respective persistent volume.
Quick command summary
brew install kubectl
orka3 login
ORorka3 user set-token <TOKEN>
orka3 ns create <NAMESPACE> --enable-custom-pods
orka3 node namespace <NODE> <NAMESPACE>
orka3 rb add-subject --namespace <NAMESPACE> --user <USER>
kubectl apply -f *.yaml --namespace=<NAMESPACE>
kubectl get [pods / pvc]
kubectl describe
kubectl delete
Limitations
Persistent volumes are not applicable to standard Orka VMs. They can be consumed only by pods deployed with kubectl
, and are called by functions such as attach-disk
.
If you want to persist the storage of a standard Orka VM, use the VM commit
, save
, or push
operations.
Step 1: Request a persistent volume
Contact the MacStadium team and request a persistent volume (PV) for your Orka environment. Work closely with the team to help them create a PV that matches your requirements. Note that at this step, you need to decide on the name of the namespace where the PV will be created.
Step 2: Get Kubernetes-ready
You need to install kubectl
and configure a namespace with permissions to run custom pods.
- If not already installed, install kubectl locally. For example:
brew install kubectl
- Authenticate with the Orka cluster.
orka3 login
OR
orka user set-token <TOKEN>
- Set up the namespace for the PV. The name must match the name confirmed with the MacStadium team when requesting the PV. The namespace must have custom pods enabled. Next, you need to move computational resources to the namespace and you need to grant namespace access to the users or service accounts which will be working with the namespace.
orka3 namespace create <NAME> --enable-custom-pods
orka3 node namespace <NODE> <NAMESPACE>
orka3 rb add-subject --namespace <NAMESPACE> --user <USER>
Step 3: Create the persistent volume claim
A persistent volume claim (PVC) lets you tap into your persistent volume and consume it. You need to create a basic yaml
manifest for the PVC and apply it to the environment.
- Create the PVC manifest. For more information, see Kubernetes Documentation: PersistentVolumeClaims. For example:
# pvc.yaml
kind: PersistentVolumeClaim
apiVersion: v1
metadata:
name: mypvc
spec:
accessModes:
- ReadWriteOnce
resources:
requests:
storage: 20Gi
The values for metadata:name
and metadata:namespace
must match the values for claimRef:name
and claimRef:namespace
declared in the manifest of the persistent volume. Double-check with the MacStadium team for these values.
- Apply the PVC. Replace
pvc.yaml
with the complete file path to your own PVC manifest. Replace<NAMESPACE>
with the namespace you created earlier.
kubectl apply -f pvc.yaml --namespace=<NAMESPACE>
- Verify that the persistent volume claim is bound to the persistent volume.
kubectl get pvc
If the persistent volume claim works as expected, you will see a similar output:
NAME STATUS VOLUME CAPACITY ACCESS MODES STORAGECLASS AGE
mypvc Bound my-pv 20Gi RWO 13s
Status Pending?
If the status is
Pending
instead ofBound
, double-check your PVC manifest, fix any naming issues, remove the oldpvc
withkubectl delete pvc <NAME>
, and re-apply the fixed manifest. If the problem persists, contact the MacStadium team.
Step 4: Deploy a pod that uses the persistent volume
Now that you have created a PVC and bound it to the PV, you can deploy a pod that uses the PV. Create a pod manifest and apply it.
- Create the pod manifest. The pod needs to reference both the PV and the PVC. For example:
apiVersion: v1
kind: Pod
metadata:
name: mypod
spec:
volumes:
- name: my-pv
persistentVolumeClaim:
claimName: mypvc
containers:
- name: mypod
image: ubuntu
command: ["/bin/bash", "-ec", "while :; do echo '.'; sleep 5 ; done"]
volumeMounts:
- mountPath: "/usr/share/mypod"
name: my-pv
restartPolicy: Never
tolerations:
- key: orka.macstadium.com/namespace-reserved
value: <NAMESPACE>
This example deploys a Linux VM. Pay attention to the command
line and the tolerations
section. Without the command
line, the state of your Linux VM will become Stopped
. Without the tolerations
section, you won't be able to create the pod.
- Apply the pod. Replace
mypod.yaml
with the complete file path to your pod manifest.
kubectl apply -f mypod.yaml --namespace=<NAMESPACE>
- Verify that the pod is deployed and running.
kubectl get pods
If the pod works as expected, you will see a similar output:
NAME READY STATUS RESTARTS AGE
pod/mypod 1/1 Running 0 12s
- Verify that the pod uses the claim and the persistent volume. Look for the data listed for
Volumes
.
kubectl describe pod <NAME>
(Optional) Step 5: Deploy a service to handle the networking between your pods and your Orka VMs
If you want to have connectivity between your Orka VMs and any pods deployed with kubectl
, you need to deploy a networking service. For more information, see Kubernetes Documentation: Service.
Make sure to use the networking information provided in your Orka IP Plan when assigning IPs.
What's next: Delete the PVC and release the PV
When you no longer need to use a PVC and the respective PV, you can delete the PVC to release the PV.
- Delete the PVC.
kubectl delete pvc <NAME>
- Contact the MacStadium team.
- If you want to reclaim the storage, an administrator might need to clean it up and verify that it's available for use again. This would depend on the provisioning type and the reclaim policy for the PV.
- If you no longer need the storage, an administrator can remove the PV.
Updated 9 months ago