Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
S
slapos
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
5
Merge Requests
5
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Jérome Perrin
slapos
Commits
1a332998
Commit
1a332998
authored
Sep 27, 2023
by
Jérome Perrin
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
WIP grafana
parent
76033ee0
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
47 additions
and
46 deletions
+47
-46
software/grafana/buildout.hash.cfg
software/grafana/buildout.hash.cfg
+1
-1
software/grafana/instance.cfg.in
software/grafana/instance.cfg.in
+42
-35
software/grafana/software.cfg
software/grafana/software.cfg
+4
-10
No files found.
software/grafana/buildout.hash.cfg
View file @
1a332998
...
@@ -15,7 +15,7 @@
...
@@ -15,7 +15,7 @@
[instance-profile]
[instance-profile]
filename = instance.cfg.in
filename = instance.cfg.in
md5sum =
6ff69aef5a7185f880359a78965e072e
md5sum =
b0bd4494451460b9cd2df7d333e5a157
[influxdb-config-file]
[influxdb-config-file]
filename = influxdb-config-file.cfg.in
filename = influxdb-config-file.cfg.in
...
...
software/grafana/instance.cfg.in
View file @
1a332998
...
@@ -163,7 +163,7 @@ ssl-cert-file = ${grafana-certificate:cert-file}
...
@@ -163,7 +163,7 @@ ssl-cert-file = ${grafana-certificate:cert-file}
recipe = slapos.cookbook:wrapper
recipe = slapos.cookbook:wrapper
command-line =
command-line =
{{ grafana_bin }} -config ${grafana-config-file:output} -homepath {{ grafana_homepath }}
{{ grafana_bin }}
server
-config ${grafana-config-file:output} -homepath {{ grafana_homepath }}
wrapper-path = ${directory:service}/grafana
wrapper-path = ${directory:service}/grafana
[grafana-certificate]
[grafana-certificate]
...
@@ -267,7 +267,12 @@ init =
...
@@ -267,7 +267,12 @@ init =
"name_override": f"{partition['name']}-mysql",
"name_override": f"{partition['name']}-mysql",
"servers": [dsn],
"servers": [dsn],
"gather_innodb_metrics": True,
"gather_innodb_metrics": True,
"tags": dict(partition.get("static-tags", {}), app=application["name"]),
"tags": dict(
partition.get("static-tags", {}),
app=application["name"],
name=partition["name"],
partition=partition["reference"],
),
}
}
)
)
if partition["type"] == "erp5/mariadb":
if partition["type"] == "erp5/mariadb":
...
@@ -278,39 +283,44 @@ init =
...
@@ -278,39 +283,44 @@ init =
"dsn": dsn,
"dsn": dsn,
"query": [
"query": [
{
{
"query": "select count(*) as message_count from message",
"query": """
select 'message' as cmf_activity_queue, count(*) as message_count from message
union all select 'message_queue' as cmf_activity_queue, count(*) as message_count from message_queue
""",
"field_columns_include": ["message_count"],
"field_columns_include": ["message_count"],
},
"tag_columns_include": ["cmf_activity_queue"],
{
"query": "select count(*) as message_queue_count from message_queue",
"field_columns_include": ["message_queue_count"],
},
{
"query": "select count(*) as message_failed_count from message where processing_node=-2",
"field_columns_include": ["message_failed_count"],
},
{
"query": "select count(*) as message_queue_failed_count from message_queue where processing_node=-2",
"field_columns_include": ["message_queue_failed_count"],
},
},
{
{
"query": """
"query": """
select cast(coalesce(max(UNIX_TIMESTAMP(now()) - UNIX_TIMESTAMP(message.date)), 0) as int)
select 'message' as cmf_activity_queue, count(*) as failed_message_count
as message_waiting_time from message
from message where processing_node between -2 and -10
where processing_node in (-1, 0) and message not like '%after_tag%'
union all select 'message_queue' as cmf_activity_queue, count(*) as failed_message_count
from message_queue where processing_node between -2 and -10
""",
""",
"field_columns_include": ["message_waiting_time"],
"field_columns_include": ["failed_message_count"],
"tag_columns_include": ["cmf_activity_queue"],
},
},
{
{
"query": """
"query": """
select cast(coalesce(max(UNIX_TIMESTAMP(now()) - UNIX_TIMESTAMP(message.date)), 0) as int)
as waiting_time, 'message' as cmf_activity_queue
from message where processing_node in (-1, 0) and message.message not like '%after_tag%'
union all
select cast(coalesce(max(UNIX_TIMESTAMP(now()) - UNIX_TIMESTAMP(message_queue.date)), 0) as int)
select cast(coalesce(max(UNIX_TIMESTAMP(now()) - UNIX_TIMESTAMP(message_queue.date)), 0) as int)
as
message_queue_waiting_time from message
_queue
as
waiting_time, 'message_queue' as cmf_activity
_queue
where processing_node in (-1, 0) and messag
e not like '%after_tag%'
from message_queue where processing_node in (-1, 0) and message.message_queu
e not like '%after_tag%'
""",
""",
"field_columns_include": ["message_queue_waiting_time"],
"field_columns_include": ["waiting_time"],
}
"tag_columns_include": ["cmf_activity_queue"],
},
],
],
"tags": dict(partition.get("static-tags", {}), app=application["name"]),
"tags": dict(
partition.get("static-tags", {}),
app=application["name"],
name=partition["name"],
partition=partition["reference"],
),
}
}
)
)
...
@@ -326,7 +336,12 @@ init =
...
@@ -326,7 +336,12 @@ init =
],
],
"grok_timezone": "Local",
"grok_timezone": "Local",
"name_override": f"{partition['name']}",
"name_override": f"{partition['name']}",
"tags": dict(partition.get("static-tags", {}), app=application["name"]),
"tags": dict(
partition.get("static-tags", {}),
app=application["name"],
name=partition["name"],
partition=partition["reference"],
),
}
}
)
)
urls = application.get("urls", [])
urls = application.get("urls", [])
...
@@ -360,8 +375,6 @@ init =
...
@@ -360,8 +375,6 @@ init =
"slapos": [{
"slapos": [{
"instance_root": application["instance-root"]}]}})
"instance_root": application["instance-root"]}]}})
# TODO: supervisor process finder for
# https://github.com/influxdata/telegraf/tree/master/plugins/inputs/procstat ?
telegraf_slapos_input_command = self.options['telegraf-input-slapos-bin']
telegraf_slapos_input_command = self.options['telegraf-input-slapos-bin']
inputs["execd"].append({
inputs["execd"].append({
"name_override": f"{application['name']}-processes",
"name_override": f"{application['name']}-processes",
...
@@ -389,9 +402,8 @@ init =
...
@@ -389,9 +402,8 @@ init =
processors["enum"].append({
processors["enum"].append({
"namepass": [ f"{application['name']}-processes"],
"namepass": [ f"{application['name']}-processes"],
"mapping": [{
"mapping": [{
# "tag": "group", # TODO: rename this in input plugin # XXX I don't remember what this means
"tag": "reference",
"tag": "slappart",
"dest": "name",
"dest": "partition",
"value_mappings": partition_mapping,
"value_mappings": partition_mapping,
}]})
}]})
...
@@ -401,7 +413,6 @@ init =
...
@@ -401,7 +413,6 @@ init =
# - [x] strip hashes from -on-watch
# - [x] strip hashes from -on-watch
# - [x] activity metrics
# - [x] activity metrics
# - [ ] alert dashboard
# - [ ] alert dashboard
# - [ ] inclu "jerome-dev" partout ???
# - [ ] apdex
# - [ ] apdex
# - [ ] "job" is bad name in Explore
# - [ ] "job" is bad name in Explore
...
@@ -476,8 +487,6 @@ command-line =
...
@@ -476,8 +487,6 @@ command-line =
\
\
-boltdb.shipper.compactor.ring.instance-addr=${loki:ip} \
-boltdb.shipper.compactor.ring.instance-addr=${loki:ip} \
-boltdb.shipper.compactor.ring.instance-id=${:_buildout_section_name_} \
-boltdb.shipper.compactor.ring.instance-id=${:_buildout_section_name_} \
-common.embedded-cachering.instance-addr=${loki:ip} \
-common.embedded-cachering.instance-id=${:_buildout_section_name_} \
-distributor.ring.instance-addr=${loki:ip} \
-distributor.ring.instance-addr=${loki:ip} \
-distributor.ring.instance-id=${:_buildout_section_name_} \
-distributor.ring.instance-id=${:_buildout_section_name_} \
-frontend.instance-addr=${loki:ip} \
-frontend.instance-addr=${loki:ip} \
...
@@ -790,8 +799,6 @@ install =
...
@@ -790,8 +799,6 @@ install =
"stages": [
"stages": [
{
{
"multiline": {
"multiline": {
# TODO
#"firstline": "^# Time: \\d{2}\\d{2}\\d{2}\\s\\d{1,2}\\:\\d{2}\\:\\d{2}",
"firstline": r"^# Time: \d{2}.*",
"firstline": r"^# Time: \d{2}.*",
"max_wait_time": "3s"
"max_wait_time": "3s"
}
}
...
...
software/grafana/software.cfg
View file @
1a332998
...
@@ -22,14 +22,6 @@ parts =
...
@@ -22,14 +22,6 @@ parts =
loki-config-file
loki-config-file
loki-nginx-config-file
loki-nginx-config-file
; [nodejs]
; <= nodejs-16.19.0
[gowork]
# XXX speed up development cycle by not rebuilding workspace on every software run
# XXX does not work ?
update-command =
[go_github.com_grafana_grafana]
[go_github.com_grafana_grafana]
<= go-git-package
<= go-git-package
...
@@ -59,7 +51,7 @@ revision = v1.28.1-0-g3ea9ffbe2
...
@@ -59,7 +51,7 @@ revision = v1.28.1-0-g3ea9ffbe2
<= go-git-package
<= go-git-package
go.importpath = github.com/perrinjerome/telegraf-input-slapos
go.importpath = github.com/perrinjerome/telegraf-input-slapos
repository = https://github.com/perrinjerome/telegraf-input-slapos
repository = https://github.com/perrinjerome/telegraf-input-slapos
revision = v0.0.
1-0-gf8981f3
revision = v0.0.
2-0-gd4c5221
[go_github.com_prometheus_prometheus]
[go_github.com_prometheus_prometheus]
<= go-git-package
<= go-git-package
...
@@ -92,7 +84,7 @@ telegraf-bin = ${:bin}/telegraf
...
@@ -92,7 +84,7 @@ telegraf-bin = ${:bin}/telegraf
telegraf-input-slapos-bin = ${:bin}/telegraf-input-slapos
telegraf-input-slapos-bin = ${:bin}/telegraf-input-slapos
influx-bin = ${:bin}/influx
influx-bin = ${:bin}/influx
influxd-bin = ${:bin}/influxd
influxd-bin = ${:bin}/influxd
grafana-bin = ${
:bin}/grafana-server
grafana-bin = ${
grafana:binpath}/grafana
grafana-homepath = ${grafana:homepath}
grafana-homepath = ${grafana:homepath}
loki-bin = ${:bin}/loki
loki-bin = ${:bin}/loki
promtail-bin = ${:bin}/promtail
promtail-bin = ${:bin}/promtail
...
@@ -119,6 +111,8 @@ command = bash -ce "
...
@@ -119,6 +111,8 @@ command = bash -ce "
rm -rf ${buildout:directory}/.cache/yarn/
rm -rf ${buildout:directory}/.cache/yarn/
"
"
homepath = ${go_github.com_grafana_grafana:location}
homepath = ${go_github.com_grafana_grafana:location}
# XXX "linux-amd64" is not portable here
binpath = ${go_github.com_grafana_grafana:location}/bin/linux-amd64
stop-on-error = true
stop-on-error = true
[download-file-base]
[download-file-base]
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment