This doc will show how to run kube-batch
as a kubernetes batch scheduler. It is for master branch.
To run kube-batch
, a Kubernetes cluster must start up. Here is a document on Using kubeadm to Create a Cluster. Additionally, for common purposes and testing and deploying on local machine, one can use Minikube. This is a document on Running Kubernetes Locally via Minikube.
kube-batch
need to run as a kubernetes scheduler. The next step will show how to run kube-batch
as kubernetes scheduler quickly. Refer Configure Multiple Schedulers to get more details.
An official kube-batch image is provided and you can download it from DockerHub. The version is v0.2
now.
# docker pull kubesigs/kube-batch:v0.2
# mkdir -p $GOPATH/src/github.com/kubernetes-sigs/
# cd $GOPATH/src/github.com/kubernetes-sigs/
# git clone http://github.com/kubernetes-sigs/kube-batch
Run the kube-batch
as kubernetes scheduler
# helm install $GOPATH/src/github.com/kubernetes-sigs/kube-batch/deployment/kube-batch --namespace kube-system
Verify the release
# helm list
NAME REVISION UPDATED STATUS CHART NAMESPACE
dozing-otter 1 Thu Jun 14 18:52:15 2018 DEPLOYED kube-batch-0.2.0 kube-system
NOTE: kube-batch
need to collect cluster information(such as Pod, Node, CRD, etc) for scheduling, so the service account used by the deployment must have permission to access those cluster resources, otherwise, kube-batch
will fail to startup. For users who are not familiar with Kubernetes RBAC, please copy the example/role.yaml into $GOPATH/src/github.com/kubernetes-sigs/kube-batch/deployment/kube-batch/templates/
and reinstall batch.
Create a file named job-01.yaml
with the following content:
apiVersion: batch/v1
kind: Job
metadata:
name: qj-1
spec:
backoffLimit: 6
completions: 6
parallelism: 6
template:
metadata:
annotations:
scheduling.k8s.io/group-name: qj-1
spec:
containers:
- image: busybox
imagePullPolicy: IfNotPresent
name: busybox
resources:
requests:
cpu: "1"
restartPolicy: Never
schedulerName: kube-batch
---
apiVersion: scheduling.incubator.k8s.io/v1alpha1
kind: PodGroup
metadata:
name: qj-1
spec:
minMember: 6
The yaml file means a Job named qj-01
to create 6 pods(it is specified by parallelism
), these pods will be scheduled by scheduler kube-batch
(it is specified by schedulerName
). kube-batch
will watch PodGroup
, and the annotation scheduling.k8s.io/group-name
identify which group the pod belongs to. kube-batch
will start .spec.minMember
pods for a Job at the same time; otherwise, such as resources are not sufficient, kube-batch
will not start any pods for the Job.
Create the Job
# kubectl create -f job-01.yaml
Check job status
# kubectl get jobs
NAME DESIRED SUCCESSFUL AGE
qj-1 6 6 2h
Check the pods status
# kubectl get pod --all-namespaces
kube-batch
scheduler will start pods by their priority in the same QueueJob, pods with higher priority will start first. Here is sample to show PriorityClass
usage:
Create a priority_1000.yaml
with the following contents:
apiVersion: scheduling.k8s.io/v1beta1
kind: PriorityClass
metadata:
name: high-priority
namespace: batch-ns01
value: 1000
Create the PriorityClass with priority 1000.
# kubectl create -f priority_1000.yaml
Create a Pod configuration file (say pod-config-ns01-r01.yaml
):
apiVersion: v1
kind: Pod
metadata:
name: pod-ns01-r01
spec:
containers:
- name: key-value-store
image: redis
resources:
limits:
memory: "1Gi"
cpu: "1"
requests:
memory: "1Gi"
cpu: "1"
ports:
- containerPort: 6379
priorityClassName: high-priority
Create the Pod with priority 1000.
# kubectl create -f pod-config-ns01-r01.yaml
NOTE:
PriorityClass
is supported in kubernetes 1.9 or later.- The pod in same Deployment/RS/Job share the same pod template, so they have the same
PriorityClass
. To specify a differentPriorityClass
for pods in same QueueJob, users need to create controllers by themselves.