- Have
quay.io
account, running docker and kubernetes. You could use any registry account and replacequay.io
with such registry name in below steps. - Docker login to your
quay.io
account.
$ docker login --username <QUAY_USERNAME> https://quay.io
- Create
csi-provisioner
,livenessprobe
andcsi-node-driver-registrar
repositories by pull/tag/push respective images to yourquay.io
account.
$ docker pull quay.io/minio/csi-provisioner@sha256:d4f94539565cf62aea57062b6a42c5156337003133fd3f51b93df9a789e69840 && \
docker tag quay.io/minio/csi-provisioner@sha256:d4f94539565cf62aea57062b6a42c5156337003133fd3f51b93df9a789e69840 quay.io/<QUAY_USERNAME>/csi-provisioner && \
docker push quay.io/<QUAY_USERNAME>/csi-provisioner
$ docker pull quay.io/minio/livenessprobe@sha256:928a80be4d363e0e438ff28dcdb00d8d674d3059c6149a8cda64ce6016a9a3f8 && \
docker tag quay.io/minio/livenessprobe@sha256:928a80be4d363e0e438ff28dcdb00d8d674d3059c6149a8cda64ce6016a9a3f8 quay.io/<QUAY_USERNAME>/livenessprobe && \
docker push quay.io/<QUAY_USERNAME>/livenessprobe
$ docker pull quay.io/minio/csi-node-driver-registrar@sha256:843fb23b1a3fa1de986378b0b8c08c35f8e62499d386de8ec57801fd029afe6d && \
docker tag quay.io/minio/csi-node-driver-registrar@sha256:843fb23b1a3fa1de986378b0b8c08c35f8e62499d386de8ec57801fd029afe6d quay.io/<QUAY_USERNAME>/csi-node-driver-registrar && \
docker push quay.io/<QUAY_USERNAME>/csi-node-driver-registrar
- Make sure
csi-provisioner
,livenessprobe
andcsi-node-driver-registrar
repositories arepublic
in yourquay.io
account. - Go to your direct-csi project root.
$ cd $GOPATH/src/github.com/minio/direct-csi
- Hack, hack, hack...
- Run go build
$ go build -v ./...
- Run ./build.sh
$ ./build.sh
- Run docker build to tag image.
$ docker build -t quay.io/<QUAY_USERNAME>/direct-csi:<NEW_BUILD_TAG> .
- Push newly created image to your
quay.io
account.
$ docker push quay.io/<QUAY_USERNAME>/direct-csi:<NEW_BUILD_TAG>
- Make sure
direct-csi
repository ispublic
in yourquay.io
account. - Install direct-csi.
$ ./kubectl-direct_csi --kubeconfig <PATH-TO-KUBECONFIG-FILE> install \
--image direct-csi:<NEW_BUILD_TAG> --org <QUAY_USERNAME> --registry quay.io
- Check running direct-csi
$ ./kubectl-direct_csi --kubeconfig <PATH-TO-KUBECONFIG-FILE> info
$ ./kubectl-direct_csi --kubeconfig <PATH-TO-KUBECONFIG-FILE> drives list
DirectCSI can automatically provision loopback devices for setups where extra drives are not available. The loopback interface is intended for use with automated testing and continuous integration, and is not recommended for use in regular development or production environments. Some operating systems, such as macOS, place limits on the number of loop devices and can cause DirectCSI to hang while attempting to provision persistent volumes. This issue is particularly noticeable on Kubernetes deployment tools like kind
or minikube
, where the deployed infrastructure takes up most if not all of the available loop devices and prevents DirectCSI from provisioning drives entirely.