2021-03-31 07:23:48 +02:00
|
|
|
type Job {
|
2021-04-14 17:57:19 +02:00
|
|
|
id: ID!
|
|
|
|
|
2021-03-31 07:23:48 +02:00
|
|
|
jobId: String!
|
|
|
|
userId: String!
|
|
|
|
projectId: String!
|
|
|
|
clusterId: String!
|
|
|
|
startTime: Time!
|
|
|
|
duration: Int!
|
|
|
|
numNodes: Int!
|
2021-04-12 14:01:59 +02:00
|
|
|
hasProfile: Boolean!
|
2021-04-14 17:57:19 +02:00
|
|
|
|
|
|
|
memUsed_max: Float
|
|
|
|
flopsAny_avg: Float
|
|
|
|
memBw_avg: Float
|
|
|
|
netBw_avg: Float
|
|
|
|
fileBw_avg: Float
|
2021-04-07 09:19:21 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
type JobMetric {
|
|
|
|
unit: String!
|
|
|
|
scope: JobMetricScope!
|
|
|
|
timestep: Int!
|
|
|
|
series: [JobMetricSeries]!
|
|
|
|
}
|
|
|
|
|
|
|
|
enum JobMetricScope {
|
|
|
|
node
|
|
|
|
cpu
|
|
|
|
socket
|
|
|
|
}
|
|
|
|
|
|
|
|
type JobMetricSeries {
|
|
|
|
node_id: String!
|
|
|
|
statistics: JobMetricStatistics
|
|
|
|
data: [Float]!
|
|
|
|
}
|
|
|
|
|
|
|
|
type JobMetricStatistics {
|
|
|
|
avg: Float!
|
|
|
|
min: Float!
|
|
|
|
max: Float!
|
|
|
|
}
|
|
|
|
|
2021-04-14 18:53:18 +02:00
|
|
|
type JobTag {
|
|
|
|
id: ID!
|
|
|
|
tagType: String!
|
|
|
|
tagName: String!
|
|
|
|
}
|
|
|
|
|
2021-03-31 07:23:48 +02:00
|
|
|
type Query {
|
|
|
|
jobById(jobId: String!): Job
|
|
|
|
jobs(filter: JobFilterList, page: PageRequest, order: OrderByInput): JobResultList!
|
|
|
|
jobsStatistics(filter: JobFilterList): JobsStatistics!
|
2021-04-12 14:01:59 +02:00
|
|
|
jobMetrics(jobId: String!, metrics: [String]): [JobMetricWithName]!
|
2021-04-14 18:53:18 +02:00
|
|
|
|
|
|
|
# Return all known tags or, if jobId is specified, only tags from this job
|
|
|
|
jobTags(jobId: String): [JobTag!]!
|
|
|
|
|
|
|
|
# For a tag ID, return the ID's of all jobs with that tag
|
|
|
|
jobsByTag(tag: ID!): [ID!]!
|
2021-03-31 07:23:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
input StartJobInput {
|
|
|
|
jobId: String!
|
|
|
|
userId: String!
|
|
|
|
projectId: String!
|
|
|
|
clusterId: String!
|
|
|
|
startTime: Time!
|
|
|
|
numNodes: Int!
|
|
|
|
}
|
|
|
|
|
|
|
|
input StopJobInput {
|
|
|
|
stopTime: Time!
|
|
|
|
}
|
|
|
|
|
|
|
|
input AddJobInput {
|
|
|
|
jobId: String!
|
|
|
|
userId: String!
|
|
|
|
projectId: String!
|
|
|
|
clusterId: String!
|
|
|
|
startTime: Time!
|
|
|
|
duration: Int!
|
|
|
|
numNodes: Int!
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
input JobFilterList {
|
|
|
|
list: [JobFilter]
|
|
|
|
}
|
|
|
|
|
|
|
|
input JobFilter {
|
|
|
|
jobId: StringInput
|
|
|
|
userId: StringInput
|
|
|
|
projectId: StringInput
|
|
|
|
clusterId: StringInput
|
|
|
|
duration: IntRange
|
|
|
|
numNodes: IntRange
|
|
|
|
startTime: TimeRange
|
|
|
|
hasProfile: Boolean
|
|
|
|
}
|
|
|
|
|
|
|
|
input OrderByInput {
|
|
|
|
field: String!
|
|
|
|
order: SortDirectionEnum = ASC
|
|
|
|
}
|
|
|
|
|
|
|
|
enum SortDirectionEnum {
|
|
|
|
DESC
|
|
|
|
ASC
|
|
|
|
}
|
|
|
|
|
|
|
|
input StringInput {
|
|
|
|
eq: String
|
|
|
|
contains: String
|
|
|
|
startsWith: String
|
|
|
|
endsWith: String
|
|
|
|
}
|
|
|
|
|
|
|
|
input IntRange {
|
|
|
|
from: Int!
|
|
|
|
to: Int!
|
|
|
|
}
|
|
|
|
|
|
|
|
input FloatRange {
|
|
|
|
from: Float!
|
|
|
|
to: Float!
|
|
|
|
}
|
|
|
|
|
|
|
|
input TimeRange {
|
|
|
|
from: Time!
|
|
|
|
to: Time!
|
|
|
|
}
|
|
|
|
|
|
|
|
type JobResultList {
|
|
|
|
items: [Job]!
|
|
|
|
offset: Int
|
|
|
|
limit: Int
|
|
|
|
count: Int
|
|
|
|
}
|
|
|
|
|
2021-04-07 09:19:21 +02:00
|
|
|
type JobMetricWithName {
|
|
|
|
name: String!
|
|
|
|
metric: JobMetric!
|
|
|
|
}
|
|
|
|
|
2021-03-31 07:23:48 +02:00
|
|
|
type HistoPoint {
|
|
|
|
count: Int!
|
|
|
|
value: Int!
|
|
|
|
}
|
|
|
|
|
|
|
|
type JobsStatistics {
|
|
|
|
totalJobs: Int!
|
|
|
|
shortJobs: Int!
|
|
|
|
totalWalltime: Int!
|
|
|
|
totalCoreHours: Int!
|
|
|
|
histWalltime: [HistoPoint]!
|
|
|
|
histNumNodes: [HistoPoint]!
|
|
|
|
}
|
|
|
|
|
|
|
|
input PageRequest {
|
2021-03-31 08:50:53 +02:00
|
|
|
itemsPerPage: Int
|
2021-03-31 07:23:48 +02:00
|
|
|
page: Int
|
|
|
|
}
|
|
|
|
|
|
|
|
scalar Time
|