Skip to content

Latest commit

 

History

History
115 lines (96 loc) · 4.11 KB

README.md

File metadata and controls

115 lines (96 loc) · 4.11 KB

Speculative-Migration

Configuration

Based on fishercht1995/progress-based-k8s-scheduler project, there are two more thing need to modify in our kubernetes system

Firstly, modify clusterrole system:kube-scheduler and add pod delete,pod create to our own scheduler.

kubectl edit clusterrole system:kube-scheduler

Modify config to that

- apiGroups:
  - ""
  resources:
  - pods
  verbs:
  - delete
  - get
  - list
  - watch
  - create
  - delete

Second, add a folder /mnt/linuxidc/templates, and put all working yaml file inside.

System

system.yaml

This yaml file is to create a pod consists of a master container and serveal worker containers. You can change args in worker container to set different parameters: checking time interval and threhold.

For example:

name: worker3
      image: fuyuqi1995/mig-worker
      command: ["python"]
      args: ["worker.py","node-3.rouji.shield-pg0.utah.cloudlab.us","0.1","10"]
      volumeMounts:
        - mountPath: "/data/"
          name: task-pv-storage

You need to change each

ser.yaml

Configure my-scheduler roles

Implement experiment

I have maintained some easily used script to implement experiments

job_node_info.py

Firstly

kubectl get pod -o=custom-columns=NODE:.spec.nodeName,NAME:.metadata.name > info.txt

Then raw job_node info will be saved to info.txt

NODE                                         NAME
node-2.wedgood.shield-pg0.utah.cloudlab.us   job1-migrated
node-1.wedgood.shield-pg0.utah.cloudlab.us   job2
node-1.wedgood.shield-pg0.utah.cloudlab.us   job3-migrated
node-1.wedgood.shield-pg0.utah.cloudlab.us   job4-migrated
node-1.wedgood.shield-pg0.utah.cloudlab.us   job5
node-2.wedgood.shield-pg0.utah.cloudlab.us   job6
node-3.rouji.shield-pg0.utah.cloudlab.us     job7

It will generate job:node pairs into a job_node_info.csv file(Since our migrated algorithm will change containers ditribution, we can do it after implement default experiment.

change_yaml.py

Firstly

kubectl get pod -o=custom-columns=NODE:.spec.nodeName,NAME:.metadata.name > info.txt

Then raw job_node info will be saved to info.txt

NODE                                         NAME
node-2.wedgood.shield-pg0.utah.cloudlab.us   job1-migrated
node-1.wedgood.shield-pg0.utah.cloudlab.us   job2
node-1.wedgood.shield-pg0.utah.cloudlab.us   job3-migrated
node-1.wedgood.shield-pg0.utah.cloudlab.us   job4-migrated
node-1.wedgood.shield-pg0.utah.cloudlab.us   job5
node-2.wedgood.shield-pg0.utah.cloudlab.us   job6
node-3.rouji.shield-pg0.utah.cloudlab.us     job7

change_yaml.py provides a easy way to modify yaml files in /mnt/linuxidc/templates. There are two ways to use it

	yaml_dic["spec"]["nodeName"] = job_node[name]
	#yaml_dic["spec"].pop("nodeName")

Now I have just commented second one. The first line mean change yaml file nodeName config to some job_node pair from now. For example, we firstly run default one, then use python change_yaml.py. Then when we implement migrated algorithm later, orginal containers before migrated will be the same as info.txt. So it makes these two experiments comparable.

test.py

You can use python test.py to start experiment. There is a variabale called time_list which is the schedules of submitted. What I do is generate random values in local and then copy it to the script

generate cpu data

kubectl get svc --all-namespaces

It will show

NAMESPACE     NAME            TYPE        CLUSTER-IP      EXTERNAL-IP   PORT(S)                  AGE
default       kubernetes      ClusterIP   10.96.0.1       <none>        443/TCP                  9d
kube-system   grafana         NodePort    10.111.15.154   <none>        3000:30325/TCP           9d
kube-system   kube-dns        ClusterIP   10.96.0.10      <none>        53/UDP,53/TCP,9153/TCP   9d
kube-system   node-exporter   NodePort    10.101.55.144   <none>        9100:31672/TCP           9d
kube-system   prometheus      NodePort    10.106.226.22   <none>        9090:30003/TCP           9d

Then use browser and use url: external_ip of master: 30325

Details are in fishercht1995/progress-based-k8s-scheduler project