Skip to content
Snippets Groups Projects
Select Git revision
  • 0f86d313da0c03dd94e1add7e18ddede0332d999
  • main default protected
  • next
  • renovate/main-ghcr.io-renovatebot-base-image-10.x
  • renovate/main-ghcr.io-containerbase-devcontainer-13.x
  • revert-31645-feat/rename-gradle-wrapper-validation-action
  • renovate/main-redis-5.x
  • fix/36615b-branch-reuse-no-cache
  • chore/punycode
  • fix/36615-branch-reuse-bug
  • refactor/pin-new-value
  • feat/36219--git-x509-signing
  • feat/structured-logger
  • hotfix/39.264.1
  • feat/skip-dangling
  • gh-readonly-queue/next/pr-36034-7a061c4ca1024a19e2c295d773d9642625d1c2be
  • hotfix/39.238.3
  • refactor/gitlab-auto-approve
  • feat/template-strings
  • gh-readonly-queue/next/pr-35654-137d934242c784e0c45d4b957362214f0eade1d7
  • fix/32307-global-extends-merging
  • 41.32.1
  • 41.32.0
  • 41.31.1
  • 41.31.0
  • 41.30.5
  • 41.30.4
  • 41.30.3
  • 41.30.2
  • 41.30.1
  • 41.30.0
  • 41.29.1
  • 41.29.0
  • 41.28.2
  • 41.28.1
  • 41.28.0
  • 41.27.1
  • 41.27.0
  • 41.26.2
  • 41.26.1
  • 41.26.0
41 results

comment.ts

Blame
  • stats.ts 2.23 KiB
    import URL from 'url';
    import { logger } from '../../logger';
    import * as memCache from '../../util/cache/memory';
    import type { RequestStats } from '../../util/http/types';
    
    export function printRequestStats(): void {
      const httpRequests = memCache.get<RequestStats[]>('http-requests');
      // istanbul ignore next
      if (!httpRequests) {
        return;
      }
      httpRequests.sort((a, b) => {
        if (a.url === b.url) {
          return 0;
        }
        if (a.url < b.url) {
          return -1;
        }
        return 1;
      });
      const allRequests: string[] = [];
      const requestHosts: Record<string, RequestStats[]> = {};
      const rawUrls: Record<string, number> = {};
      for (const httpRequest of httpRequests) {
        const { method, url, duration, queueDuration } = httpRequest;
        const [baseUrl] = url.split('?');
        // put method last for better sorting
        const urlKey = `${baseUrl} (${method.toUpperCase()})`;
        if (rawUrls[urlKey]) {
          rawUrls[urlKey] += 1;
        } else {
          rawUrls[urlKey] = 1;
        }
        allRequests.push(
          `${method.toUpperCase()} ${url} ${duration} ${queueDuration}`
        );
        const { hostname } = URL.parse(url);
        requestHosts[hostname] = requestHosts[hostname] || [];
        requestHosts[hostname].push(httpRequest);
      }
      const urls: Record<string, number> = {};
      // Sort urls for easier reading
      for (const url of Object.keys(rawUrls).sort()) {
        urls[url] = rawUrls[url];
      }
      logger.trace({ allRequests, requestHosts }, 'full stats');
      type HostStats = {
        requestCount: number;
        requestAvgMs: number;
        queueAvgMs: number;
      };
      const hostStats: Record<string, HostStats> = {};
      let totalRequests = 0;
      for (const [hostname, requests] of Object.entries(requestHosts)) {
        const requestCount = requests.length;
        totalRequests += requestCount;
        const requestSum = requests
          .map(({ duration }) => duration)
          .reduce((a, b) => a + b, 0);
        const requestAvgMs = Math.round(requestSum / requestCount);
    
        const queueSum = requests
          .map(({ queueDuration }) => queueDuration)
          .reduce((a, b) => a + b, 0);
        const queueAvgMs = Math.round(queueSum / requestCount);
        hostStats[hostname] = { requestCount, requestAvgMs, queueAvgMs };
      }
      logger.debug({ urls, hostStats, totalRequests }, 'http statistics');
    }