github.com/containerd/containerd@v22.0.0-20200918172823-438c87b8e050+incompatible/metrics/cgroups/v2/memory.go (about) 1 // +build linux 2 3 /* 4 Copyright The containerd Authors. 5 6 Licensed under the Apache License, Version 2.0 (the "License"); 7 you may not use this file except in compliance with the License. 8 You may obtain a copy of the License at 9 10 http://www.apache.org/licenses/LICENSE-2.0 11 12 Unless required by applicable law or agreed to in writing, software 13 distributed under the License is distributed on an "AS IS" BASIS, 14 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 15 See the License for the specific language governing permissions and 16 limitations under the License. 17 */ 18 19 package v2 20 21 import ( 22 v2 "github.com/containerd/containerd/metrics/types/v2" 23 metrics "github.com/docker/go-metrics" 24 "github.com/prometheus/client_golang/prometheus" 25 ) 26 27 var memoryMetrics = []*metric{ 28 { 29 name: "memory_usage", 30 help: "Current memory usage (cgroup v2)", 31 unit: metrics.Bytes, 32 vt: prometheus.GaugeValue, 33 getValues: func(stats *v2.Metrics) []value { 34 if stats.Memory == nil { 35 return nil 36 } 37 return []value{ 38 { 39 v: float64(stats.Memory.Usage), 40 }, 41 } 42 }, 43 }, 44 { 45 name: "memory_usage_limit", 46 help: "Current memory usage limit (cgroup v2)", 47 unit: metrics.Bytes, 48 vt: prometheus.GaugeValue, 49 getValues: func(stats *v2.Metrics) []value { 50 if stats.Memory == nil { 51 return nil 52 } 53 return []value{ 54 { 55 v: float64(stats.Memory.UsageLimit), 56 }, 57 } 58 }, 59 }, 60 { 61 name: "memory_swap_usage", 62 help: "Current swap usage (cgroup v2)", 63 unit: metrics.Bytes, 64 vt: prometheus.GaugeValue, 65 getValues: func(stats *v2.Metrics) []value { 66 if stats.Memory == nil { 67 return nil 68 } 69 return []value{ 70 { 71 v: float64(stats.Memory.SwapUsage), 72 }, 73 } 74 }, 75 }, 76 { 77 name: "memory_swap_limit", 78 help: "Current swap usage limit (cgroup v2)", 79 unit: metrics.Bytes, 80 vt: prometheus.GaugeValue, 81 getValues: func(stats *v2.Metrics) []value { 82 if stats.Memory == nil { 83 return nil 84 } 85 return []value{ 86 { 87 v: float64(stats.Memory.SwapLimit), 88 }, 89 } 90 }, 91 }, 92 93 { 94 name: "memory_file_mapped", 95 help: "The file_mapped amount", 96 unit: metrics.Bytes, 97 vt: prometheus.GaugeValue, 98 getValues: func(stats *v2.Metrics) []value { 99 if stats.Memory == nil { 100 return nil 101 } 102 return []value{ 103 { 104 v: float64(stats.Memory.FileMapped), 105 }, 106 } 107 }, 108 }, 109 { 110 name: "memory_file_dirty", 111 help: "The file_dirty amount", 112 unit: metrics.Bytes, 113 vt: prometheus.GaugeValue, 114 getValues: func(stats *v2.Metrics) []value { 115 if stats.Memory == nil { 116 return nil 117 } 118 return []value{ 119 { 120 v: float64(stats.Memory.FileDirty), 121 }, 122 } 123 }, 124 }, 125 { 126 name: "memory_file_writeback", 127 help: "The file_writeback amount", 128 unit: metrics.Bytes, 129 vt: prometheus.GaugeValue, 130 getValues: func(stats *v2.Metrics) []value { 131 if stats.Memory == nil { 132 return nil 133 } 134 return []value{ 135 { 136 v: float64(stats.Memory.FileWriteback), 137 }, 138 } 139 }, 140 }, 141 { 142 name: "memory_pgactivate", 143 help: "The pgactivate amount", 144 unit: metrics.Bytes, 145 vt: prometheus.GaugeValue, 146 getValues: func(stats *v2.Metrics) []value { 147 if stats.Memory == nil { 148 return nil 149 } 150 return []value{ 151 { 152 v: float64(stats.Memory.Pgactivate), 153 }, 154 } 155 }, 156 }, 157 { 158 name: "memory_pgdeactivate", 159 help: "The pgdeactivate amount", 160 unit: metrics.Bytes, 161 vt: prometheus.GaugeValue, 162 getValues: func(stats *v2.Metrics) []value { 163 if stats.Memory == nil { 164 return nil 165 } 166 return []value{ 167 { 168 v: float64(stats.Memory.Pgdeactivate), 169 }, 170 } 171 }, 172 }, 173 { 174 name: "memory_pgfault", 175 help: "The pgfault amount", 176 unit: metrics.Bytes, 177 vt: prometheus.GaugeValue, 178 getValues: func(stats *v2.Metrics) []value { 179 if stats.Memory == nil { 180 return nil 181 } 182 return []value{ 183 { 184 v: float64(stats.Memory.Pgfault), 185 }, 186 } 187 }, 188 }, 189 { 190 name: "memory_pgmajfault", 191 help: "The pgmajfault amount", 192 unit: metrics.Bytes, 193 vt: prometheus.GaugeValue, 194 getValues: func(stats *v2.Metrics) []value { 195 if stats.Memory == nil { 196 return nil 197 } 198 return []value{ 199 { 200 v: float64(stats.Memory.Pgmajfault), 201 }, 202 } 203 }, 204 }, 205 { 206 name: "memory_pglazyfree", 207 help: "The pglazyfree amount", 208 unit: metrics.Bytes, 209 vt: prometheus.GaugeValue, 210 getValues: func(stats *v2.Metrics) []value { 211 if stats.Memory == nil { 212 return nil 213 } 214 return []value{ 215 { 216 v: float64(stats.Memory.Pglazyfree), 217 }, 218 } 219 }, 220 }, 221 { 222 name: "memory_pgrefill", 223 help: "The pgrefill amount", 224 unit: metrics.Bytes, 225 vt: prometheus.GaugeValue, 226 getValues: func(stats *v2.Metrics) []value { 227 if stats.Memory == nil { 228 return nil 229 } 230 return []value{ 231 { 232 v: float64(stats.Memory.Pgrefill), 233 }, 234 } 235 }, 236 }, 237 { 238 name: "memory_pglazyfreed", 239 help: "The pglazyfreed amount", 240 unit: metrics.Bytes, 241 vt: prometheus.GaugeValue, 242 getValues: func(stats *v2.Metrics) []value { 243 if stats.Memory == nil { 244 return nil 245 } 246 return []value{ 247 { 248 v: float64(stats.Memory.Pglazyfreed), 249 }, 250 } 251 }, 252 }, 253 { 254 name: "memory_pgscan", 255 help: "The pgscan amount", 256 unit: metrics.Bytes, 257 vt: prometheus.GaugeValue, 258 getValues: func(stats *v2.Metrics) []value { 259 if stats.Memory == nil { 260 return nil 261 } 262 return []value{ 263 { 264 v: float64(stats.Memory.Pgscan), 265 }, 266 } 267 }, 268 }, 269 { 270 name: "memory_pgsteal", 271 help: "The pgsteal amount", 272 unit: metrics.Bytes, 273 vt: prometheus.GaugeValue, 274 getValues: func(stats *v2.Metrics) []value { 275 if stats.Memory == nil { 276 return nil 277 } 278 return []value{ 279 { 280 v: float64(stats.Memory.Pgsteal), 281 }, 282 } 283 }, 284 }, 285 { 286 name: "memory_inactive_anon", 287 help: "The inactive_anon amount", 288 unit: metrics.Bytes, 289 vt: prometheus.GaugeValue, 290 getValues: func(stats *v2.Metrics) []value { 291 if stats.Memory == nil { 292 return nil 293 } 294 return []value{ 295 { 296 v: float64(stats.Memory.InactiveAnon), 297 }, 298 } 299 }, 300 }, 301 { 302 name: "memory_active_anon", 303 help: "The active_anon amount", 304 unit: metrics.Bytes, 305 vt: prometheus.GaugeValue, 306 getValues: func(stats *v2.Metrics) []value { 307 if stats.Memory == nil { 308 return nil 309 } 310 return []value{ 311 { 312 v: float64(stats.Memory.ActiveAnon), 313 }, 314 } 315 }, 316 }, 317 { 318 name: "memory_inactive_file", 319 help: "The inactive_file amount", 320 unit: metrics.Bytes, 321 vt: prometheus.GaugeValue, 322 getValues: func(stats *v2.Metrics) []value { 323 if stats.Memory == nil { 324 return nil 325 } 326 return []value{ 327 { 328 v: float64(stats.Memory.InactiveFile), 329 }, 330 } 331 }, 332 }, 333 { 334 name: "memory_active_file", 335 help: "The active_file amount", 336 unit: metrics.Bytes, 337 vt: prometheus.GaugeValue, 338 getValues: func(stats *v2.Metrics) []value { 339 if stats.Memory == nil { 340 return nil 341 } 342 return []value{ 343 { 344 v: float64(stats.Memory.ActiveFile), 345 }, 346 } 347 }, 348 }, 349 { 350 name: "memory_unevictable", 351 help: "The unevictable amount", 352 unit: metrics.Bytes, 353 vt: prometheus.GaugeValue, 354 getValues: func(stats *v2.Metrics) []value { 355 if stats.Memory == nil { 356 return nil 357 } 358 return []value{ 359 { 360 v: float64(stats.Memory.Unevictable), 361 }, 362 } 363 }, 364 }, 365 { 366 name: "memory_anon", 367 help: "The anon amount", 368 unit: metrics.Bytes, 369 vt: prometheus.GaugeValue, 370 getValues: func(stats *v2.Metrics) []value { 371 if stats.Memory == nil { 372 return nil 373 } 374 return []value{ 375 { 376 v: float64(stats.Memory.Anon), 377 }, 378 } 379 }, 380 }, 381 { 382 name: "memory_file", 383 help: "The file amount", 384 unit: metrics.Bytes, 385 vt: prometheus.GaugeValue, 386 getValues: func(stats *v2.Metrics) []value { 387 if stats.Memory == nil { 388 return nil 389 } 390 return []value{ 391 { 392 v: float64(stats.Memory.File), 393 }, 394 } 395 }, 396 }, 397 { 398 name: "memory_kernel_stack", 399 help: "The kernel_stack amount", 400 unit: metrics.Bytes, 401 vt: prometheus.GaugeValue, 402 getValues: func(stats *v2.Metrics) []value { 403 if stats.Memory == nil { 404 return nil 405 } 406 return []value{ 407 { 408 v: float64(stats.Memory.KernelStack), 409 }, 410 } 411 }, 412 }, 413 { 414 name: "memory_slab", 415 help: "The slab amount", 416 unit: metrics.Bytes, 417 vt: prometheus.GaugeValue, 418 getValues: func(stats *v2.Metrics) []value { 419 if stats.Memory == nil { 420 return nil 421 } 422 return []value{ 423 { 424 v: float64(stats.Memory.Slab), 425 }, 426 } 427 }, 428 }, 429 { 430 name: "memory_sock", 431 help: "The sock amount", 432 unit: metrics.Bytes, 433 vt: prometheus.GaugeValue, 434 getValues: func(stats *v2.Metrics) []value { 435 if stats.Memory == nil { 436 return nil 437 } 438 return []value{ 439 { 440 v: float64(stats.Memory.Sock), 441 }, 442 } 443 }, 444 }, 445 { 446 name: "memory_shmem", 447 help: "The shmem amount", 448 unit: metrics.Bytes, 449 vt: prometheus.GaugeValue, 450 getValues: func(stats *v2.Metrics) []value { 451 if stats.Memory == nil { 452 return nil 453 } 454 return []value{ 455 { 456 v: float64(stats.Memory.Shmem), 457 }, 458 } 459 }, 460 }, 461 { 462 name: "memory_anon_thp", 463 help: "The anon_thp amount", 464 unit: metrics.Bytes, 465 vt: prometheus.GaugeValue, 466 getValues: func(stats *v2.Metrics) []value { 467 if stats.Memory == nil { 468 return nil 469 } 470 return []value{ 471 { 472 v: float64(stats.Memory.AnonThp), 473 }, 474 } 475 }, 476 }, 477 { 478 name: "memory_slab_reclaimable", 479 help: "The slab_reclaimable amount", 480 unit: metrics.Bytes, 481 vt: prometheus.GaugeValue, 482 getValues: func(stats *v2.Metrics) []value { 483 if stats.Memory == nil { 484 return nil 485 } 486 return []value{ 487 { 488 v: float64(stats.Memory.SlabReclaimable), 489 }, 490 } 491 }, 492 }, 493 { 494 name: "memory_slab_unreclaimable", 495 help: "The slab_unreclaimable amount", 496 unit: metrics.Bytes, 497 vt: prometheus.GaugeValue, 498 getValues: func(stats *v2.Metrics) []value { 499 if stats.Memory == nil { 500 return nil 501 } 502 return []value{ 503 { 504 v: float64(stats.Memory.SlabUnreclaimable), 505 }, 506 } 507 }, 508 }, 509 { 510 name: "memory_workingset_refault", 511 help: "The workingset_refault amount", 512 unit: metrics.Bytes, 513 vt: prometheus.GaugeValue, 514 getValues: func(stats *v2.Metrics) []value { 515 if stats.Memory == nil { 516 return nil 517 } 518 return []value{ 519 { 520 v: float64(stats.Memory.WorkingsetRefault), 521 }, 522 } 523 }, 524 }, 525 { 526 name: "memory_workingset_activate", 527 help: "The workingset_activate amount", 528 unit: metrics.Bytes, 529 vt: prometheus.GaugeValue, 530 getValues: func(stats *v2.Metrics) []value { 531 if stats.Memory == nil { 532 return nil 533 } 534 return []value{ 535 { 536 v: float64(stats.Memory.WorkingsetActivate), 537 }, 538 } 539 }, 540 }, 541 { 542 name: "memory_workingset_nodereclaim", 543 help: "The workingset_nodereclaim amount", 544 unit: metrics.Bytes, 545 vt: prometheus.GaugeValue, 546 getValues: func(stats *v2.Metrics) []value { 547 if stats.Memory == nil { 548 return nil 549 } 550 return []value{ 551 { 552 v: float64(stats.Memory.WorkingsetNodereclaim), 553 }, 554 } 555 }, 556 }, 557 { 558 name: "memory_thp_fault_alloc", 559 help: "The thp_fault_alloc amount", 560 unit: metrics.Bytes, 561 vt: prometheus.GaugeValue, 562 getValues: func(stats *v2.Metrics) []value { 563 if stats.Memory == nil { 564 return nil 565 } 566 return []value{ 567 { 568 v: float64(stats.Memory.ThpFaultAlloc), 569 }, 570 } 571 }, 572 }, 573 { 574 name: "memory_thp_collapse_alloc", 575 help: "The thp_collapse_alloc amount", 576 unit: metrics.Bytes, 577 vt: prometheus.GaugeValue, 578 getValues: func(stats *v2.Metrics) []value { 579 if stats.Memory == nil { 580 return nil 581 } 582 return []value{ 583 { 584 v: float64(stats.Memory.ThpCollapseAlloc), 585 }, 586 } 587 }, 588 }, 589 { 590 name: "memory_oom", 591 help: "The number of times a container has received an oom event", 592 unit: metrics.Total, 593 vt: prometheus.GaugeValue, 594 getValues: func(stats *v2.Metrics) []value { 595 if stats.MemoryEvents == nil { 596 return nil 597 } 598 return []value{ 599 { 600 v: float64(stats.MemoryEvents.Oom), 601 }, 602 } 603 }, 604 }, 605 }