This commit is contained in:
zino
2025-08-14 19:25:30 +02:00
parent c40f1e41a1
commit c415d8af33

View File

@@ -2,6 +2,10 @@ counter registry_requests_total by path_class, repo, node
counter registry_pull_blob_bytes_total by repo, user, node
counter registry_pull_blob_seconds_total by repo, user, node
counter registry_push_upload_bytes_total by repo, user, node
gauge registry_push_session_speed_mbps by repo, user, node
hidden push_session_bytes by repo, user, node
hidden push_session_start by repo, user, node
/"remote_address":"(?P<node>[^"]*)".*"remote_user":"(?P<user>[^"]*)".*"method":"GET".*"path":"\/v2\/(?P<repo>.+?)\/blobs\/sha256:[a-f0-9]+".*"body_bytes_sent":(?P<body>\d+).*"request_time":(?P<rt>[0-9.]+)/ {
registry_pull_blob_bytes_total[$repo][$user][$node] += $body
@@ -10,23 +14,38 @@ counter registry_push_upload_bytes_total by repo, user, node
}
/"remote_address":"(?P<node>[^"]*)".*"remote_user":"(?P<user>[^"]*)".*"method":"PATCH".*"path":"\/v2\/(?P<repo>.+?)\/blobs\/uploads\/[a-f0-9-]+".*"upstream_range":"(?P<start>\d+)-(?P<end>\d+)".*"request_time":(?P<rt>[0-9.]+)/ {
registry_push_upload_bytes_total[$repo][$user][$node] += int($end) - int($start) + 1
bytes = int($end) - int($start) + 1
registry_push_upload_bytes_total[$repo][$user][$node] += bytes
push_session_bytes[$repo][$user][$node] += bytes
if push_session_start[$repo][$user][$node] == 0 {
push_session_start[$repo][$user][$node] = time()
}
registry_requests_total["push_upload"][$repo][$node]++
}
/"remote_address":"(?P<node>[^"]*)".*"remote_user":"(?P<user>[^"]*)".*"method":"PATCH".*"path":"\/v2\/(?P<repo>.+?)\/blobs\/uploads\/[a-f0-9-]+".*"upstream_range":"" .*"request_length":(?P<req>\d+)/ {
registry_push_upload_bytes_total[$repo][$user][$node] += $req
push_session_bytes[$repo][$user][$node] += $req
if push_session_start[$repo][$user][$node] == 0 {
push_session_start[$repo][$user][$node] = time()
}
registry_requests_total["push_upload"][$repo][$node]++
}
/"remote_address":"(?P<node>[^"]*)".*"method":"PUT".*"path":"\/v2\/(?P<repo>.+?)\/manifests\/[^"]+"/ {
registry_requests_total["push_manifest"][$repo][$node]++
duration = time() - push_session_start[$repo][$user][$node]
if duration > 0 && push_session_bytes[$repo][$user][$node] > 0 {
registry_push_session_speed_mbps[$repo][$user][$node] = (push_session_bytes[$repo][$user][$node] * 8) / duration / 1e6
}
push_session_bytes[$repo][$user][$node] = 0
push_session_start[$repo][$user][$node] = 0
}
/"remote_address":"(?P<node>[^"]*)".*"method":"GET".*"path":"\/v2\/(?P<repo>.+?)\/manifests\/[^"]+"/ {
registry_requests_total["pull_manifest"][$repo][$node]++
}
/"remote_address":"(?P<node>[^"]*)".*"method":"PUT".*"path":"\/v2\/(?P<repo>.+?)\/manifests\/[^"]+"/ {
registry_requests_total["push_manifest"][$repo][$node]++
}
/"remote_address":"(?P<node>[^"]*)".*"path":"\/v2\/".*"method":"\w+"/ {
registry_requests_total["v2_root"]["none"][$node]++
}