Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Adding the support of Linux bridge interface for VM setup #157

Closed
wants to merge 1 commit into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
9 changes: 9 additions & 0 deletions cmd/k8s-netperf/k8s-netperf.go
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
package main

Check failure on line 1 in cmd/k8s-netperf/k8s-netperf.go

View workflow job for this annotation

GitHub Actions / build

: # github.com/cloud-bulldozer/k8s-netperf/cmd/k8s-netperf

import (
"context"
Expand Down Expand Up @@ -43,6 +43,7 @@
full bool
vm bool
debug bool
bridge string
promURL string
id string
searchURL string
Expand Down Expand Up @@ -164,6 +165,13 @@
}
s.KClient = kclient
s.DClient = dynClient
if len(bridge) > 0 {
err := k8s.DeployNADBridge(s.DClient, bridge)

Check failure on line 169 in cmd/k8s-netperf/k8s-netperf.go

View workflow job for this annotation

GitHub Actions / build

undefined: k8s.DeployNADBridge

Check failure on line 169 in cmd/k8s-netperf/k8s-netperf.go

View workflow job for this annotation

GitHub Actions / build

undefined: k8s.DeployNADBridge (typecheck)

Check failure on line 169 in cmd/k8s-netperf/k8s-netperf.go

View workflow job for this annotation

GitHub Actions / build

undefined: k8s.DeployNADBridge
if err != nil {
log.Error(err)
}
s.Bridge = true
}
}

