Start using Grafonnet to create Grafana dashboards
Versioning the pure JSON files representing the Grafana dashboards
had some disadvantages. It was hard to review them, they were very
cluttered and a lot was duplicated.
There are some tools that deal with that. One of them is Grafonnet,
which is a superset of Jsonnet, a tool to create JSON files using a
domain specific language.
This change implements the Gerrit Process dashboard in Grafonnet.
It also extends the installer to be able to install dashboards in
the Jsonnet format.
Change-Id: I6235fb7d045bd71557678a4e3b0d4ad4515f4615
This commit is contained in:
parent
baa386bd98
commit
ce5b8300f1
1
Pipfile
1
Pipfile
|
@ -13,6 +13,7 @@ pyyaml = "~=5.3"
|
|||
passlib = "~=1.7.2"
|
||||
python-gnupg = "~=0.4.5"
|
||||
requests = "~=2.23.0"
|
||||
jsonnet = "~=0.16.0"
|
||||
|
||||
[requires]
|
||||
python_version = "3.8"
|
||||
|
|
107
Pipfile.lock
generated
107
Pipfile.lock
generated
|
@ -1,7 +1,7 @@
|
|||
{
|
||||
"_meta": {
|
||||
"hash": {
|
||||
"sha256": "04289147b549a22aa59a430acffa91aec1ce904346f398e8e01093962f562cb7"
|
||||
"sha256": "567e752ac5b32023d7b9dbcff1c8b5613b4c4e9dc7d64cb69a2b22f3b9a8a521"
|
||||
},
|
||||
"pipfile-spec": 6,
|
||||
"requires": {
|
||||
|
@ -18,10 +18,10 @@
|
|||
"default": {
|
||||
"certifi": {
|
||||
"hashes": [
|
||||
"sha256:1d987a998c75633c40847cc966fcf5904906c920a7f17ef374f5aa4282abd304",
|
||||
"sha256:51fcb31174be6e6664c5f69e3e1691a2d72a1a12e90f872cbdb1567eb47b6519"
|
||||
"sha256:5930595817496dd21bb8dc35dad090f1c2cd0adfaf21204bf6732ca5d8ee34d3",
|
||||
"sha256:8fc0819f1f30ba15bdb34cceffb9ef04d99f420f68eb75d901e9560b8749fc41"
|
||||
],
|
||||
"version": "==2020.4.5.1"
|
||||
"version": "==2020.6.20"
|
||||
},
|
||||
"chardet": {
|
||||
"hashes": [
|
||||
|
@ -32,10 +32,17 @@
|
|||
},
|
||||
"idna": {
|
||||
"hashes": [
|
||||
"sha256:7588d1c14ae4c77d74036e8c22ff447b26d0fde8f007354fd48a7814db15b7cb",
|
||||
"sha256:a068a21ceac8a4d63dbfd964670474107f541babbd2250d61922f029858365fa"
|
||||
"sha256:b307872f855b18632ce0c21c5e45be78c0ea7ae4c15c828c20788b26921eb3f6",
|
||||
"sha256:b97d804b1e9b523befed77c48dacec60e6dcb0b5391d57af6a65a312a90648c0"
|
||||
],
|
||||
"version": "==2.9"
|
||||
"version": "==2.10"
|
||||
},
|
||||
"jsonnet": {
|
||||
"hashes": [
|
||||
"sha256:4d6eff8c17e146dccd244eda45317577cd5e264ce8d5d0676f1f36afdc01307e"
|
||||
],
|
||||
"index": "pypi",
|
||||
"version": "==0.16.0"
|
||||
},
|
||||
"passlib": {
|
||||
"hashes": [
|
||||
|
@ -47,11 +54,11 @@
|
|||
},
|
||||
"python-gnupg": {
|
||||
"hashes": [
|
||||
"sha256:3353e59949cd2c15efbf1fca45e347d8a22f4bed0d93e9b89b2657bda19cec05",
|
||||
"sha256:c095a41f310ad7a4fd393406660ac9bd6c175ccaa0f072f9c18f33be8130a27a"
|
||||
"sha256:3aa0884b3bd414652c2385b9df39e7b87272c2eca1b8fcc3089bc9e58652019a",
|
||||
"sha256:cba3566e8a8fb7bb417d6897a6e17bfc7f9371052e57eb0057783c07d762a679"
|
||||
],
|
||||
"index": "pypi",
|
||||
"version": "==0.4.5"
|
||||
"version": "==0.4.6"
|
||||
},
|
||||
"pyyaml": {
|
||||
"hashes": [
|
||||
|
@ -80,19 +87,19 @@
|
|||
},
|
||||
"urllib3": {
|
||||
"hashes": [
|
||||
"sha256:2f3db8b19923a873b3e5256dc9c2dedfa883e33d87c690d9c7913e1f40673cdc",
|
||||
"sha256:87716c2d2a7121198ebcb7ce7cccf6ce5e9ba539041cfbaeecfb641dc0bf6acc"
|
||||
"sha256:91056c15fa70756691db97756772bb1eb9678fa585d9184f24534b100dc60f4a",
|
||||
"sha256:e7983572181f5e1522d9c98453462384ee92a0be7fac5f1413a1e35c56cc0461"
|
||||
],
|
||||
"version": "==1.25.8"
|
||||
"version": "==1.25.10"
|
||||
}
|
||||
},
|
||||
"develop": {
|
||||
"appdirs": {
|
||||
"hashes": [
|
||||
"sha256:9e5896d1372858f8dd3344faf4e5014d21849c756c8d5701f78f8a103b372d92",
|
||||
"sha256:d8b24664561d0d34ddfaec54636d502d7cea6e29c3eaf68f3df6180863e2166e"
|
||||
"sha256:7d5d0167b2b1ba821647616af46a749d1c653740dd0d2415100fe26e27afdf41",
|
||||
"sha256:a841dacd6b99318a741b166adb07e19ee71a274450e68237b4650ca1055ab128"
|
||||
],
|
||||
"version": "==1.4.3"
|
||||
"version": "==1.4.4"
|
||||
},
|
||||
"astroid": {
|
||||
"hashes": [
|
||||
|
@ -103,10 +110,10 @@
|
|||
},
|
||||
"attrs": {
|
||||
"hashes": [
|
||||
"sha256:08a96c641c3a74e44eb59afb61a24f2cb9f4d7188748e76ba4bb5edfa3cb7d1c",
|
||||
"sha256:f7b7ce16570fe9965acd6d30101a28f62fb4a7f9e926b3bbc9b61f8b04247e72"
|
||||
"sha256:0ef97238856430dcf9228e07f316aefc17e8939fc8507e18c6501b761ef1a42a",
|
||||
"sha256:2867b7b9f8326499ab5b0e2d12801fa5c98842d2cbd22b35112ae04bf85b4dff"
|
||||
],
|
||||
"version": "==19.3.0"
|
||||
"version": "==20.1.0"
|
||||
},
|
||||
"black": {
|
||||
"hashes": [
|
||||
|
@ -118,10 +125,10 @@
|
|||
},
|
||||
"click": {
|
||||
"hashes": [
|
||||
"sha256:8a18b4ea89d8820c5d0c7da8a64b2c324b4dabb695804dbfea19b9be9d88c0cc",
|
||||
"sha256:e345d143d80bf5ee7534056164e5e112ea5e22716bbb1ce727941f4c8b471b9a"
|
||||
"sha256:d2b5255c7c6349bc1bd1e59e08cd12acbbd63ce649f2588755783aa94dfb6b1a",
|
||||
"sha256:dacca89f4bfadd5de3d7489b7c8a566eee0d3676333fbb50030263894c38c0dc"
|
||||
],
|
||||
"version": "==7.1.1"
|
||||
"version": "==7.1.2"
|
||||
},
|
||||
"isort": {
|
||||
"hashes": [
|
||||
|
@ -180,43 +187,43 @@
|
|||
},
|
||||
"regex": {
|
||||
"hashes": [
|
||||
"sha256:08119f707f0ebf2da60d2f24c2f39ca616277bb67ef6c92b72cbf90cbe3a556b",
|
||||
"sha256:0ce9537396d8f556bcfc317c65b6a0705320701e5ce511f05fc04421ba05b8a8",
|
||||
"sha256:1cbe0fa0b7f673400eb29e9ef41d4f53638f65f9a2143854de6b1ce2899185c3",
|
||||
"sha256:2294f8b70e058a2553cd009df003a20802ef75b3c629506be20687df0908177e",
|
||||
"sha256:23069d9c07e115537f37270d1d5faea3e0bdded8279081c4d4d607a2ad393683",
|
||||
"sha256:24f4f4062eb16c5bbfff6a22312e8eab92c2c99c51a02e39b4eae54ce8255cd1",
|
||||
"sha256:295badf61a51add2d428a46b8580309c520d8b26e769868b922750cf3ce67142",
|
||||
"sha256:2a3bf8b48f8e37c3a40bb3f854bf0121c194e69a650b209628d951190b862de3",
|
||||
"sha256:4385f12aa289d79419fede43f979e372f527892ac44a541b5446617e4406c468",
|
||||
"sha256:5635cd1ed0a12b4c42cce18a8d2fb53ff13ff537f09de5fd791e97de27b6400e",
|
||||
"sha256:5bfed051dbff32fd8945eccca70f5e22b55e4148d2a8a45141a3b053d6455ae3",
|
||||
"sha256:7e1037073b1b7053ee74c3c6c0ada80f3501ec29d5f46e42669378eae6d4405a",
|
||||
"sha256:90742c6ff121a9c5b261b9b215cb476eea97df98ea82037ec8ac95d1be7a034f",
|
||||
"sha256:a58dd45cb865be0ce1d5ecc4cfc85cd8c6867bea66733623e54bd95131f473b6",
|
||||
"sha256:c087bff162158536387c53647411db09b6ee3f9603c334c90943e97b1052a156",
|
||||
"sha256:c162a21e0da33eb3d31a3ac17a51db5e634fc347f650d271f0305d96601dc15b",
|
||||
"sha256:c9423a150d3a4fc0f3f2aae897a59919acd293f4cb397429b120a5fcd96ea3db",
|
||||
"sha256:ccccdd84912875e34c5ad2d06e1989d890d43af6c2242c6fcfa51556997af6cd",
|
||||
"sha256:e91ba11da11cf770f389e47c3f5c30473e6d85e06d7fd9dcba0017d2867aab4a",
|
||||
"sha256:ea4adf02d23b437684cd388d557bf76e3afa72f7fed5bbc013482cc00c816948",
|
||||
"sha256:fb95debbd1a824b2c4376932f2216cc186912e389bdb0e27147778cf6acb3f89"
|
||||
"sha256:0dc64ee3f33cd7899f79a8d788abfbec168410be356ed9bd30bbd3f0a23a7204",
|
||||
"sha256:1269fef3167bb52631ad4fa7dd27bf635d5a0790b8e6222065d42e91bede4162",
|
||||
"sha256:14a53646369157baa0499513f96091eb70382eb50b2c82393d17d7ec81b7b85f",
|
||||
"sha256:3a3af27a8d23143c49a3420efe5b3f8cf1a48c6fc8bc6856b03f638abc1833bb",
|
||||
"sha256:46bac5ca10fb748d6c55843a931855e2727a7a22584f302dd9bb1506e69f83f6",
|
||||
"sha256:4c037fd14c5f4e308b8370b447b469ca10e69427966527edcab07f52d88388f7",
|
||||
"sha256:51178c738d559a2d1071ce0b0f56e57eb315bcf8f7d4cf127674b533e3101f88",
|
||||
"sha256:5ea81ea3dbd6767873c611687141ec7b06ed8bab43f68fad5b7be184a920dc99",
|
||||
"sha256:6961548bba529cac7c07af2fd4d527c5b91bb8fe18995fed6044ac22b3d14644",
|
||||
"sha256:75aaa27aa521a182824d89e5ab0a1d16ca207318a6b65042b046053cfc8ed07a",
|
||||
"sha256:7a2dd66d2d4df34fa82c9dc85657c5e019b87932019947faece7983f2089a840",
|
||||
"sha256:8a51f2c6d1f884e98846a0a9021ff6861bdb98457879f412fdc2b42d14494067",
|
||||
"sha256:9c568495e35599625f7b999774e29e8d6b01a6fb684d77dee1f56d41b11b40cd",
|
||||
"sha256:9eddaafb3c48e0900690c1727fba226c4804b8e6127ea409689c3bb492d06de4",
|
||||
"sha256:bbb332d45b32df41200380fff14712cb6093b61bd142272a10b16778c418e98e",
|
||||
"sha256:bc3d98f621898b4a9bc7fecc00513eec8f40b5b83913d74ccb445f037d58cd89",
|
||||
"sha256:c11d6033115dc4887c456565303f540c44197f4fc1a2bfb192224a301534888e",
|
||||
"sha256:c50a724d136ec10d920661f1442e4a8b010a4fe5aebd65e0c2241ea41dbe93dc",
|
||||
"sha256:d0a5095d52b90ff38592bbdc2644f17c6d495762edf47d876049cfd2968fbccf",
|
||||
"sha256:d6cff2276e502b86a25fd10c2a96973fdb45c7a977dca2138d661417f3728341",
|
||||
"sha256:e46d13f38cfcbb79bfdb2964b0fe12561fe633caf964a77a5f8d4e45fe5d2ef7"
|
||||
],
|
||||
"version": "==2020.4.4"
|
||||
"version": "==2020.7.14"
|
||||
},
|
||||
"six": {
|
||||
"hashes": [
|
||||
"sha256:236bdbdce46e6e6a3d61a337c0f8b763ca1e8717c03b369e87a7ec7ce1319c0a",
|
||||
"sha256:8f3cd2e254d8f793e7f3d6d9df77b92252b52637291d0f0da013c76ea2724b6c"
|
||||
"sha256:30639c035cdb23534cd4aa2dd52c3bf48f06e5f4a941509c8bafd8ce11080259",
|
||||
"sha256:8b74bedcbbbaca38ff6d7491d76f2b06b3592611af620f8426e82dddb04a5ced"
|
||||
],
|
||||
"version": "==1.14.0"
|
||||
"version": "==1.15.0"
|
||||
},
|
||||
"toml": {
|
||||
"hashes": [
|
||||
"sha256:229f81c57791a41d65e399fc06bf0848bab550a9dfd5ed66df18ce5f05e73d5c",
|
||||
"sha256:235682dd292d5899d361a811df37e04a8828a5b1da3115886b73cf81ebc9100e"
|
||||
"sha256:926b612be1e5ce0634a2ca03470f95169cf16f939018233a670519cb4ac58b0f",
|
||||
"sha256:bda89d5935c2eac546d648028b9901107a595863cb36bae0c73ac804a9b4ce88"
|
||||
],
|
||||
"version": "==0.10.0"
|
||||
"version": "==0.10.1"
|
||||
},
|
||||
"typed-ast": {
|
||||
"hashes": [
|
||||
|
|
39
README.md
39
README.md
|
@ -48,6 +48,17 @@ based on a lock-file, ensuring a deterministic Python environment. Instruction o
|
|||
how Pipenv can be installed, can be found
|
||||
[here](https://github.com/pypa/pipenv#installation)
|
||||
|
||||
- Jsonnet \
|
||||
Jsonnet is used to create the JSON-files describing the Grafana dashboards.
|
||||
Instruction on how Jsonnet can be installed, can be found
|
||||
[here](https://github.com/google/jsonnet#packages)
|
||||
|
||||
- Grafonnet \
|
||||
Grafonnet should be installed using jsonnet-bundler and the `jsonnetfile.json`
|
||||
provided by this project. Install jsonnet-bundler as described
|
||||
[here](https://github.com/jsonnet-bundler/jsonnet-bundler#install). Then run
|
||||
`jb install` from this project's root directory.
|
||||
|
||||
### Infrastructure
|
||||
|
||||
- Kubernetes Cluster \
|
||||
|
@ -64,11 +75,29 @@ via the S3 API.
|
|||
|
||||
## Add dashboards
|
||||
|
||||
To have dashboards deployed automatically during installation, export the dashboards
|
||||
to a JSON-file or create JSON-files describing the dashboards in another way.
|
||||
Put these dashboards into the `./dashboards`-directory of this repository. During
|
||||
the installation the dashboards will be added to a configmap and with this
|
||||
automatically installed to Grafana.
|
||||
There are two ways to have dashboards deployed automatically during installation:
|
||||
|
||||
### Using JSON
|
||||
|
||||
One way is to export the dashboards to a JSON-file in the UI or create JSON-files
|
||||
describing the dashboards in another way. Put these dashboards into the
|
||||
`./dashboards`-directory of this repository.
|
||||
|
||||
### Using Jsonnet + Grafonnet
|
||||
|
||||
The other way is to use Jsonnet/Grafonnet to programmatically create dashboards.
|
||||
Install Grafonnet into the project as described above and put your dashboard
|
||||
jsonnet files into the dashboards-directory or one of its subdirectories. The
|
||||
jsonnet-based dashboards can be transcribed into json manually using the following
|
||||
command:
|
||||
|
||||
```sh
|
||||
jsonnet -J grafonnet-lib --ext-code publish=false dashboards/<dashboard>.jsonnet
|
||||
```
|
||||
|
||||
The external variable `publish` should be set to `false`, if the dashboard is
|
||||
imported via API and to `true`, if it is published to the Grafana homepage or
|
||||
imported via the UI.
|
||||
|
||||
## Configuration
|
||||
|
||||
|
|
|
@ -1,850 +0,0 @@
|
|||
{
|
||||
"__inputs": [
|
||||
{
|
||||
"name": "DS_PROMETHEUS",
|
||||
"label": "Prometheus",
|
||||
"description": "",
|
||||
"type": "datasource",
|
||||
"pluginId": "prometheus",
|
||||
"pluginName": "Prometheus"
|
||||
}
|
||||
],
|
||||
"__requires": [
|
||||
{
|
||||
"type": "grafana",
|
||||
"id": "grafana",
|
||||
"name": "Grafana",
|
||||
"version": "7.1.5"
|
||||
},
|
||||
{
|
||||
"type": "panel",
|
||||
"id": "graph",
|
||||
"name": "Graph",
|
||||
"version": ""
|
||||
},
|
||||
{
|
||||
"type": "datasource",
|
||||
"id": "prometheus",
|
||||
"name": "Prometheus",
|
||||
"version": "1.0.0"
|
||||
}
|
||||
],
|
||||
"annotations": {
|
||||
"list": [
|
||||
{
|
||||
"builtIn": 1,
|
||||
"datasource": "-- Grafana --",
|
||||
"enable": true,
|
||||
"hide": true,
|
||||
"iconColor": "rgba(0, 211, 255, 1)",
|
||||
"name": "Annotations & Alerts",
|
||||
"type": "dashboard"
|
||||
}
|
||||
]
|
||||
},
|
||||
"editable": true,
|
||||
"gnetId": null,
|
||||
"graphTooltip": 0,
|
||||
"links": [],
|
||||
"panels": [
|
||||
{
|
||||
"aliasColors": {},
|
||||
"bars": false,
|
||||
"dashLength": 10,
|
||||
"dashes": false,
|
||||
"datasource": "${DS_PROMETHEUS}",
|
||||
"fill": 1,
|
||||
"fillGradient": 0,
|
||||
"gridPos": {
|
||||
"h": 11,
|
||||
"w": 12,
|
||||
"x": 0,
|
||||
"y": 0
|
||||
},
|
||||
"hiddenSeries": false,
|
||||
"id": 14,
|
||||
"legend": {
|
||||
"alignAsTable": true,
|
||||
"avg": true,
|
||||
"current": true,
|
||||
"max": true,
|
||||
"min": true,
|
||||
"show": true,
|
||||
"total": false,
|
||||
"values": true
|
||||
},
|
||||
"lines": true,
|
||||
"linewidth": 1,
|
||||
"nullPointMode": "null",
|
||||
"options": {
|
||||
"dataLinks": []
|
||||
},
|
||||
"percentage": false,
|
||||
"pointradius": 2,
|
||||
"points": false,
|
||||
"renderer": "flot",
|
||||
"seriesOverrides": [],
|
||||
"spaceLength": 10,
|
||||
"stack": false,
|
||||
"steppedLine": false,
|
||||
"targets": [
|
||||
{
|
||||
"expr": "proc_cpu_system_load{instance=\"$instance\",replica=\"$replica\"}",
|
||||
"legendFormat": "system load",
|
||||
"refId": "A"
|
||||
}
|
||||
],
|
||||
"thresholds": [],
|
||||
"timeFrom": null,
|
||||
"timeRegions": [],
|
||||
"timeShift": null,
|
||||
"title": "System load",
|
||||
"tooltip": {
|
||||
"shared": true,
|
||||
"sort": 0,
|
||||
"value_type": "individual"
|
||||
},
|
||||
"type": "graph",
|
||||
"xaxis": {
|
||||
"buckets": null,
|
||||
"mode": "time",
|
||||
"name": null,
|
||||
"show": true,
|
||||
"values": []
|
||||
},
|
||||
"yaxes": [
|
||||
{
|
||||
"format": "short",
|
||||
"label": null,
|
||||
"logBase": 1,
|
||||
"max": null,
|
||||
"min": null,
|
||||
"show": true
|
||||
},
|
||||
{
|
||||
"format": "short",
|
||||
"label": null,
|
||||
"logBase": 1,
|
||||
"max": null,
|
||||
"min": null,
|
||||
"show": true
|
||||
}
|
||||
],
|
||||
"yaxis": {
|
||||
"align": false,
|
||||
"alignLevel": null
|
||||
}
|
||||
},
|
||||
{
|
||||
"aliasColors": {},
|
||||
"bars": false,
|
||||
"dashLength": 10,
|
||||
"dashes": false,
|
||||
"datasource": "${DS_PROMETHEUS}",
|
||||
"fill": 1,
|
||||
"fillGradient": 0,
|
||||
"gridPos": {
|
||||
"h": 11,
|
||||
"w": 12,
|
||||
"x": 12,
|
||||
"y": 0
|
||||
},
|
||||
"hiddenSeries": false,
|
||||
"id": 2,
|
||||
"legend": {
|
||||
"alignAsTable": true,
|
||||
"avg": true,
|
||||
"current": true,
|
||||
"max": true,
|
||||
"min": true,
|
||||
"rightSide": false,
|
||||
"show": true,
|
||||
"total": false,
|
||||
"values": true
|
||||
},
|
||||
"lines": true,
|
||||
"linewidth": 1,
|
||||
"nullPointMode": "null",
|
||||
"options": {
|
||||
"dataLinks": []
|
||||
},
|
||||
"percentage": false,
|
||||
"pointradius": 2,
|
||||
"points": false,
|
||||
"renderer": "flot",
|
||||
"seriesOverrides": [],
|
||||
"spaceLength": 10,
|
||||
"stack": false,
|
||||
"steppedLine": false,
|
||||
"targets": [
|
||||
{
|
||||
"expr": "proc_jvm_memory_heap_committed{instance=\"$instance\",replica=\"$replica\"}",
|
||||
"legendFormat": "committed heap",
|
||||
"refId": "C"
|
||||
},
|
||||
{
|
||||
"expr": "proc_jvm_memory_heap_used{instance=\"$instance\",replica=\"$replica\"}",
|
||||
"legendFormat": "used heap",
|
||||
"refId": "B"
|
||||
},
|
||||
{
|
||||
"expr": "jgit_block_cache_cache_used{instance=\"$instance\",replica=\"$replica\"}",
|
||||
"instant": false,
|
||||
"legendFormat": "JGit block cache",
|
||||
"refId": "A"
|
||||
},
|
||||
{
|
||||
"expr": "proc_jvm_memory_non_heap_used{instance=\"$instance\",replica=\"$replica\"}",
|
||||
"legendFormat": "used non-heap",
|
||||
"refId": "D"
|
||||
}
|
||||
],
|
||||
"thresholds": [],
|
||||
"timeFrom": null,
|
||||
"timeRegions": [],
|
||||
"timeShift": null,
|
||||
"title": "Memory",
|
||||
"tooltip": {
|
||||
"shared": true,
|
||||
"sort": 0,
|
||||
"value_type": "individual"
|
||||
},
|
||||
"type": "graph",
|
||||
"xaxis": {
|
||||
"buckets": null,
|
||||
"mode": "time",
|
||||
"name": null,
|
||||
"show": true,
|
||||
"values": []
|
||||
},
|
||||
"yaxes": [
|
||||
{
|
||||
"decimals": null,
|
||||
"format": "decbytes",
|
||||
"label": "Memory Consumption",
|
||||
"logBase": 1,
|
||||
"max": null,
|
||||
"min": null,
|
||||
"show": true
|
||||
},
|
||||
{
|
||||
"format": "short",
|
||||
"label": null,
|
||||
"logBase": 1,
|
||||
"max": null,
|
||||
"min": null,
|
||||
"show": true
|
||||
}
|
||||
],
|
||||
"yaxis": {
|
||||
"align": false,
|
||||
"alignLevel": null
|
||||
}
|
||||
},
|
||||
{
|
||||
"aliasColors": {},
|
||||
"bars": false,
|
||||
"dashLength": 10,
|
||||
"dashes": false,
|
||||
"datasource": "${DS_PROMETHEUS}",
|
||||
"fill": 1,
|
||||
"fillGradient": 0,
|
||||
"gridPos": {
|
||||
"h": 10,
|
||||
"w": 12,
|
||||
"x": 0,
|
||||
"y": 11
|
||||
},
|
||||
"hiddenSeries": false,
|
||||
"id": 4,
|
||||
"legend": {
|
||||
"alignAsTable": true,
|
||||
"avg": true,
|
||||
"current": true,
|
||||
"max": true,
|
||||
"min": true,
|
||||
"rightSide": false,
|
||||
"show": true,
|
||||
"sideWidth": 100,
|
||||
"total": false,
|
||||
"values": true
|
||||
},
|
||||
"lines": true,
|
||||
"linewidth": 1,
|
||||
"nullPointMode": "null",
|
||||
"options": {
|
||||
"dataLinks": []
|
||||
},
|
||||
"percentage": false,
|
||||
"pointradius": 2,
|
||||
"points": false,
|
||||
"renderer": "flot",
|
||||
"seriesOverrides": [
|
||||
{
|
||||
"alias": "available CPUs",
|
||||
"color": "#1F60C4",
|
||||
"fill": 0
|
||||
}
|
||||
],
|
||||
"spaceLength": 10,
|
||||
"stack": false,
|
||||
"steppedLine": false,
|
||||
"targets": [
|
||||
{
|
||||
"expr": "rate(proc_cpu_usage{instance=\"$instance\",replica=\"$replica\"}[5m])",
|
||||
"legendFormat": "used CPUs",
|
||||
"refId": "A"
|
||||
},
|
||||
{
|
||||
"expr": "proc_cpu_num_cores{instance=\"$instance\",replica=\"$replica\"}",
|
||||
"legendFormat": "available CPUs",
|
||||
"refId": "B"
|
||||
}
|
||||
],
|
||||
"thresholds": [],
|
||||
"timeFrom": null,
|
||||
"timeRegions": [],
|
||||
"timeShift": null,
|
||||
"title": "CPU",
|
||||
"tooltip": {
|
||||
"shared": true,
|
||||
"sort": 0,
|
||||
"value_type": "individual"
|
||||
},
|
||||
"type": "graph",
|
||||
"xaxis": {
|
||||
"buckets": null,
|
||||
"mode": "time",
|
||||
"name": null,
|
||||
"show": true,
|
||||
"values": []
|
||||
},
|
||||
"yaxes": [
|
||||
{
|
||||
"format": "short",
|
||||
"label": "CPU cores",
|
||||
"logBase": 1,
|
||||
"max": null,
|
||||
"min": null,
|
||||
"show": true
|
||||
},
|
||||
{
|
||||
"format": "short",
|
||||
"label": "",
|
||||
"logBase": 1,
|
||||
"max": null,
|
||||
"min": null,
|
||||
"show": true
|
||||
}
|
||||
],
|
||||
"yaxis": {
|
||||
"align": false,
|
||||
"alignLevel": null
|
||||
}
|
||||
},
|
||||
{
|
||||
"aliasColors": {},
|
||||
"bars": true,
|
||||
"dashLength": 10,
|
||||
"dashes": false,
|
||||
"datasource": "${DS_PROMETHEUS}",
|
||||
"decimals": 2,
|
||||
"fill": 6,
|
||||
"fillGradient": 0,
|
||||
"gridPos": {
|
||||
"h": 10,
|
||||
"w": 12,
|
||||
"x": 12,
|
||||
"y": 11
|
||||
},
|
||||
"hiddenSeries": false,
|
||||
"id": 6,
|
||||
"legend": {
|
||||
"alignAsTable": true,
|
||||
"avg": true,
|
||||
"current": true,
|
||||
"hideEmpty": true,
|
||||
"hideZero": true,
|
||||
"max": true,
|
||||
"min": true,
|
||||
"rightSide": false,
|
||||
"show": true,
|
||||
"total": false,
|
||||
"values": true
|
||||
},
|
||||
"lines": false,
|
||||
"linewidth": 1,
|
||||
"nullPointMode": "null",
|
||||
"options": {
|
||||
"dataLinks": []
|
||||
},
|
||||
"percentage": false,
|
||||
"pointradius": 2,
|
||||
"points": false,
|
||||
"renderer": "flot",
|
||||
"seriesOverrides": [
|
||||
{
|
||||
"alias": "gc time G1 old gen",
|
||||
"color": "#F2CC0C"
|
||||
},
|
||||
{
|
||||
"alias": "gc time G1 young gen",
|
||||
"color": "#3274D9"
|
||||
},
|
||||
{
|
||||
"alias": "gc time PS Scavange",
|
||||
"color": "#8AB8FF"
|
||||
},
|
||||
{
|
||||
"alias": "gc time PS MarkSweep",
|
||||
"color": "#E02F44"
|
||||
}
|
||||
],
|
||||
"spaceLength": 10,
|
||||
"stack": true,
|
||||
"steppedLine": false,
|
||||
"targets": [
|
||||
{
|
||||
"expr": "increase(proc_jvm_gc_time_G1_Young_Generation{instance=\"$instance\",replica=\"$replica\"}[2m])/increase(proc_uptime{instance=\"$instance\",replica=\"$replica\"}[2m])",
|
||||
"interval": "1m",
|
||||
"intervalFactor": 1,
|
||||
"legendFormat": "gc time G1 young gen",
|
||||
"refId": "B"
|
||||
},
|
||||
{
|
||||
"expr": "increase(proc_jvm_gc_time_G1_Old_Generation{instance=\"$instance\",replica=\"$replica\"}[2m])/increase(proc_uptime{instance=\"$instance\",replica=\"$replica\"}[2m])",
|
||||
"interval": "1m",
|
||||
"intervalFactor": 1,
|
||||
"legendFormat": "gc time G1 old gen",
|
||||
"refId": "A"
|
||||
},
|
||||
{
|
||||
"expr": "increase(proc_jvm_gc_time_PS_MarkSweep{instance=\"$instance\",replica=\"$replica\"}[2m])/increase(proc_uptime{instance=\"$instance\",replica=\"$replica\"}[2m])",
|
||||
"interval": "1m",
|
||||
"intervalFactor": 1,
|
||||
"legendFormat": "gc time PS MarkSweep",
|
||||
"refId": "C"
|
||||
},
|
||||
{
|
||||
"expr": "increase(proc_jvm_gc_time_PS_Scavenge{instance=\"$instance\",replica=\"$replica\"}[2m])/increase(proc_uptime{instance=\"$instance\",replica=\"$replica\"}[2m])",
|
||||
"interval": "1m",
|
||||
"intervalFactor": 1,
|
||||
"legendFormat": "gc time PS Scavange",
|
||||
"refId": "D"
|
||||
}
|
||||
],
|
||||
"thresholds": [],
|
||||
"timeFrom": null,
|
||||
"timeRegions": [],
|
||||
"timeShift": null,
|
||||
"title": "Java - % of time spent in GC",
|
||||
"tooltip": {
|
||||
"shared": true,
|
||||
"sort": 0,
|
||||
"value_type": "individual"
|
||||
},
|
||||
"type": "graph",
|
||||
"xaxis": {
|
||||
"buckets": null,
|
||||
"mode": "time",
|
||||
"name": null,
|
||||
"show": true,
|
||||
"values": []
|
||||
},
|
||||
"yaxes": [
|
||||
{
|
||||
"format": "percentunit",
|
||||
"label": "GC Time",
|
||||
"logBase": 1,
|
||||
"max": null,
|
||||
"min": null,
|
||||
"show": true
|
||||
},
|
||||
{
|
||||
"format": "short",
|
||||
"label": null,
|
||||
"logBase": 1,
|
||||
"max": null,
|
||||
"min": null,
|
||||
"show": true
|
||||
}
|
||||
],
|
||||
"yaxis": {
|
||||
"align": false,
|
||||
"alignLevel": null
|
||||
}
|
||||
},
|
||||
{
|
||||
"aliasColors": {},
|
||||
"bars": false,
|
||||
"dashLength": 10,
|
||||
"dashes": false,
|
||||
"datasource": "${DS_PROMETHEUS}",
|
||||
"description": "",
|
||||
"fill": 1,
|
||||
"fillGradient": 0,
|
||||
"gridPos": {
|
||||
"h": 10,
|
||||
"w": 12,
|
||||
"x": 0,
|
||||
"y": 21
|
||||
},
|
||||
"hiddenSeries": false,
|
||||
"id": 8,
|
||||
"legend": {
|
||||
"alignAsTable": true,
|
||||
"avg": true,
|
||||
"current": true,
|
||||
"max": true,
|
||||
"min": true,
|
||||
"show": true,
|
||||
"total": false,
|
||||
"values": true
|
||||
},
|
||||
"lines": true,
|
||||
"linewidth": 1,
|
||||
"nullPointMode": "null",
|
||||
"options": {
|
||||
"dataLinks": []
|
||||
},
|
||||
"percentage": false,
|
||||
"pointradius": 2,
|
||||
"points": false,
|
||||
"renderer": "flot",
|
||||
"seriesOverrides": [],
|
||||
"spaceLength": 10,
|
||||
"stack": false,
|
||||
"steppedLine": false,
|
||||
"targets": [
|
||||
{
|
||||
"expr": "proc_jvm_thread_num_live{instance=\"$instance\",replica=\"$replica\"}",
|
||||
"legendFormat": "Java live threads",
|
||||
"refId": "A"
|
||||
}
|
||||
],
|
||||
"thresholds": [],
|
||||
"timeFrom": null,
|
||||
"timeRegions": [],
|
||||
"timeShift": null,
|
||||
"title": "Threads",
|
||||
"tooltip": {
|
||||
"shared": true,
|
||||
"sort": 0,
|
||||
"value_type": "individual"
|
||||
},
|
||||
"type": "graph",
|
||||
"xaxis": {
|
||||
"buckets": null,
|
||||
"mode": "time",
|
||||
"name": null,
|
||||
"show": true,
|
||||
"values": []
|
||||
},
|
||||
"yaxes": [
|
||||
{
|
||||
"format": "short",
|
||||
"label": "Live Threads",
|
||||
"logBase": 1,
|
||||
"max": null,
|
||||
"min": null,
|
||||
"show": true
|
||||
},
|
||||
{
|
||||
"format": "short",
|
||||
"label": null,
|
||||
"logBase": 1,
|
||||
"max": null,
|
||||
"min": null,
|
||||
"show": true
|
||||
}
|
||||
],
|
||||
"yaxis": {
|
||||
"align": false,
|
||||
"alignLevel": null
|
||||
}
|
||||
},
|
||||
{
|
||||
"aliasColors": {},
|
||||
"bars": false,
|
||||
"dashLength": 10,
|
||||
"dashes": false,
|
||||
"datasource": "${DS_PROMETHEUS}",
|
||||
"fill": 6,
|
||||
"fillGradient": 0,
|
||||
"gridPos": {
|
||||
"h": 10,
|
||||
"w": 12,
|
||||
"x": 12,
|
||||
"y": 21
|
||||
},
|
||||
"hiddenSeries": false,
|
||||
"id": 10,
|
||||
"interval": "",
|
||||
"legend": {
|
||||
"alignAsTable": true,
|
||||
"avg": true,
|
||||
"current": true,
|
||||
"max": true,
|
||||
"min": true,
|
||||
"show": true,
|
||||
"total": false,
|
||||
"values": true
|
||||
},
|
||||
"lines": true,
|
||||
"linewidth": 1,
|
||||
"nullPointMode": "null",
|
||||
"options": {
|
||||
"dataLinks": []
|
||||
},
|
||||
"percentage": false,
|
||||
"pointradius": 2,
|
||||
"points": false,
|
||||
"renderer": "flot",
|
||||
"seriesOverrides": [],
|
||||
"spaceLength": 10,
|
||||
"stack": true,
|
||||
"steppedLine": false,
|
||||
"targets": [
|
||||
{
|
||||
"expr": "jgit_block_cache_open_files{instance=\"$instance\",replica=\"$replica\"}",
|
||||
"legendFormat": "jgit block cache",
|
||||
"refId": "B"
|
||||
},
|
||||
{
|
||||
"expr": "proc_num_open_fds{instance=\"$instance\",replica=\"$replica\"}-jgit_block_cache_open_files{instance=\"$instance\",replica=\"$replica\"}",
|
||||
"legendFormat": "other",
|
||||
"refId": "C"
|
||||
}
|
||||
],
|
||||
"thresholds": [],
|
||||
"timeFrom": null,
|
||||
"timeRegions": [],
|
||||
"timeShift": null,
|
||||
"title": "Java open file descriptors",
|
||||
"tooltip": {
|
||||
"shared": true,
|
||||
"sort": 0,
|
||||
"value_type": "individual"
|
||||
},
|
||||
"type": "graph",
|
||||
"xaxis": {
|
||||
"buckets": null,
|
||||
"mode": "time",
|
||||
"name": null,
|
||||
"show": true,
|
||||
"values": []
|
||||
},
|
||||
"yaxes": [
|
||||
{
|
||||
"format": "short",
|
||||
"label": "Open File Descriptors",
|
||||
"logBase": 1,
|
||||
"max": null,
|
||||
"min": null,
|
||||
"show": true
|
||||
},
|
||||
{
|
||||
"format": "short",
|
||||
"label": null,
|
||||
"logBase": 1,
|
||||
"max": null,
|
||||
"min": null,
|
||||
"show": true
|
||||
}
|
||||
],
|
||||
"yaxis": {
|
||||
"align": false,
|
||||
"alignLevel": null
|
||||
}
|
||||
},
|
||||
{
|
||||
"aliasColors": {},
|
||||
"bars": false,
|
||||
"dashLength": 10,
|
||||
"dashes": false,
|
||||
"datasource": "${DS_PROMETHEUS}",
|
||||
"fill": 2,
|
||||
"fillGradient": 0,
|
||||
"gridPos": {
|
||||
"h": 10,
|
||||
"w": 12,
|
||||
"x": 12,
|
||||
"y": 31
|
||||
},
|
||||
"hiddenSeries": false,
|
||||
"id": 12,
|
||||
"interval": "",
|
||||
"legend": {
|
||||
"alignAsTable": true,
|
||||
"avg": true,
|
||||
"current": true,
|
||||
"max": true,
|
||||
"min": true,
|
||||
"show": true,
|
||||
"total": false,
|
||||
"values": true
|
||||
},
|
||||
"lines": true,
|
||||
"linewidth": 1,
|
||||
"nullPointMode": "null",
|
||||
"options": {
|
||||
"dataLinks": []
|
||||
},
|
||||
"percentage": false,
|
||||
"pointradius": 2,
|
||||
"points": false,
|
||||
"renderer": "flot",
|
||||
"seriesOverrides": [
|
||||
{
|
||||
"alias": "miss ratio",
|
||||
"yaxis": 1
|
||||
},
|
||||
{
|
||||
"alias": "eviction ratio",
|
||||
"yaxis": 2
|
||||
}
|
||||
],
|
||||
"spaceLength": 10,
|
||||
"stack": false,
|
||||
"steppedLine": false,
|
||||
"targets": [
|
||||
{
|
||||
"expr": "increase(jgit_block_cache_miss_count{instance=\"$instance\",replica=\"$replica\"}[2m])/(increase(jgit_block_cache_hit_count{instance=\"$instance\",replica=\"$replica\"}[2m])+increase(jgit_block_cache_miss_count{instance=\"$instance\",replica=\"$replica\"}[2m]))",
|
||||
"format": "time_series",
|
||||
"instant": false,
|
||||
"legendFormat": "miss ratio",
|
||||
"refId": "A"
|
||||
},
|
||||
{
|
||||
"expr": "increase(jgit_block_cache_eviction_count{instance=\"$instance\",replica=\"$replica\"}[2m])/(increase(jgit_block_cache_hit_count{instance=\"$instance\",replica=\"$replica\"}[2m])+increase(jgit_block_cache_miss_count{instance=\"$instance\",replica=\"$replica\"}[2m]))",
|
||||
"format": "time_series",
|
||||
"instant": false,
|
||||
"legendFormat": "eviction ratio",
|
||||
"refId": "B"
|
||||
}
|
||||
],
|
||||
"thresholds": [],
|
||||
"timeFrom": null,
|
||||
"timeRegions": [],
|
||||
"timeShift": null,
|
||||
"title": "JGit block cache",
|
||||
"tooltip": {
|
||||
"shared": true,
|
||||
"sort": 0,
|
||||
"value_type": "individual"
|
||||
},
|
||||
"type": "graph",
|
||||
"xaxis": {
|
||||
"buckets": null,
|
||||
"mode": "time",
|
||||
"name": null,
|
||||
"show": true,
|
||||
"values": []
|
||||
},
|
||||
"yaxes": [
|
||||
{
|
||||
"decimals": null,
|
||||
"format": "percentunit",
|
||||
"label": "miss ratio",
|
||||
"logBase": 1,
|
||||
"max": null,
|
||||
"min": null,
|
||||
"show": true
|
||||
},
|
||||
{
|
||||
"decimals": null,
|
||||
"format": "percentunit",
|
||||
"label": "eviction ratio",
|
||||
"logBase": 1,
|
||||
"max": null,
|
||||
"min": null,
|
||||
"show": true
|
||||
}
|
||||
],
|
||||
"yaxis": {
|
||||
"align": false,
|
||||
"alignLevel": 1
|
||||
}
|
||||
}
|
||||
],
|
||||
"refresh": "1m",
|
||||
"schemaVersion": 22,
|
||||
"style": "dark",
|
||||
"tags": [],
|
||||
"templating": {
|
||||
"list": [
|
||||
{
|
||||
"allValue": null,
|
||||
"current": {
|
||||
"text": "",
|
||||
"value": ""
|
||||
},
|
||||
"datasource": "${DS_PROMETHEUS}",
|
||||
"definition": "label_values(git_upload_pack_phase_writing_total, instance)",
|
||||
"hide": 0,
|
||||
"includeAll": false,
|
||||
"label": "Gerrit Instance",
|
||||
"multi": false,
|
||||
"name": "instance",
|
||||
"options": [],
|
||||
"query": "label_values(git_upload_pack_phase_writing_total, instance)",
|
||||
"refresh": 1,
|
||||
"regex": "",
|
||||
"skipUrlSync": false,
|
||||
"sort": 0,
|
||||
"tagValuesQuery": "",
|
||||
"tags": [],
|
||||
"tagsQuery": "",
|
||||
"type": "query",
|
||||
"useTags": false
|
||||
},
|
||||
{
|
||||
"allValue": null,
|
||||
"current": {
|
||||
"text": "",
|
||||
"value": ""
|
||||
},
|
||||
"datasource": "${DS_PROMETHEUS}",
|
||||
"definition": "label_values(git_upload_pack_phase_writing_total{instance=\"$instance\"}, replica)",
|
||||
"hide": 0,
|
||||
"includeAll": false,
|
||||
"label": "Replica",
|
||||
"multi": false,
|
||||
"name": "replica",
|
||||
"options": [],
|
||||
"query": "label_values(git_upload_pack_phase_writing_total{instance=\"$instance\"}, replica)",
|
||||
"refresh": 2,
|
||||
"regex": "",
|
||||
"skipUrlSync": false,
|
||||
"sort": 0,
|
||||
"tagValuesQuery": "",
|
||||
"tags": [],
|
||||
"tagsQuery": "",
|
||||
"type": "query",
|
||||
"useTags": false
|
||||
}
|
||||
]
|
||||
},
|
||||
"time": {
|
||||
"from": "now-24h",
|
||||
"to": "now"
|
||||
},
|
||||
"timepicker": {
|
||||
"refresh_intervals": [
|
||||
"5s",
|
||||
"10s",
|
||||
"30s",
|
||||
"1m",
|
||||
"5m",
|
||||
"15m",
|
||||
"30m",
|
||||
"1h",
|
||||
"2h",
|
||||
"1d"
|
||||
]
|
||||
},
|
||||
"timezone": "",
|
||||
"title": "Process",
|
||||
"uid": "MeOVgCPWz",
|
||||
"version": 5
|
||||
}
|
21
dashboards/gerrit/globals/variables.libsonnet
Normal file
21
dashboards/gerrit/globals/variables.libsonnet
Normal file
|
@ -0,0 +1,21 @@
|
|||
local grafana = import '../../../vendor/grafonnet/grafana.libsonnet';
|
||||
local template = grafana.template;
|
||||
|
||||
local defaults = import '../../globals/defaults.libsonnet';
|
||||
|
||||
{
|
||||
instance: template.new(
|
||||
name='instance',
|
||||
datasource=defaults.datasource,
|
||||
query='label_values(git_upload_pack_phase_writing_total, instance)',
|
||||
label='Gerrit Instance',
|
||||
refresh='load',
|
||||
),
|
||||
replica: template.new(
|
||||
name='replica',
|
||||
datasource=defaults.datasource,
|
||||
query='label_values(git_upload_pack_phase_writing_total{instance="$instance"}, replica)',
|
||||
label='Replica',
|
||||
refresh='time',
|
||||
),
|
||||
}
|
60
dashboards/gerrit/process/gerrit-process.jsonnet
Normal file
60
dashboards/gerrit/process/gerrit-process.jsonnet
Normal file
|
@ -0,0 +1,60 @@
|
|||
local grafana = import '../../../vendor/grafonnet/grafana.libsonnet';
|
||||
local dashboard = grafana.dashboard;
|
||||
local template = grafana.template;
|
||||
local graphPanel = grafana.graphPanel;
|
||||
local prometheus = grafana.prometheus;
|
||||
|
||||
local defaults = import '../../globals/defaults.libsonnet';
|
||||
local gridPos = import '../../globals/grid_pos.libsonnet';
|
||||
local publishVariables = import '../../globals/publish.libsonnet';
|
||||
local variables = import '../globals/variables.libsonnet';
|
||||
|
||||
local cpu_panel = import './panels/cpu.libsonnet';
|
||||
local file_descr_panel = import './panels/file-descriptors.libsonnet';
|
||||
local gc_time_panel = import './panels/gc-time.libsonnet';
|
||||
local jgit_block_cache_panel = import './panels/jgit-block-cache.libsonnet';
|
||||
local memory_panel = import './panels/memory.libsonnet';
|
||||
local system_load_panel = import './panels/system-load.libsonnet';
|
||||
local threads_panel = import './panels/threads.libsonnet';
|
||||
|
||||
dashboard.new(
|
||||
'Gerrit - Process',
|
||||
tags=['gerrit'],
|
||||
schemaVersion=defaults.dashboards.schemaVersion,
|
||||
editable=defaults.dashboards.editable,
|
||||
time_from=defaults.dashboards.timeFrom,
|
||||
time_to=defaults.dashboards.timeTo,
|
||||
refresh=defaults.dashboards.refresh,
|
||||
graphTooltip='shared_tooltip',
|
||||
)
|
||||
.addTemplate(variables.instance)
|
||||
.addTemplate(variables.replica)
|
||||
.addPanel(
|
||||
system_load_panel,
|
||||
gridPos=gridPos.new(0, 0)
|
||||
)
|
||||
.addPanel(
|
||||
memory_panel,
|
||||
gridPos=gridPos.new(0, 1)
|
||||
)
|
||||
.addPanel(
|
||||
cpu_panel,
|
||||
gridPos=gridPos.new(1, 0)
|
||||
)
|
||||
.addPanel(
|
||||
gc_time_panel,
|
||||
gridPos=gridPos.new(1, 1)
|
||||
)
|
||||
.addPanel(
|
||||
threads_panel,
|
||||
gridPos=gridPos.new(2, 0)
|
||||
)
|
||||
.addPanel(
|
||||
file_descr_panel,
|
||||
gridPos=gridPos.new(2, 1)
|
||||
)
|
||||
.addPanel(
|
||||
jgit_block_cache_panel,
|
||||
gridPos=gridPos.new(3, 0)
|
||||
)
|
||||
+ if std.extVar('publish') then publishVariables else {}
|
28
dashboards/gerrit/process/panels/cpu.libsonnet
Normal file
28
dashboards/gerrit/process/panels/cpu.libsonnet
Normal file
|
@ -0,0 +1,28 @@
|
|||
local grafana = import '../../../../vendor/grafonnet/grafana.libsonnet';
|
||||
local prometheus = grafana.prometheus;
|
||||
|
||||
local lineGraph = import '../../../globals/line-graph.libsonnet';
|
||||
|
||||
lineGraph.new(
|
||||
title='CPU',
|
||||
labelY1='CPU cores',
|
||||
)
|
||||
.addTarget(
|
||||
prometheus.target(
|
||||
'rate(proc_cpu_usage{instance="$instance",replica="$replica"}[5m])',
|
||||
legendFormat='used CPUs',
|
||||
)
|
||||
)
|
||||
.addTarget(
|
||||
prometheus.target(
|
||||
'proc_cpu_num_cores{instance="$instance",replica="$replica"}',
|
||||
legendFormat='available CPUs',
|
||||
)
|
||||
)
|
||||
.addSeriesOverride(
|
||||
{
|
||||
alias: 'available CPUs',
|
||||
color: '#1F60C4',
|
||||
fill: 0,
|
||||
}
|
||||
)
|
23
dashboards/gerrit/process/panels/file-descriptors.libsonnet
Normal file
23
dashboards/gerrit/process/panels/file-descriptors.libsonnet
Normal file
|
@ -0,0 +1,23 @@
|
|||
local grafana = import '../../../../vendor/grafonnet/grafana.libsonnet';
|
||||
local graphPanel = grafana.graphPanel;
|
||||
local prometheus = grafana.prometheus;
|
||||
|
||||
local lineGraph = import '../../../globals/line-graph.libsonnet';
|
||||
|
||||
lineGraph.new(
|
||||
title='Java open file descriptors',
|
||||
labelY1='Open File Descriptors',
|
||||
stack=true,
|
||||
)
|
||||
.addTarget(
|
||||
prometheus.target(
|
||||
'jgit_block_cache_open_files{instance="$instance",replica="$replica"}',
|
||||
legendFormat='jgit block cache',
|
||||
)
|
||||
)
|
||||
.addTarget(
|
||||
prometheus.target(
|
||||
'proc_num_open_fds{instance="$instance",replica="$replica"}-jgit_block_cache_open_files{instance="$instance",replica="$replica"}',
|
||||
legendFormat='other',
|
||||
)
|
||||
)
|
62
dashboards/gerrit/process/panels/gc-time.libsonnet
Normal file
62
dashboards/gerrit/process/panels/gc-time.libsonnet
Normal file
|
@ -0,0 +1,62 @@
|
|||
local grafana = import '../../../../vendor/grafonnet/grafana.libsonnet';
|
||||
local prometheus = grafana.prometheus;
|
||||
|
||||
local barGraph = import '../../../globals/bar-graph.libsonnet';
|
||||
|
||||
barGraph.new(
|
||||
title='Java - % of time spent in GC',
|
||||
formatY1='percentunit',
|
||||
labelY1='GC Time',
|
||||
)
|
||||
.addTarget(
|
||||
prometheus.target(
|
||||
'increase(proc_jvm_gc_time_G1_Young_Generation{instance="$instance",replica="$replica"}[2m])/increase(proc_uptime{instance="$instance",replica="$replica"}[2m])',
|
||||
legendFormat='gc time G1 young gen',
|
||||
interval='1m',
|
||||
)
|
||||
)
|
||||
.addTarget(
|
||||
prometheus.target(
|
||||
'increase(proc_jvm_gc_time_G1_Old_Generation{instance="$instance",replica="$replica"}[2m])/increase(proc_uptime{instance="$instance",replica="$replica"}[2m])',
|
||||
legendFormat='gc time G1 old gen',
|
||||
interval='1m',
|
||||
)
|
||||
)
|
||||
.addTarget(
|
||||
prometheus.target(
|
||||
'increase(proc_jvm_gc_time_PS_MarkSweep{instance="$instance",replica="$replica"}[2m])/increase(proc_uptime{instance="$instance",replica="$replica"}[2m])',
|
||||
legendFormat='gc time PS MarkSweep',
|
||||
interval='1m',
|
||||
)
|
||||
)
|
||||
.addTarget(
|
||||
prometheus.target(
|
||||
'increase(proc_jvm_gc_time_PS_Scavenge{instance="$instance",replica="$replica"}[2m])/increase(proc_uptime{instance="$instance",replica="$replica"}[2m])',
|
||||
legendFormat='gc time PS Scavange',
|
||||
interval='1m',
|
||||
)
|
||||
)
|
||||
.addSeriesOverride(
|
||||
{
|
||||
alias: 'gc time G1 young gen',
|
||||
color: '#F2CC0C',
|
||||
}
|
||||
)
|
||||
.addSeriesOverride(
|
||||
{
|
||||
alias: 'gc time G1 young gen',
|
||||
color: '#3274D9',
|
||||
}
|
||||
)
|
||||
.addSeriesOverride(
|
||||
{
|
||||
alias: 'gc time PS Scavange',
|
||||
color: '#8AB8FF',
|
||||
}
|
||||
)
|
||||
.addSeriesOverride(
|
||||
{
|
||||
alias: 'gc time PS MarkSweep',
|
||||
color: '#E02F44',
|
||||
}
|
||||
)
|
25
dashboards/gerrit/process/panels/jgit-block-cache.libsonnet
Normal file
25
dashboards/gerrit/process/panels/jgit-block-cache.libsonnet
Normal file
|
@ -0,0 +1,25 @@
|
|||
local grafana = import '../../../../vendor/grafonnet/grafana.libsonnet';
|
||||
local graphPanel = grafana.graphPanel;
|
||||
local prometheus = grafana.prometheus;
|
||||
|
||||
local lineGraph = import '../../../globals/line-graph.libsonnet';
|
||||
|
||||
lineGraph.new(
|
||||
title='JGit block cache',
|
||||
formatY1='percentunit',
|
||||
labelY1='miss ratio',
|
||||
formatY2='percentunit',
|
||||
labelY2='eviction ratio',
|
||||
)
|
||||
.addTarget(
|
||||
prometheus.target(
|
||||
'increase(jgit_block_cache_miss_count{instance="$instance",replica="$replica"}[2m])/(increase(jgit_block_cache_hit_count{instance="$instance",replica="$replica"}[2m])+increase(jgit_block_cache_miss_count{instance="$instance",replica="$replica"}[2m]))',
|
||||
legendFormat='miss ratio',
|
||||
)
|
||||
)
|
||||
.addTarget(
|
||||
prometheus.target(
|
||||
'increase(jgit_block_cache_eviction_count{instance="$instance",replica="$replica"}[2m])/(increase(jgit_block_cache_hit_count{instance="$instance",replica="$replica"}[2m])+increase(jgit_block_cache_miss_count{instance="$instance",replica="$replica"}[2m]))',
|
||||
legendFormat='eviction ratio',
|
||||
)
|
||||
)
|
35
dashboards/gerrit/process/panels/memory.libsonnet
Normal file
35
dashboards/gerrit/process/panels/memory.libsonnet
Normal file
|
@ -0,0 +1,35 @@
|
|||
local grafana = import '../../../../vendor/grafonnet/grafana.libsonnet';
|
||||
local graphPanel = grafana.graphPanel;
|
||||
local prometheus = grafana.prometheus;
|
||||
|
||||
local lineGraph = import '../../../globals/line-graph.libsonnet';
|
||||
|
||||
lineGraph.new(
|
||||
title='Memory',
|
||||
formatY1='decbytes',
|
||||
labelY1='Memory Consumption',
|
||||
)
|
||||
.addTarget(
|
||||
prometheus.target(
|
||||
'proc_jvm_memory_heap_committed{instance="$instance",replica="$replica"}',
|
||||
legendFormat='committed heap'
|
||||
)
|
||||
)
|
||||
.addTarget(
|
||||
prometheus.target(
|
||||
'proc_jvm_memory_heap_used{instance="$instance",replica="$replica"}',
|
||||
legendFormat='used heap'
|
||||
)
|
||||
)
|
||||
.addTarget(
|
||||
prometheus.target(
|
||||
'jgit_block_cache_cache_used{instance="$instance",replica="$replica"}',
|
||||
legendFormat='JGit block cache'
|
||||
)
|
||||
)
|
||||
.addTarget(
|
||||
prometheus.target(
|
||||
'proc_jvm_memory_non_heap_used{instance="$instance",replica="$replica"}',
|
||||
legendFormat='used non-heap'
|
||||
)
|
||||
)
|
16
dashboards/gerrit/process/panels/system-load.libsonnet
Normal file
16
dashboards/gerrit/process/panels/system-load.libsonnet
Normal file
|
@ -0,0 +1,16 @@
|
|||
local grafana = import '../../../../vendor/grafonnet/grafana.libsonnet';
|
||||
local graphPanel = grafana.graphPanel;
|
||||
local prometheus = grafana.prometheus;
|
||||
|
||||
local lineGraph = import '../../../globals/line-graph.libsonnet';
|
||||
|
||||
lineGraph.new(
|
||||
title='System load',
|
||||
labelY1='System load',
|
||||
)
|
||||
.addTarget(
|
||||
prometheus.target(
|
||||
'proc_cpu_system_load{instance="$instance",replica="$replica"}',
|
||||
legendFormat='system load',
|
||||
)
|
||||
)
|
16
dashboards/gerrit/process/panels/threads.libsonnet
Normal file
16
dashboards/gerrit/process/panels/threads.libsonnet
Normal file
|
@ -0,0 +1,16 @@
|
|||
local grafana = import '../../../../vendor/grafonnet/grafana.libsonnet';
|
||||
local graphPanel = grafana.graphPanel;
|
||||
local prometheus = grafana.prometheus;
|
||||
|
||||
local lineGraph = import '../../../globals/line-graph.libsonnet';
|
||||
|
||||
lineGraph.new(
|
||||
title='Threads',
|
||||
labelY1='Live Threads',
|
||||
)
|
||||
.addTarget(
|
||||
prometheus.target(
|
||||
'proc_jvm_thread_num_live{instance="$instance",replica="$replica"}',
|
||||
legendFormat='Java live threads',
|
||||
)
|
||||
)
|
32
dashboards/globals/bar-graph.libsonnet
Normal file
32
dashboards/globals/bar-graph.libsonnet
Normal file
|
@ -0,0 +1,32 @@
|
|||
local grafana = import '../../vendor/grafonnet/grafana.libsonnet';
|
||||
local graphPanel = grafana.graphPanel;
|
||||
|
||||
local defaults = import './defaults.libsonnet';
|
||||
|
||||
{
|
||||
new(
|
||||
title,
|
||||
labelY1,
|
||||
labelY2='',
|
||||
formatY1='short',
|
||||
formatY2='short',
|
||||
stack=false,
|
||||
):: graphPanel.new(
|
||||
title=title,
|
||||
labelY1=labelY1,
|
||||
labelY2=labelY2,
|
||||
formatY1=formatY1,
|
||||
formatY2=formatY2,
|
||||
stack=stack,
|
||||
datasource=defaults.datasource,
|
||||
fill=1,
|
||||
legend_alignAsTable=true,
|
||||
legend_avg=true,
|
||||
legend_current=true,
|
||||
legend_max=true,
|
||||
legend_min=true,
|
||||
legend_values=true,
|
||||
lines=false,
|
||||
bars=true
|
||||
),
|
||||
}
|
14
dashboards/globals/defaults.libsonnet
Normal file
14
dashboards/globals/defaults.libsonnet
Normal file
|
@ -0,0 +1,14 @@
|
|||
{
|
||||
dashboards: {
|
||||
editable: false,
|
||||
schemaVersion: 22,
|
||||
timeFrom: 'now-24h',
|
||||
timeTo: 'now',
|
||||
refresh: '1m',
|
||||
},
|
||||
panels: {
|
||||
width: 12,
|
||||
height: 11,
|
||||
},
|
||||
datasource: if std.extVar('publish') then '${DS_PROMETHEUS}' else 'Prometheus',
|
||||
}
|
13
dashboards/globals/grid_pos.libsonnet
Normal file
13
dashboards/globals/grid_pos.libsonnet
Normal file
|
@ -0,0 +1,13 @@
|
|||
local defaults = import './defaults.libsonnet';
|
||||
|
||||
{
|
||||
new(
|
||||
row,
|
||||
column,
|
||||
):: {
|
||||
x: column * defaults.panels.width,
|
||||
y: row * defaults.panels.height,
|
||||
w: defaults.panels.width,
|
||||
h: defaults.panels.height,
|
||||
},
|
||||
}
|
32
dashboards/globals/line-graph.libsonnet
Normal file
32
dashboards/globals/line-graph.libsonnet
Normal file
|
@ -0,0 +1,32 @@
|
|||
local grafana = import '../../vendor/grafonnet/grafana.libsonnet';
|
||||
local graphPanel = grafana.graphPanel;
|
||||
|
||||
local defaults = import './defaults.libsonnet';
|
||||
|
||||
{
|
||||
new(
|
||||
title,
|
||||
labelY1,
|
||||
labelY2='',
|
||||
formatY1='short',
|
||||
formatY2='short',
|
||||
stack=false,
|
||||
):: graphPanel.new(
|
||||
title=title,
|
||||
labelY1=labelY1,
|
||||
labelY2=labelY2,
|
||||
formatY1=formatY1,
|
||||
formatY2=formatY2,
|
||||
stack=stack,
|
||||
datasource=defaults.datasource,
|
||||
fill=1,
|
||||
legend_alignAsTable=true,
|
||||
legend_avg=true,
|
||||
legend_current=true,
|
||||
legend_max=true,
|
||||
legend_min=true,
|
||||
legend_values=true,
|
||||
lines=true,
|
||||
linewidth=1,
|
||||
),
|
||||
}
|
32
dashboards/globals/publish.libsonnet
Normal file
32
dashboards/globals/publish.libsonnet
Normal file
|
@ -0,0 +1,32 @@
|
|||
{
|
||||
__inputs: [
|
||||
{
|
||||
name: 'DS_PROMETHEUS',
|
||||
label: 'Prometheus',
|
||||
description: '',
|
||||
type: 'datasource',
|
||||
pluginId: 'prometheus',
|
||||
pluginName: 'Prometheus',
|
||||
},
|
||||
],
|
||||
__requires: [
|
||||
{
|
||||
type: 'grafana',
|
||||
id: 'grafana',
|
||||
name: 'Grafana',
|
||||
version: '7.1.5',
|
||||
},
|
||||
{
|
||||
type: 'panel',
|
||||
id: 'graph',
|
||||
name: 'Graph',
|
||||
version: '',
|
||||
},
|
||||
{
|
||||
type: 'datasource',
|
||||
id: 'prometheus',
|
||||
name: 'Prometheus',
|
||||
version: '1.0.0',
|
||||
},
|
||||
],
|
||||
}
|
15
jsonnetfile.json
Normal file
15
jsonnetfile.json
Normal file
|
@ -0,0 +1,15 @@
|
|||
{
|
||||
"version": 1,
|
||||
"dependencies": [
|
||||
{
|
||||
"source": {
|
||||
"git": {
|
||||
"remote": "https://github.com/grafana/grafonnet-lib.git",
|
||||
"subdir": "grafonnet"
|
||||
}
|
||||
},
|
||||
"version": "master"
|
||||
}
|
||||
],
|
||||
"legacyImports": true
|
||||
}
|
16
jsonnetfile.lock.json
Normal file
16
jsonnetfile.lock.json
Normal file
|
@ -0,0 +1,16 @@
|
|||
{
|
||||
"version": 1,
|
||||
"dependencies": [
|
||||
{
|
||||
"source": {
|
||||
"git": {
|
||||
"remote": "https://github.com/grafana/grafonnet-lib.git",
|
||||
"subdir": "grafonnet"
|
||||
}
|
||||
},
|
||||
"version": "3336c69715f8f7a4d637582504c9fabd9d9ca081",
|
||||
"sum": "w6zS28Rjs9EzRN/WoLLIdi028BvumxDTyLefYVoql2k="
|
||||
}
|
||||
],
|
||||
"legacyImports": false
|
||||
}
|
|
@ -19,6 +19,7 @@ import subprocess
|
|||
import sys
|
||||
import zipfile
|
||||
|
||||
import _jsonnet
|
||||
import requests
|
||||
import yaml
|
||||
|
||||
|
@ -55,13 +56,23 @@ def _create_dashboard_configmaps(output_dir, namespace):
|
|||
if not os.path.exists(output_dir):
|
||||
os.mkdir(output_dir)
|
||||
|
||||
for dashboard in os.listdir(dashboards_dir):
|
||||
dashboard_path = os.path.join(dashboards_dir, dashboard)
|
||||
dashboard_name = os.path.splitext(dashboard)[0]
|
||||
for dir_path, _, files in os.walk(dashboards_dir):
|
||||
for dashboard in files:
|
||||
dashboard_path = os.path.join(dir_path, dashboard)
|
||||
dashboard_name, ext = os.path.splitext(dashboard)
|
||||
if ext == ".json":
|
||||
source = f"--from-file={dashboard_path}"
|
||||
elif ext == ".jsonnet":
|
||||
json = _jsonnet.evaluate_file(dashboard_path, ext_codes={"publish": "false"})
|
||||
source = f"--from-literal={dashboard_name}.json='{json}'"
|
||||
else:
|
||||
continue
|
||||
|
||||
output_file = f"{output_dir}/{dashboard_name}.dashboard.yaml"
|
||||
|
||||
command = (
|
||||
f"kubectl create configmap {dashboard_name} -o yaml "
|
||||
f"--from-file={dashboard_path} --dry-run=client --namespace={namespace} "
|
||||
f"{source} --dry-run=client --namespace={namespace} "
|
||||
f"> {output_file}"
|
||||
)
|
||||
|
||||
|
@ -74,9 +85,9 @@ def _create_dashboard_configmaps(output_dir, namespace):
|
|||
dashboard_cm = yaml.load(f, Loader=yaml.SafeLoader)
|
||||
dashboard_cm["metadata"]["labels"] = dict()
|
||||
dashboard_cm["metadata"]["labels"]["grafana_dashboard"] = dashboard_name
|
||||
dashboard_cm["data"][dashboard] = dashboard_cm["data"][dashboard].replace(
|
||||
'"${DS_PROMETHEUS}"', "null"
|
||||
)
|
||||
dashboard_cm["data"][f"{dashboard_name}.json"] = dashboard_cm["data"][
|
||||
f"{dashboard_name}.json"
|
||||
].replace('"${DS_PROMETHEUS}"', "null")
|
||||
|
||||
with open(output_file, "w") as f:
|
||||
yaml.dump(dashboard_cm, f)
|
||||
|
|
Loading…
Reference in a new issue