mirror of
https://github.com/netbirdio/gvisor.git
synced 2026-05-22 17:12:49 -07:00
cc665d1dcb
This is part of a series of changes to add metric charts in performance benchmarks. All benchmarks now auto-detect if profiling metrics are enabled in the test runtime. If profiling metrics data is present, it will generate charts of the data. PiperOrigin-RevId: 633094699
72 lines
2.1 KiB
Go
72 lines
2.1 KiB
Go
// Copyright 2020 The gVisor 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.
|
|
|
|
// Package network holds benchmarks around raw network performance.
|
|
package network
|
|
|
|
import (
|
|
"context"
|
|
"testing"
|
|
|
|
"gvisor.dev/gvisor/pkg/test/dockerutil"
|
|
"gvisor.dev/gvisor/test/benchmarks/harness"
|
|
"gvisor.dev/gvisor/test/benchmarks/tools"
|
|
"gvisor.dev/gvisor/test/metricsviz"
|
|
)
|
|
|
|
// runStaticServer runs static serving workloads (httpd, nginx).
|
|
func runStaticServer(b *testing.B, serverOpts dockerutil.RunOpts, serverCmd []string, port int, hey *tools.Hey) {
|
|
ctx := context.Background()
|
|
|
|
// Get two machines: a client and server.
|
|
clientMachine, err := harness.GetMachine()
|
|
if err != nil {
|
|
b.Fatalf("failed to get machine: %v", err)
|
|
}
|
|
defer clientMachine.CleanUp()
|
|
|
|
serverMachine, err := harness.GetMachine()
|
|
if err != nil {
|
|
b.Fatalf("failed to get machine: %v", err)
|
|
}
|
|
defer serverMachine.CleanUp()
|
|
|
|
// Make the containers.
|
|
client := clientMachine.GetNativeContainer(ctx, b)
|
|
defer client.CleanUp(ctx)
|
|
server := serverMachine.GetContainer(ctx, b)
|
|
defer server.CleanUp(ctx)
|
|
defer metricsviz.FromContainerLogs(ctx, b, server)
|
|
|
|
// Start the server.
|
|
if err := server.Spawn(ctx, serverOpts, serverCmd...); err != nil {
|
|
b.Fatalf("failed to start server: %v", err)
|
|
}
|
|
|
|
// Make sure the server is serving.
|
|
harness.WaitUntilContainerServing(ctx, clientMachine, server, port)
|
|
|
|
// Run the client.
|
|
b.ResetTimer()
|
|
out, err := client.Run(ctx, dockerutil.RunOpts{
|
|
Image: "benchmarks/hey",
|
|
Links: []string{server.MakeLink("server")},
|
|
}, hey.MakeCmd("server", port)...)
|
|
if err != nil {
|
|
b.Fatalf("run failed with: %v", err)
|
|
}
|
|
b.StopTimer()
|
|
hey.Report(b, out)
|
|
}
|