swift-system-metrics

1.1.0

Report process-level system metrics (memory, CPU, file descriptors) to Swift Metrics
apple/swift-system-metrics

What's New

1.1.0

2026-03-26T17:09:30Z

What's Changed

SemVer Minor

Other Changes

  • [CI] Add automated release workflow using swift-temporal-sdk by @inductor in #93
  • Enable dependabot and switch GHA references to tags by @czechboy0 in #94
  • Bump actions/checkout from 4 to 6 by @dependabot[bot] in #95
  • Bump swiftlang/github-workflows/.github/workflows/soundness.yml from 0.0.7 to 0.0.8 by @dependabot[bot] in #99

New Contributors

Full Changelog: 1.0.1...1.1.0

Swift System Metrics

A Swift library for reporting process-level system metrics (memory, CPU, file descriptors) to Swift Metrics.

  • 📚 Documentation is available on the Swift Package Index.
  • 💻 Examples are available in the Examples directory.
  • 🚀 Contributions are welcome, please see CONTRIBUTING.md.
  • 🪪 License is Apache 2.0, repeated in LICENSE.
  • 🔒 Security issues should be reported via the process in SECURITY.md.

Overview

Swift System Metrics provides a type that periodically collects process-level system metrics and reports them to the Swift Metrics factory.

This package is designed to be run in tools and applications directly and is not expected to be used from libraries. If you'd like to report additional metrics from your library, use Swift Metrics directly.

Quick start

Add the dependency to your Package.swift:

.package(url: "https://github.com/apple/swift-system-metrics", from: "1.0.0")

Add the library dependency to your target:

.product(name: "SystemMetrics", package: "swift-system-metrics")

Import and use in your code:

import SystemMetrics
import ServiceLifecycle
import Metrics
import Logging

@main
struct Application {
  static func main() async throws {
    // Create a logger, or use one of the existing loggers
    let logger = Logger(label: "Application")
    let metrics = MyMetricsBackendImplementation()
    MetricsSystem.bootstrap(metrics)

    let service = FooService()
    // Create the monitor
    let systemMetricsMonitor = SystemMetricsMonitor(logger: logger)
    
    // Create the service
    let serviceGroup = ServiceGroup(
      services: [service, systemMetricsMonitor],
      gracefulShutdownSignals: [.sigint],
      cancellationSignals: [.sigterm],
      logger: logger
    )

    try await serviceGroup.run()
  }
}

Collected metrics

The monitor collects and reports the following metrics as gauges:

  • Virtual Memory: Total virtual memory, in bytes, that the process allocates.
    • Metric name: process_virtual_memory_bytes
  • Resident Memory: Physical memory, in bytes, that the process currently uses.
    • Metric name: process_resident_memory_bytes
  • Start Time: Process start time, in seconds, since UNIX epoch.
    • Metric name: process_start_time_seconds
  • CPU Time: Cumulative CPU time the process consumes, in seconds.
    • Metric name: process_cpu_seconds_total
  • Max File Descriptors: The maximum number of file descriptors the process can open.
    • Metric name: process_max_fds
  • Open File Descriptors: The number of file descriptors the process currently has open.
    • Metric name: process_open_fds

Supported platforms and minimum versions

The library is supported on macOS and Linux.

Component macOS Linux
SystemMetrics ✅ 13+ ✅

Documentation

Comprehensive documentation is hosted on the Swift Package Index.

Description

  • Swift Tools 6.0.0
View More Packages from this Author

Dependencies

Last updated: Mon Apr 06 2026 07:35:47 GMT-0900 (Hawaii-Aleutian Daylight Time)