1 /* 2 * P2PFaaS - A framework for FaaS Load Balancing 3 * Copyright (c) 2019 - 2022. Gabriele Proietti Mattia <pm.gabriele@outlook.com> 4 * 5 * This program is free software: you can redistribute it and/or modify 6 * it under the terms of the GNU General Public License as published by 7 * the Free Software Foundation, either version 3 of the License, or 8 * (at your option) any later version. 9 * 10 * This program is distributed in the hope that it will be useful, 11 * but WITHOUT ANY WARRANTY; without even the implied warranty of 12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 13 * GNU General Public License for more details. 14 * 15 * You should have received a copy of the GNU General Public License 16 * along with this program. If not, see <https://www.gnu.org/licenses/>. 17 */ 18 19 package queue 20 21 import ( 22 "scheduler/types" 23 "scheduler/utils" 24 ) 25 26 type QueuedJob struct { 27 Request *types.ServiceRequest 28 Semaphore *utils.Semaphore 29 Response *types.FaasApiResponse 30 ErrorExecution bool 31 Timings *Timings 32 } 33 34 type Timings struct { 35 ExecutionTime float64 `json:"execution_time"` // the time of executing the job comprising the GET to openfaas 36 FaasExecutionTime float64 `json:"faas_execution_time"` // the execution time as it is told by openfaas 37 QueueTime float64 `json:"queue_time"` // the time in which the job remains in the local queue (comprises the execution time) 38 // ForwardingTime float64 `json:"forwarding_time"` // total time for forwarding the job to another machine 39 // ProbingTime float64 `json:"probing_time"` // average of time for probing all machines in the fanout (if applicable) 40 } 41