Nutanix COSI Driver provides reference implementation for Container Object Storage Interface (COSI) API for Nutanix Object Store
Checkout the detailed helm chart documentation in charts directory for installing COSI driver using helm.
$ git clone github.com/kubernetes-sigs/container-object-storage-interface-api
$ cd container-object-storage-interface-api
$ git checkout 2504944fc33162a34a8a95d6f935cf35c4d08762
$ kubectl create -k .
$ git clone github.com/kubernetes-sigs/container-object-storage-interface-controller
$ cd container-object-storage-interface-controller
$ git checkout 5240fb3aceded346058bdae116e39fabac8897aa
$ kubectl create -k .
Following pods will execute in the default namespace:
NAME READY STATUS RESTARTS AGE
objectstorage-controller-6fc5f89444-4ws72 1/1 Running 0 2d6h
$ git clone https://github.com/nutanix-cloud-native/cosi-driver-nutanix
$ cd cosi-driver-nutanix
Update the following credentials in project/resources/secret.yaml:
ENDPOINT
: Nutanix Object Store EndpointACCESS_KEY
: Nutanix Object Store Access KeySECRET_KEY
: Nutanix Object Store Secret KeyPC_SECRET
: Prism Central Credentials in the form 'prism-ip:prism-port:username:password'ACCOUNT_NAME
(Optional) : DisplayName identifier prefix for Nutanix Object Store (Default_Prefix: ntnx-cosi-iam-user)
Pre-requisites: Already deployed Nutanix object-store
Steps on how to get the above details:
- Open Prism Central UI in any browser and go the objects page. Below I already have a object store called
cosi
deployed ready for use. On the right side of the object store, you will see the objects Public IPs which you can use as the endpoint and update it in the secret.yaml file in the format:http:<objects public ip>:80
.
- On the side navigation bar click the
Access Keys
tab and then click onAdd People
.
- Add a new email address and name and click
Next
.
- Now click the
Generate Keys
button.
- After the keys are generated download the generated keys.
- Now, in the
Access Key
tab you will be able to see the person you just added.
- The keys file that you downloaded will be a text file which will contain the
Access Key
andSecret Key
that you need to update in the above secret.yaml file.
After updating the above file, execute these commands:
$ kubectl apply -k project/.
$ kubectl -n ntnx-system get pods
NAME READY STATUS RESTARTS AGE
objectstorage-provisioner-6c8df56cc6-lqr26 2/2 Running 0 26h
$ kubectl create -f project/examples/bucketclass.yaml
$ kubectl create -f project/examples/bucketclaim.yaml
A new bucket is created on nutanix object store using Object Store credentials (secret.yaml
) and a Bucket(B) custom resource gets created.
$ kubectl get bucket
NAME AGE
sample-bucketclass-ed073779-329e-4aff-b7f8-f5bdd54e06d5 7s
$ kubectl create -f project/examples/bucketaccessclass.yaml
$ kubectl create -f project/examples/bucketaccess.yaml
$ kubectl get bucketaccess
NAME AGE
sample-bucketaccess 5s
A new Nutanix Object Store user (userName of the format _ba-) is created using PC credentials (secret.yaml
) and the newly created bucket is shared with this new user
In the app, bucketaccess
can be consumed as a volume mount. A secret is created with the name provided in the bucketaccess spec field credentialsSecretName
which can be mounted onto to the pod:
$ kubectl get secret
NAME TYPE DATA AGE
bucketcreds Opaque 1 24h
spec:
containers:
volumeMounts:
- name: cosi-secrets
mountPath: /data/cosi
volumes:
- name: cosi-secrets
secret:
secretName: bucketcreds
An example awscli pod can be found at project/examples/awscliapppod.yaml
This Pod will list the buckets and then writes a test file to the new bucket.
$ kubectl create -f project/examples/awscliapppod.yaml
$ kubectl logs awscli
Defaulted container "awscli" out of: awscli, write-aws-credentials (init), write-test-file (init)
+ aws s3 ls
2024-12-20 19:38:40 sample-bucketclassc949a8c0-4c73-46ea-ace8-20071bff8102
++ cat /tmp/test-directory/file.txt
+ readonly BUCKET_NAME=sample-bucketclassc949a8c0-4c73-46ea-ace8-20071bff8102
+ BUCKET_NAME=sample-bucketclassc949a8c0-4c73-46ea-ace8-20071bff8102
++ date +%Y%m%d_%H%M%S
+ readonly FILE_NAME=20241220_213034.txt
+ FILE_NAME=20241220_213034.txt
+ aws s3 cp /tmp/test-directory/file.txt s3://sample-bucketclassc949a8c0-4c73-46ea-ace8-20071bff8102/20241220_213034.txt
upload: ../tmp/test-directory/file.txt to s3://sample-bucketclassc949a8c0-4c73-46ea-ace8-20071bff8102/20241220_213034.txt
+ aws s3 cp s3://sample-bucketclassc949a8c0-4c73-46ea-ace8-20071bff8102/20241220_213034.txt -
sample-bucketclassc949a8c0-4c73-46ea-ace8-20071bff8102
Credentials are available at /data/cosi/BucketInfo
in the awscli Pod.
$ kubectl delete bucketaccess sample-bucketaccess
$ kubectl delete bucketaccessclass sample-bucketaccessclass
$ kubectl delete bucketclaim sample-bucketclaim
$ kubectl delete bucketclass sample-bucketclass
Update the objectstorage-provisioner
secret that is used by the running provisioner deployment with the new config
# Nutanix Object Store instance endpoint, eg. "http://10.51.142.82:80"
ENDPOINT: "http://10.51.155.148:80"
# Admin IAM Access key to be used for Nutanix Objects
ACCESS_KEY: ""
# Admin IAM Secret key to be used for Nutanix Objects
SECRET_KEY: ""
# PC Credentials in format <prism-ip>:<prism-port>:<user>:<password>.
# eg. "<ip>:<port>:user:password"
PC_SECRET: ""
Then restart the provisioner pod so that the new secret changes getting mounted on the new pod and will thereon be used.
$ kubectl -n ntnx-system get pods
NAME READY STATUS RESTARTS AGE
objectstorage-provisioner-6c8df56cc6-lqr26 2/2 Running 0 26h
$ kubectl delete pod objectstorage-provisioner-6c8df56cc6-lqr26 -n ntnx-system
New pod comes up which will be having the updated config
$ kubectl -n ntnx-system get pods
NAME READY STATUS RESTARTS AGE
objectstorage-provisioner-5f3we89tt2-tfy357 2/2 Running 0 2s
Code can be compiled using:
$ git clone https://github.com/nutanix-cloud-native/cosi-driver-nutanix
$ cd cosi-driver-nutanix
$ make build
Build and push docker image and for your custom resistry name and image tag
$ make REGISTRY_NAME=SampleRegistryUsername/cosi-driver-nutanix IMAGE_TAG=latest container
$ make REGISTRY_NAME=SampleRegistryUsername/cosi-driver-nutanix IMAGE_TAG=latest docker-push
Your custom image SampleRegistry/cosi-driver-nutanix:latest
is now ready to be used.