// Build the SUT (Deployments)
Expand Down Expand Up @@ -481,6 +489,7 @@
rootCmd.Flags().BoolVar(&acrossAZ, "across", false, "Place the client and server across availability zones")
rootCmd.Flags().BoolVar(&full, "all", false, "Run all tests scenarios - hostNet and podNetwork (if possible)")
rootCmd.Flags().BoolVar(&debug, "debug", false, "Enable debug log")
rootCmd.Flags().StringVar(&bridge, "bridge", "", "Name of the NNCP to be used for creating bridge interface - VM only.")
rootCmd.Flags().StringVar(&promURL, "prom", "", "Prometheus URL")
rootCmd.Flags().StringVar(&id, "uuid", "", "User provided UUID")
rootCmd.Flags().StringVar(&searchURL, "search", "", "OpenSearch URL, if you have auth, pass in the format of https://user:pass@url:port")
Expand Down
1 change: 1 addition & 0 deletions pkg/config/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,7 @@ type PerfScenarios struct {
Configs []Config
VM bool
VMHost string
Bridge bool
ServerNodeInfo metrics.NodeInfo
ClientNodeInfo metrics.NodeInfo
Client apiv1.PodList
Expand Down
4 changes: 2 additions & 2 deletions pkg/k8s/kubernetes.go
Original file line number Diff line number Diff line change
Expand Up @@ -451,7 +451,7 @@ func BuildSUT(client *kubernetes.Clientset, s *config.PerfScenarios) error {

// launchServerVM will create the ServerVM with the specific node and pod affinity.
func launchServerVM(perf *config.PerfScenarios, name string, podAff *corev1.PodAntiAffinity, nodeAff *corev1.NodeAffinity) error {
_, err := CreateVMServer(perf.KClient, serverRole, serverRole, *podAff, *nodeAff)
_, err := CreateVMServer(perf.KClient, serverRole, serverRole, *podAff, *nodeAff, perf.Bridge)
if err != nil {
return err
}
Expand All @@ -476,7 +476,7 @@ func launchServerVM(perf *config.PerfScenarios, name string, podAff *corev1.PodA

// launchClientVM will create the ClientVM with the specific node and pod affinity.
func launchClientVM(perf *config.PerfScenarios, name string, podAff *corev1.PodAntiAffinity, nodeAff *corev1.NodeAffinity) error {
host, err := CreateVMClient(perf.KClient, perf.ClientSet, perf.DClient, name, podAff, nodeAff)
host, err := CreateVMClient(perf.KClient, perf.ClientSet, perf.DClient, name, podAff, nodeAff, perf.Bridge)
if err != nil {
return err
}
Expand Down
93 changes: 85 additions & 8 deletions pkg/k8s/kubevirt.go
Original file line number Diff line number Diff line change
Expand Up @@ -158,7 +158,7 @@ func exposeService(client *kubernetes.Clientset, dynamicClient *dynamic.DynamicC

// CreateVMClient takes in the affinity rules and deploys the VMI
func CreateVMClient(kclient *kubevirtv1.KubevirtV1Client, client *kubernetes.Clientset,
dyn *dynamic.DynamicClient, name string, podAff *corev1.PodAntiAffinity, nodeAff *corev1.NodeAffinity) (string, error) {
dyn *dynamic.DynamicClient, name string, podAff *corev1.PodAntiAffinity, nodeAff *corev1.NodeAffinity, bridge bool) (string, error) {
label := map[string]string{
"app": name,
"role": name,
Expand All @@ -171,6 +171,7 @@ func CreateVMClient(kclient *kubevirtv1.KubevirtV1Client, client *kubernetes.Cli
if err != nil {
return "", err
}
netData := "{}"
data := fmt.Sprintf(`#cloud-config
users:
- name: fedora
Expand All @@ -184,7 +185,7 @@ chpasswd: { expire: False }
runcmd:
- export HOME=/home/fedora
- dnf install -y --nodocs uperf iperf3 git ethtool automake gcc bc lksctp-tools-devel texinfo --enablerepo=*
- git clone https://github.com/HewlettPackard/netperf
- git clone https://github.com/HewlettPackard/netperf.git
- cd netperf
- git reset --hard 3bc455b23f901dae377ca0a558e1e32aa56b31c4
- curl -o netperf.diff https://raw.githubusercontent.com/cloud-bulldozer/k8s-netperf/main/containers/netperf.diff
Expand All @@ -196,7 +197,43 @@ runcmd:
- curl -o /usr/bin/super-netperf https://raw.githubusercontent.com/cloud-bulldozer/k8s-netperf/main/containers/super-netperf
- chmod 0777 /usr/bin/super-netperf
`, ssh)
_, err = CreateVMI(kclient, name, label, b64.StdEncoding.EncodeToString([]byte(data)), *podAff, *nodeAff)
interfaces := []v1.Interface{
{
Name: "default",
InterfaceBindingMethod: v1.InterfaceBindingMethod{
Bridge: &v1.InterfaceBridge{},
},
},
}
networks := []v1.Network{
{
Name: "default",
NetworkSource: v1.NetworkSource{
Pod: &v1.PodNetwork{},
},
},
}
if bridge {
interfaces = append(interfaces, v1.Interface{
Name: "br-netperf",
InterfaceBindingMethod: v1.InterfaceBindingMethod{
Bridge: &v1.InterfaceBridge{},
},
})
networks = append(networks, v1.Network{
Name: "br-netperf",
NetworkSource: v1.NetworkSource{
Multus: &v1.MultusNetwork{
NetworkName: "netperf/br-netperf",
},
},
})
netData = `version: 2
ethernets:
eth1:
addresses: [ 10.10.10.12/24 ]`
}
_, err = CreateVMI(kclient, name, label, b64.StdEncoding.EncodeToString([]byte(data)), *podAff, *nodeAff, interfaces, networks, b64.StdEncoding.EncodeToString([]byte(netData)))
if err != nil {
return "", err
}
Expand All @@ -213,11 +250,12 @@ runcmd:

// CreateVMServer will take the pod and node affinity and deploy the VMI
func CreateVMServer(client *kubevirtv1.KubevirtV1Client, name string, role string, podAff corev1.PodAntiAffinity,
nodeAff corev1.NodeAffinity) (*v1.VirtualMachineInstance, error) {
nodeAff corev1.NodeAffinity, bridge bool) (*v1.VirtualMachineInstance, error) {
label := map[string]string{
"app": name,
"role": role,
}
netData := "{}"
dirname, err := os.UserHomeDir()
if err != nil {
return nil, err
Expand All @@ -239,7 +277,7 @@ chpasswd: { expire: False }
runcmd:
- dnf install -y --nodocs uperf iperf3 git ethtool
- dnf install -y --nodocs automake gcc bc lksctp-tools-devel texinfo --enablerepo=*
- git clone https://github.com/HewlettPackard/netperf
- git clone https://github.com/HewlettPackard/netperf.git
- cd netperf
- git reset --hard 3bc455b23f901dae377ca0a558e1e32aa56b31c4
- curl -o netperf.diff https://raw.githubusercontent.com/cloud-bulldozer/k8s-netperf/main/containers/netperf.diff
Expand All @@ -252,12 +290,48 @@ runcmd:
- iperf3 -s -p %d &
- netserver &
`, string(ssh), UperfServerCtlPort, IperfServerCtlPort)
return CreateVMI(client, name, label, b64.StdEncoding.EncodeToString([]byte(data)), podAff, nodeAff)
interfaces := []v1.Interface{
{
Name: "default",
InterfaceBindingMethod: v1.InterfaceBindingMethod{
Bridge: &v1.InterfaceBridge{},
},
},
}
networks := []v1.Network{
{
Name: "default",
NetworkSource: v1.NetworkSource{
Pod: &v1.PodNetwork{},
},
},
}
if bridge {
interfaces = append(interfaces, v1.Interface{
Name: "br-netperf",
InterfaceBindingMethod: v1.InterfaceBindingMethod{
Bridge: &v1.InterfaceBridge{},
},
})
networks = append(networks, v1.Network{
Name: "br-netperf",
NetworkSource: v1.NetworkSource{
Multus: &v1.MultusNetwork{
NetworkName: "netperf/br-netperf",
},
},
})
netData = `version: 2
ethernets:
eth1:
addresses: [ 10.10.10.14/24 ]`
}
return CreateVMI(client, name, label, b64.StdEncoding.EncodeToString([]byte(data)), podAff, nodeAff, interfaces, networks, b64.StdEncoding.EncodeToString([]byte(netData)))
}

// CreateVMI creates the desired Virtual Machine instance with the cloud-init config with affinity.
func CreateVMI(client *kubevirtv1.KubevirtV1Client, name string, label map[string]string, b64data string, podAff corev1.PodAntiAffinity,
nodeAff corev1.NodeAffinity) (*v1.VirtualMachineInstance, error) {
nodeAff corev1.NodeAffinity, interfaces []v1.Interface, networks []v1.Network, netDatab64 string) (*v1.VirtualMachineInstance, error) {
delSeconds := int64(0)
mutliQ := true
vmi, err := client.VirtualMachineInstances(namespace).Create(context.TODO(), &v1.VirtualMachineInstance{
Expand Down Expand Up @@ -300,8 +374,10 @@ func CreateVMI(client *kubevirtv1.KubevirtV1Client, name string, label map[strin
},
},
},
Interfaces: interfaces,
},
},
Networks: networks,
Volumes: []v1.Volume{
v1.Volume{
Name: "disk0",
Expand All @@ -315,7 +391,8 @@ func CreateVMI(client *kubevirtv1.KubevirtV1Client, name string, label map[strin
Name: "cloudinit",
VolumeSource: v1.VolumeSource{
CloudInitNoCloud: &v1.CloudInitNoCloudSource{
UserDataBase64: b64data,
UserDataBase64: b64data,
NetworkDataBase64: netDatab64,
},
},
},
Expand Down
Loading