Пример #1
0
func benchmarkVariesInterval(d *helpers.DockerHelper) {
	alive := d.GetContainerNum(false)
	dead := d.GetContainerNum(true) - alive
	containerIDs := d.GetContainerIDs()
	cfg := variesIntervalConfig
	listIntervals := cfg["list interval"].([]time.Duration)
	listPeriod := cfg["list period"].(time.Duration)
	func() {
		defer d.LogError()
		helpers.LogTitle("list_all")
		helpers.LogEVar(map[string]interface{}{
			"#alive": alive,
			"#dead":  dead,
			"all":    true,
			"period": listPeriod,
		})
		helpers.LogLabels("interval")
		for _, curInterval := range listIntervals {
			latencies := d.DoListContainerBenchmark(curInterval, listPeriod, true)
			helpers.LogResult(latencies, helpers.Itoas(int(curInterval/time.Millisecond))...)
		}
	}()

	func() {
		defer d.LogError()
		helpers.LogTitle("list_alive")
		helpers.LogEVar(map[string]interface{}{
			"#alive": alive,
			"#dead":  dead,
			"all":    false,
			"period": listPeriod,
		})
		helpers.LogLabels("interval")
		for _, curInterval := range listIntervals {
			latencies := d.DoListContainerBenchmark(curInterval, listPeriod, false)
			helpers.LogResult(latencies, helpers.Itoas(int(curInterval/time.Millisecond))...)
		}
	}()

	func() {
		defer d.LogError()
		inspectIntervals := cfg["inspect interval"].([]time.Duration)
		inspectPeriod := cfg["inspect period"].(time.Duration)
		helpers.LogTitle("inspect")
		helpers.LogEVar(map[string]interface{}{
			"#alive": alive,
			"#dead":  dead,
			"period": inspectPeriod,
		})
		helpers.LogLabels("interval")
		for _, curInterval := range inspectIntervals {
			latencies := d.DoInspectContainerBenchmark(curInterval, inspectPeriod, containerIDs)
			helpers.LogResult(latencies, helpers.Itoas(int(curInterval/time.Millisecond))...)
		}
	}()
}
Пример #2
0
func benchmarkVariesRoutineNumber(d *helpers.DockerHelper) {
	alive := d.GetContainerNum(false)
	dead := d.GetContainerNum(true) - alive
	containerIDs := d.GetContainerIDs()
	cfg := variesRoutineNumConfig
	routines := cfg["routines"].([]int)
	period := cfg["period"].(time.Duration)

	func() {
		defer d.LogError()
		listInterval := cfg["list interval"].(time.Duration)
		helpers.LogTitle("list_all")
		helpers.LogEVar(map[string]interface{}{
			"#alive":   alive,
			"#dead":    dead,
			"all":      true,
			"interval": listInterval,
			"period":   period,
		})
		helpers.LogLabels("#routines")
		for _, curRoutineNumber := range routines {
			latencies := d.DoParallelListContainerBenchmark(listInterval, period, curRoutineNumber, true)
			helpers.LogResult(latencies, helpers.Itoas(curRoutineNumber)...)
		}
	}()

	func() {
		defer d.LogError()
		inspectInterval := cfg["inspect interval"].(time.Duration)
		helpers.LogTitle("inspect")
		helpers.LogEVar(map[string]interface{}{
			"#alive":   alive,
			"#dead":    dead,
			"interval": inspectInterval,
			"period":   period,
		})
		helpers.LogLabels("#routines")
		for _, curRoutineNumber := range routines {
			latencies := d.DoParallelInspectContainerBenchmark(inspectInterval, period, curRoutineNumber, containerIDs)
			helpers.LogResult(latencies, helpers.Itoas(curRoutineNumber)...)
		}
	}()
}