This commit is contained in:
zino
2025-08-13 16:18:41 +02:00
parent 00d00e8b7f
commit 442a16e9e0

View File

@@ -7,17 +7,37 @@ counter registry_push_upload_seconds_total by repo, user, node
/"method":"([A-Z]+)"/ { /"method":"([A-Z]+)"/ {
method = $1 method = $1
} }
"/path":"([^"]+)"/ { path = $1 } /"path":"([^"]+)"/ {
/"remote_address":"([^"]*)"/ { node = $1 } path = $1
/"remote_user":"([^"]*)"/ { user = $1 } }
/"status":([0-9]{3})/ { status = $1 } /"remote_address":"([^"]*)"/ {
/"request_time":([0-9.]+)/ { request_time = $1 } node = $1
/"body_bytes_sent":([0-9]+)/ { body_bytes_sent = $1 } }
/"upstream_range":"([^"]*)"/ { up_range = $1 } /"remote_user":"([^"]*)"/ {
/"docker_upload_uuid":"([^"]*)"/ { upload_uuid = $1 } user = $1
/"docker_content_digest":"([^"]*)"/ { digest = $1 } }
/"status":([0-9]{3})/ {
status = $1
}
/"request_time":([0-9.]+)/ {
request_time = $1
}
/"body_bytes_sent":([0-9]+)/ {
body_bytes_sent = $1
}
/"upstream_range":"([^"]*)"/ {
up_range = $1
}
/"docker_upload_uuid":"([^"]*)"/ {
upload_uuid = $1
}
/"docker_content_digest":"([^"]*)"/ {
digest = $1
}
/"path":"\/v2\/(.+?)\/(blobs|manifests|tags|_catalog)/ { repo = $1 } /"path":"\/v2\/(.+?)\/(blobs|manifests|tags|_catalog)/ {
repo = $1
}
/$/ { /$/ {
repo == "" { repo = "unknown" } repo == "" { repo = "unknown" }
@@ -25,37 +45,41 @@ counter registry_push_upload_seconds_total by repo, user, node
node == "" { node = "unknown" } node == "" { node = "unknown" }
} }
/"upstream_range":"([0-9]+)-([0-9]+)"/ { uploaded_bytes = int($2) + 1 } /"upstream_range":"([0-9]+)-([0-9]+)"/ {
uploaded_bytes = int($2) + 1
}
/"method":"GET".*"\/v2\/.+\/blobs\/sha256:[a-f0-9]+"/ { /"method":"GET".*"\/v2\/.+\/blobs\/sha256:[a-f0-9]+"/ {
registry_pull_blob_bytes_total[repo][user][node] += body_bytes_sent registry_pull_blob_bytes_total[repo, user, node] += body_bytes_sent
registry_pull_blob_seconds_total[repo][user][node] += request_time registry_pull_blob_seconds_total[repo, user, node] += request_time
registry_requests_total[method]["pull_blob"][status][repo][user][node]++ registry_requests_total[method, "pull_blob", status, repo, user, node]++
} }
/"method":"PATCH".*"\/v2\/.+\/blobs\/uploads\/[a-f0-9-]+"/ { /"method":"PATCH".*"\/v2\/.+\/blobs\/uploads\/[a-f0-9-]+"/ {
uploaded_bytes > 0 { registry_push_upload_bytes_total[repo][user][node] += uploaded_bytes } uploaded_bytes > 0 {
registry_push_upload_seconds_total[repo][user][node] += request_time registry_push_upload_bytes_total[repo, user, node] += uploaded_bytes
registry_requests_total[method]["push_upload"][status][repo][user][node]++ }
registry_push_upload_seconds_total[repo, user, node] += request_time
registry_requests_total[method, "push_upload", status, repo, user, node]++
uploaded_bytes = 0 uploaded_bytes = 0
} }
/"method":"POST".*"\/v2\/.+\/blobs\/uploads\/"/ { /"method":"POST".*"\/v2\/.+\/blobs\/uploads\/"/ {
registry_requests_total[method]["push_start"][status][repo][user][node]++ registry_requests_total[method, "push_start", status, repo, user, node]++
} }
/"method":"PUT".*"\/v2\/.+\/blobs\/uploads\/[a-f0-9-]+"/ { /"method":"PUT".*"\/v2\/.+\/blobs\/uploads\/[a-f0-9-]+"/ {
registry_requests_total[method]["push_commit"][status][repo][user][node]++ registry_requests_total[method, "push_commit", status, repo, user, node]++
} }
/"method":"GET".*"\/v2\/.+\/manifests\/[^"]+"/ { /"method":"GET".*"\/v2\/.+\/manifests\/[^"]+"/ {
registry_requests_total[method]["pull_manifest"][status][repo][user][node]++ registry_requests_total[method, "pull_manifest", status, repo, user, node]++
} }
/"method":"PUT".*"\/v2\/.+\/manifests\/[^"]+"/ { /"method":"PUT".*"\/v2\/.+\/manifests\/[^"]+"/ {
registry_requests_total[method]["push_manifest"][status][repo][user][node]++ registry_requests_total[method, "push_manifest", status, repo, user, node]++
} }
/"path":"\/v2\/"/ { /"path":"\/v2\/"/ {
registry_requests_total[method]["v2_root"][status]["none"][user][node]++ registry_requests_total[method, "v2_root", status, "none", user, node]++
} }