Run AI/ML jobs based on the pre-defined templates
This kubectl plugin allows ML researchers to run templated Jobs with different values for the application-specific parameters, without the need to edit and submit entire YAML files. The tool comes with built-in support for running slurm scripts inside a Kubernetes cluster.
Read the overview to learn more.
- go version v1.23+
- kubectl version v1.27+.
- Access to a Kubernetes v1.27+ cluster.
Install the CRDs into the cluster:
make install
Install kubectl kjob
plugin:
make kubectl-kjob
sudo cp ./bin/kubectl-kjob /usr/local/bin/kubectl-kjob
Additionally, you can create an alias kjobctl
to allow shorter syntax:
echo 'alias kjobctl="kubectl kjob"' >> ~/.bashrc
# Or if you are using ZSH
echo 'alias kjobctl="kubectl kjob"' >> ~/.zshrc
Autocompletion:
echo '[[ $commands[kubectl-kjob] ]] && source <(kubectl-kjob completion bash)' >> ~/.bashrc
# Or if you are using ZSH
echo '[[ $commands[kubectl-kjob] ]] && source <(kubectl-kjob completion zsh)' >> ~/.zshrc
cat <<EOF >kubectl_complete-kjob
#!/usr/bin/env sh
# Call the __complete command passing it all arguments
kubectl kjob __complete "\$@"
EOF
chmod u+x kubectl_complete-kjob
sudo mv kubectl_complete-kjob /usr/local/bin/kubectl_complete-kjob
Delete the APIs(CRDs) from the cluster:
make uninstall
Delete kubectl kjob
plugin:
sudo rm /usr/local/bin/kubectl-kjob
NOTE: Run make help
for more information on all potential make
targets
Copyright 2024 The Kubernetes Authors.
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
Learn how to engage with the Kubernetes community on the community page.
You can reach the maintainers of this project at:
Participation in the Kubernetes community is governed by the Kubernetes Code of Conduct.