Skip to content

GeoCompas/ds-k8s-gpu

 
 

Repository files navigation

DevSeed k8s cluster with GPU nodes

This is a lab project aimed at providing easy access to GPU instances for machine learning engineers. The script uses eksctl to deploy a Kubernetes cluster that is equipped with GPU support. In addition, it allows users to choose between Spot and On-Demand instances. Once the cluster is up and running, it also prepares the environment for deploying Helm charts.

e.g: https://github.com/developmentseed/ds-helm-chart

Create/Delete a cluster

./deploy.sh <enviroment> <aws_region> create_cluster
./deploy.sh <enviroment> <aws_region> delete_cluster

Once you have created your cluster, the next step is to create your GPU nodes. The configuration can be found in the instance_list.yaml file, which you can modify according to the instances you require.

Create/Delete GPU nodes

./deploy.sh <enviroment> <aws_region> create_nodes
./deploy.sh <enviroment> <aws_region> delete_nodes

Once you have created your nodes, you will have a file called devseed-k8s-<enviroment>-nodes.yaml, which will contain the available nodegroup_type for you to use to deploy the helm charts.

Using Persistence Disk

If you plan to use persistent disks, make sure to first check the availability zone where your nodes are created. e.g: us-east-1b then:

aws ec2 create-volume \
  --region us-east-1 \
  --availability-zone us-east-1b \
  --size 20 \
  --volume-type gp2 \
  --tag-specifications 'ResourceType=volume,Tags=[{Key=Name,Value=devseed-ebs-test}]'

Copy the VolumeId and add in the values.yaml file

SSH into the GPU node

You can access the GPU node via SSH using a key pair that has been created in AWS, named k8s-sam. If you require access to the associated private key, k8s-sam.pem, please reach out to the cluster administrator. If you are setting up your own cluster, you'll also need to create this key pair. To make your experience smoother, essential applications like git and aws-cli are pre-installed on the node.

TODO: install docker-compose

sudo systemctl enable docker
sudo usermod -aG docker ${USER}
newgrp docker
ls -la /var/run/docker.sock
sudo systemctl restart docker
sudo curl -L "https://github.com/docker/compose/releases/latest/download/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
sudo chmod +x /usr/local/bin/docker-compose

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Shell 100.0%