mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
* wip: restructure to monorepo Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com> * refactor create-release-pr to a package Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com> * build fixes Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com> * github workflow fixes Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com> * fix typo Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com> * add webpack-env types to core Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com> * fix github workflows Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com> * refactor/fix integration tests Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com> * lint fix Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com> * yarn run dev Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com> * eslint settings for vscode Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com> * move templates to right package Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com> * open-lens build fixes Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com> * integration test fix Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com> * fix nx task dependencies Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com> * use bash shell for unit tests in test workflow Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com> * fix test:unit for windows Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com> * fix win-ca webpack error in open-lens Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com> * fix win-ca webpack error in open-lens Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com> * fix build:app on windows Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com> * remove ELECTRON_BUILDER_EXTRA_ARGS Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com> * sync src/ from master Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com> * remove Makefile from core Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com> Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com>
147 lines
8.4 KiB
TypeScript
147 lines
8.4 KiB
TypeScript
/**
|
|
* Copyright (c) OpenLens Authors. All rights reserved.
|
|
* Licensed under MIT License. See LICENSE in root directory for more information.
|
|
*/
|
|
|
|
import type { PrometheusProvider } from "./provider";
|
|
import { createPrometheusProvider, bytesSent, findFirstNamespacedService, prometheusProviderInjectionToken } from "./provider";
|
|
import { getInjectable } from "@ogre-tools/injectable";
|
|
|
|
export const getHelmLikeQueryFor = ({ rateAccuracy }: { rateAccuracy: string }): PrometheusProvider["getQuery"] => (
|
|
(opts, queryName) => {
|
|
switch(opts.category) {
|
|
case "cluster":
|
|
switch (queryName) {
|
|
case "memoryUsage":
|
|
return `sum(node_memory_MemTotal_bytes - (node_memory_MemFree_bytes + node_memory_Buffers_bytes + node_memory_Cached_bytes)) by (component)`.replace(/_bytes/g, `_bytes{node=~"${opts.nodes}"}`);
|
|
case "workloadMemoryUsage":
|
|
return `sum(container_memory_working_set_bytes{container!="POD",container!="",instance=~"${opts.nodes}"}) by (component)`;
|
|
case "memoryRequests":
|
|
return `sum(kube_pod_container_resource_requests{node=~"${opts.nodes}", resource="memory"}) by (component)`;
|
|
case "memoryLimits":
|
|
return `sum(kube_pod_container_resource_limits{node=~"${opts.nodes}", resource="memory"}) by (component)`;
|
|
case "memoryCapacity":
|
|
return `sum(kube_node_status_capacity{node=~"${opts.nodes}", resource="memory"}) by (component)`;
|
|
case "memoryAllocatableCapacity":
|
|
return `sum(kube_node_status_allocatable{node=~"${opts.nodes}", resource="memory"}) by (component)`;
|
|
case "cpuUsage":
|
|
return `sum(rate(node_cpu_seconds_total{node=~"${opts.nodes}", mode=~"user|system"}[${rateAccuracy}]))`;
|
|
case "cpuRequests":
|
|
return `sum(kube_pod_container_resource_requests{node=~"${opts.nodes}", resource="cpu"}) by (component)`;
|
|
case "cpuLimits":
|
|
return `sum(kube_pod_container_resource_limits{node=~"${opts.nodes}", resource="cpu"}) by (component)`;
|
|
case "cpuCapacity":
|
|
return `sum(kube_node_status_capacity{node=~"${opts.nodes}", resource="cpu"}) by (component)`;
|
|
case "cpuAllocatableCapacity":
|
|
return `sum(kube_node_status_allocatable{node=~"${opts.nodes}", resource="cpu"}) by (component)`;
|
|
case "podUsage":
|
|
return `sum({__name__=~"kubelet_running_pod_count|kubelet_running_pods", instance=~"${opts.nodes}"})`;
|
|
case "podCapacity":
|
|
return `sum(kube_node_status_capacity{node=~"${opts.nodes}", resource="pods"}) by (component)`;
|
|
case "podAllocatableCapacity":
|
|
return `sum(kube_node_status_allocatable{node=~"${opts.nodes}", resource="pods"}) by (component)`;
|
|
case "fsSize":
|
|
return `sum(node_filesystem_size_bytes{node=~"${opts.nodes}", mountpoint="/"}) by (node)`;
|
|
case "fsUsage":
|
|
return `sum(node_filesystem_size_bytes{node=~"${opts.nodes}", mountpoint="/"} - node_filesystem_avail_bytes{node=~"${opts.nodes}", mountpoint="/"}) by (node)`;
|
|
}
|
|
break;
|
|
case "nodes":
|
|
switch (queryName) {
|
|
case "memoryUsage":
|
|
return `sum(node_memory_MemTotal_bytes - (node_memory_MemFree_bytes + node_memory_Buffers_bytes + node_memory_Cached_bytes)) by (node)`;
|
|
case "workloadMemoryUsage":
|
|
return `sum(container_memory_working_set_bytes{container!="POD",container!=""}) by (instance)`;
|
|
case "memoryCapacity":
|
|
return `sum(kube_node_status_capacity{resource="memory"}) by (node)`;
|
|
case "memoryAllocatableCapacity":
|
|
return `sum(kube_node_status_allocatable{resource="memory"}) by (node)`;
|
|
case "cpuUsage":
|
|
return `sum(rate(node_cpu_seconds_total{mode=~"user|system"}[${rateAccuracy}])) by(node)`;
|
|
case "cpuCapacity":
|
|
return `sum(kube_node_status_allocatable{resource="cpu"}) by (node)`;
|
|
case "cpuAllocatableCapacity":
|
|
return `sum(kube_node_status_allocatable{resource="cpu"}) by (node)`;
|
|
case "fsSize":
|
|
return `sum(node_filesystem_size_bytes{mountpoint="/"}) by (node)`;
|
|
case "fsUsage":
|
|
return `sum(node_filesystem_size_bytes{mountpoint="/"} - node_filesystem_avail_bytes{mountpoint="/"}) by (node)`;
|
|
}
|
|
break;
|
|
case "pods":
|
|
switch (queryName) {
|
|
case "cpuUsage":
|
|
return `sum(rate(container_cpu_usage_seconds_total{container!="POD",container!="",pod=~"${opts.pods}",namespace="${opts.namespace}"}[${rateAccuracy}])) by (${opts.selector})`;
|
|
case "cpuRequests":
|
|
return `sum(kube_pod_container_resource_requests{pod=~"${opts.pods}",resource="cpu",namespace="${opts.namespace}"}) by (${opts.selector})`;
|
|
case "cpuLimits":
|
|
return `sum(kube_pod_container_resource_limits{pod=~"${opts.pods}",resource="cpu",namespace="${opts.namespace}"}) by (${opts.selector})`;
|
|
case "memoryUsage":
|
|
return `sum(container_memory_working_set_bytes{container!="POD",container!="",pod=~"${opts.pods}",namespace="${opts.namespace}"}) by (${opts.selector})`;
|
|
case "memoryRequests":
|
|
return `sum(kube_pod_container_resource_requests{pod=~"${opts.pods}",resource="memory",namespace="${opts.namespace}"}) by (${opts.selector})`;
|
|
case "memoryLimits":
|
|
return `sum(kube_pod_container_resource_limits{pod=~"${opts.pods}",resource="memory",namespace="${opts.namespace}"}) by (${opts.selector})`;
|
|
case "fsUsage":
|
|
return `sum(container_fs_usage_bytes{container!="POD",container!="",pod=~"${opts.pods}",namespace="${opts.namespace}"}) by (${opts.selector})`;
|
|
case "fsWrites":
|
|
return `sum(rate(container_fs_writes_bytes_total{container!="", pod=~"${opts.pods}", namespace="${opts.namespace}"}[${rateAccuracy}])) by (${opts.selector})`;
|
|
case "fsReads":
|
|
return `sum(rate(container_fs_reads_bytes_total{container!="", pod=~"${opts.pods}", namespace="${opts.namespace}"}[${rateAccuracy}])) by (${opts.selector})`;
|
|
case "networkReceive":
|
|
return `sum(rate(container_network_receive_bytes_total{pod=~"${opts.pods}",namespace="${opts.namespace}"}[${rateAccuracy}])) by (${opts.selector})`;
|
|
case "networkTransmit":
|
|
return `sum(rate(container_network_transmit_bytes_total{pod=~"${opts.pods}",namespace="${opts.namespace}"}[${rateAccuracy}])) by (${opts.selector})`;
|
|
}
|
|
break;
|
|
case "pvc":
|
|
switch (queryName) {
|
|
case "diskUsage":
|
|
return `sum(kubelet_volume_stats_used_bytes{persistentvolumeclaim="${opts.pvc}",namespace="${opts.namespace}"}) by (persistentvolumeclaim, namespace)`;
|
|
case "diskCapacity":
|
|
return `sum(kubelet_volume_stats_capacity_bytes{persistentvolumeclaim="${opts.pvc}",namespace="${opts.namespace}"}) by (persistentvolumeclaim, namespace)`;
|
|
}
|
|
break;
|
|
case "ingress":
|
|
switch (queryName) {
|
|
case "bytesSentSuccess":
|
|
return bytesSent({
|
|
rateAccuracy,
|
|
ingress: opts.ingress,
|
|
namespace: opts.namespace,
|
|
statuses: "^2\\\\d*",
|
|
});
|
|
case "bytesSentFailure":
|
|
return bytesSent({
|
|
rateAccuracy,
|
|
ingress: opts.ingress,
|
|
namespace: opts.namespace,
|
|
statuses: "^5\\\\d*",
|
|
});
|
|
case "requestDurationSeconds":
|
|
return `sum(rate(nginx_ingress_controller_request_duration_seconds_sum{ingress="${opts.ingress}",namespace="${opts.namespace}"}[${rateAccuracy}])) by (ingress, namespace)`;
|
|
case "responseDurationSeconds":
|
|
return `sum(rate(nginx_ingress_controller_response_duration_seconds_sum{ingress="${opts.ingress}",namespace="${opts.namespace}"}[${rateAccuracy}])) by (ingress, namespace)`;
|
|
}
|
|
break;
|
|
}
|
|
|
|
throw new Error(`Unknown queryName="${queryName}" for category="${opts.category}"`);
|
|
}
|
|
);
|
|
|
|
const helmPrometheusProviderInjectable = getInjectable({
|
|
id: "helm-prometheus-provider",
|
|
instantiate: () => createPrometheusProvider({
|
|
kind: "helm",
|
|
name: "Helm",
|
|
isConfigurable: true,
|
|
getQuery: getHelmLikeQueryFor({ rateAccuracy: "5m" }),
|
|
getService: (client) => findFirstNamespacedService(client, "app=prometheus,component=server,heritage=Helm"),
|
|
}),
|
|
injectionToken: prometheusProviderInjectionToken,
|
|
});
|
|
|
|
export default helmPrometheusProviderInjectable;
|
|
|