2021-06-25 18:04:30 +00:00
|
|
|
def dashboard_row_zfs(panel_id, node):
|
|
|
|
return {
|
|
|
|
'title': 'zfs',
|
|
|
|
'collapse': False,
|
|
|
|
'editable': False,
|
|
|
|
'height': '250px',
|
|
|
|
'panels': [
|
|
|
|
{
|
|
|
|
'aliasColors': {},
|
|
|
|
'bars': False,
|
|
|
|
'dashLength': 10,
|
|
|
|
'dashes': False,
|
|
|
|
'datasource': None,
|
|
|
|
'fieldConfig': {
|
|
|
|
'defaults': {
|
|
|
|
'displayName': '${__field.name}'
|
|
|
|
},
|
|
|
|
'overrides': []
|
|
|
|
},
|
|
|
|
'fill': 1,
|
|
|
|
'fillGradient': 0,
|
|
|
|
'hiddenSeries': False,
|
|
|
|
'id': next(panel_id),
|
|
|
|
'legend': {
|
|
|
|
'alignAsTable': False,
|
|
|
|
'avg': False,
|
|
|
|
'current': False,
|
|
|
|
'max': False,
|
|
|
|
'min': False,
|
|
|
|
'rightSide': False,
|
|
|
|
'show': True,
|
|
|
|
'total': False,
|
|
|
|
'values': False
|
|
|
|
},
|
|
|
|
'lines': True,
|
|
|
|
'linewidth': 1,
|
|
|
|
'NonePointMode': 'None',
|
|
|
|
'options': {
|
|
|
|
'alertThreshold': True
|
|
|
|
},
|
|
|
|
'percentage': False,
|
|
|
|
'pluginVersion': '7.5.5',
|
|
|
|
'pointradius': 2,
|
|
|
|
'points': False,
|
|
|
|
'renderer': 'flot',
|
|
|
|
'seriesOverrides': [],
|
|
|
|
'spaceLength': 10,
|
|
|
|
'span': 4,
|
|
|
|
'stack': False,
|
|
|
|
'steppedLine': False,
|
|
|
|
'targets': [
|
|
|
|
{
|
|
|
|
'groupBy': [
|
|
|
|
{'type': 'time', 'params': ['$__interval']},
|
|
|
|
{'type': 'fill', 'params': ['linear']},
|
|
|
|
],
|
|
|
|
'orderByTime': "ASC",
|
|
|
|
'policy': "default",
|
|
|
|
'query': f"""from(bucket: "telegraf")
|
|
|
|
|> range(start: v.timeRangeStart, stop: v.timeRangeStop)
|
|
|
|
|> filter(fn: (r) =>
|
|
|
|
r["_measurement"] == "zfs" and
|
|
|
|
r["_field"] == "arcstats_c" and
|
|
|
|
r["host"] == "{node.name}"
|
|
|
|
)
|
|
|
|
|> map(fn: (r) => ({{
|
|
|
|
r with
|
|
|
|
_field: "target"
|
|
|
|
}})
|
|
|
|
)
|
|
|
|
|> aggregateWindow(every: v.windowPeriod, fn: mean, createEmpty: false)
|
|
|
|
|> yield(name: "target")""",
|
|
|
|
'resultFormat': 'time_series',
|
|
|
|
'select': [[
|
|
|
|
{'type': 'field', 'params': ['value']},
|
|
|
|
{'type': 'mean', 'params': []},
|
|
|
|
]],
|
|
|
|
"tags": []
|
|
|
|
},
|
|
|
|
{
|
|
|
|
'groupBy': [
|
|
|
|
{'type': 'time', 'params': ['$__interval']},
|
|
|
|
{'type': 'fill', 'params': ['linear']},
|
|
|
|
],
|
|
|
|
'orderByTime': "ASC",
|
|
|
|
'policy': "default",
|
|
|
|
'query': f"""from(bucket: "telegraf")
|
|
|
|
|> range(start: v.timeRangeStart, stop: v.timeRangeStop)
|
|
|
|
|> filter(fn: (r) =>
|
|
|
|
r["_measurement"] == "zfs" and
|
|
|
|
r["_field"] == "arcstats_size" and
|
|
|
|
r["host"] == "{node.name}"
|
|
|
|
)
|
|
|
|
|> map(fn: (r) => ({{
|
|
|
|
r with
|
|
|
|
_field: "used"
|
|
|
|
}})
|
|
|
|
)
|
|
|
|
|> aggregateWindow(every: v.windowPeriod, fn: mean, createEmpty: false)
|
|
|
|
|> yield(name: "used")""",
|
|
|
|
'resultFormat': 'time_series',
|
|
|
|
'select': [[
|
|
|
|
{'type': 'field', 'params': ['value']},
|
|
|
|
{'type': 'mean', 'params': []},
|
|
|
|
]],
|
|
|
|
"tags": []
|
|
|
|
},
|
|
|
|
],
|
|
|
|
'thresholds': [],
|
|
|
|
'timeRegions': [],
|
|
|
|
'title': 'zfs arc usage',
|
|
|
|
'tooltip': {
|
|
|
|
'shared': True,
|
|
|
|
'sort': 0,
|
|
|
|
'value_type': 'individual'
|
|
|
|
},
|
|
|
|
'type': 'graph',
|
|
|
|
'xaxis': {
|
|
|
|
'buckets': None,
|
|
|
|
'mode': 'time',
|
|
|
|
'name': None,
|
|
|
|
'show': True,
|
|
|
|
'values': []
|
|
|
|
},
|
|
|
|
'yaxes': [
|
|
|
|
{
|
2021-06-25 18:16:13 +00:00
|
|
|
'format': 'bytes',
|
2021-06-25 18:04:30 +00:00
|
|
|
'label': None,
|
|
|
|
'logBase': 1,
|
|
|
|
'max': None,
|
|
|
|
'min': 0,
|
|
|
|
'show': True,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
'format': 'short',
|
|
|
|
'label': None,
|
|
|
|
'logBase': 1,
|
|
|
|
'max': None,
|
|
|
|
'min': None,
|
|
|
|
'show': False,
|
|
|
|
}
|
|
|
|
],
|
|
|
|
'yaxis': {
|
|
|
|
'align': False,
|
|
|
|
'alignLevel': None
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
'aliasColors': {},
|
|
|
|
'bars': False,
|
|
|
|
'dashLength': 10,
|
|
|
|
'dashes': False,
|
|
|
|
'datasource': None,
|
|
|
|
'fieldConfig': {
|
|
|
|
'defaults': {
|
|
|
|
'displayName': '${__field.name}'
|
|
|
|
},
|
|
|
|
'overrides': []
|
|
|
|
},
|
|
|
|
'fill': 1,
|
|
|
|
'fillGradient': 0,
|
|
|
|
'hiddenSeries': False,
|
|
|
|
'id': next(panel_id),
|
|
|
|
'legend': {
|
|
|
|
'alignAsTable': False,
|
|
|
|
'avg': False,
|
|
|
|
'current': False,
|
|
|
|
'max': False,
|
|
|
|
'min': False,
|
|
|
|
'rightSide': False,
|
|
|
|
'show': True,
|
|
|
|
'total': False,
|
|
|
|
'values': False
|
|
|
|
},
|
|
|
|
'lines': True,
|
|
|
|
'linewidth': 1,
|
|
|
|
'NonePointMode': 'None',
|
|
|
|
'options': {
|
|
|
|
'alertThreshold': True
|
|
|
|
},
|
|
|
|
'percentage': False,
|
|
|
|
'pluginVersion': '7.5.5',
|
|
|
|
'pointradius': 2,
|
|
|
|
'points': False,
|
|
|
|
'renderer': 'flot',
|
|
|
|
'seriesOverrides': [],
|
|
|
|
'spaceLength': 10,
|
|
|
|
'span': 4,
|
|
|
|
'stack': False,
|
|
|
|
'steppedLine': False,
|
|
|
|
'targets': [
|
|
|
|
{
|
|
|
|
'groupBy': [
|
|
|
|
{'type': 'time', 'params': ['$__interval']},
|
|
|
|
{'type': 'fill', 'params': ['linear']},
|
|
|
|
],
|
|
|
|
'orderByTime': "ASC",
|
|
|
|
'policy': "default",
|
|
|
|
'query': f"""from(bucket: "telegraf")
|
|
|
|
|> range(start: v.timeRangeStart, stop: v.timeRangeStop)
|
|
|
|
|> filter(fn: (r) =>
|
|
|
|
r["_measurement"] == "zfs" and
|
|
|
|
r["_field"] == "arcstats_l2_size" and
|
|
|
|
r["host"] == "{node.name}"
|
|
|
|
)
|
|
|
|
|> map(fn: (r) => ({{
|
|
|
|
r with
|
|
|
|
_field: "used"
|
|
|
|
}})
|
|
|
|
)
|
|
|
|
|> aggregateWindow(every: v.windowPeriod, fn: mean, createEmpty: false)
|
|
|
|
|> yield(name: "used")""",
|
|
|
|
'resultFormat': 'time_series',
|
|
|
|
'select': [[
|
|
|
|
{'type': 'field', 'params': ['value']},
|
|
|
|
{'type': 'mean', 'params': []},
|
|
|
|
]],
|
|
|
|
"tags": []
|
|
|
|
},
|
|
|
|
],
|
|
|
|
'thresholds': [],
|
|
|
|
'timeRegions': [],
|
|
|
|
'title': 'zfs l2arc usage',
|
|
|
|
'tooltip': {
|
|
|
|
'shared': True,
|
|
|
|
'sort': 0,
|
|
|
|
'value_type': 'individual'
|
|
|
|
},
|
|
|
|
'type': 'graph',
|
|
|
|
'xaxis': {
|
|
|
|
'buckets': None,
|
|
|
|
'mode': 'time',
|
|
|
|
'name': None,
|
|
|
|
'show': True,
|
|
|
|
'values': []
|
|
|
|
},
|
|
|
|
'yaxes': [
|
|
|
|
{
|
2021-06-25 18:16:13 +00:00
|
|
|
'format': 'bytes',
|
2021-06-25 18:04:30 +00:00
|
|
|
'label': None,
|
|
|
|
'logBase': 1,
|
|
|
|
'max': None,
|
|
|
|
'min': 0,
|
|
|
|
'show': True,
|
|
|
|
'decimals': 0,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
'format': 'short',
|
|
|
|
'label': None,
|
|
|
|
'logBase': 1,
|
|
|
|
'max': None,
|
|
|
|
'min': None,
|
|
|
|
'show': False,
|
|
|
|
}
|
|
|
|
],
|
|
|
|
'yaxis': {
|
|
|
|
'align': False,
|
|
|
|
'alignLevel': None
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
'aliasColors': {},
|
|
|
|
'bars': False,
|
|
|
|
'dashLength': 10,
|
|
|
|
'dashes': False,
|
|
|
|
'datasource': None,
|
|
|
|
'fieldConfig': {
|
|
|
|
'defaults': {
|
|
|
|
'displayName': '${__field.name}'
|
|
|
|
},
|
|
|
|
'overrides': []
|
|
|
|
},
|
|
|
|
'fill': 1,
|
|
|
|
'fillGradient': 0,
|
|
|
|
'hiddenSeries': False,
|
|
|
|
'id': next(panel_id),
|
|
|
|
'legend': {
|
|
|
|
'alignAsTable': False,
|
|
|
|
'avg': False,
|
|
|
|
'current': False,
|
|
|
|
'max': False,
|
|
|
|
'min': False,
|
|
|
|
'rightSide': False,
|
|
|
|
'show': True,
|
|
|
|
'total': False,
|
|
|
|
'values': False
|
|
|
|
},
|
|
|
|
'lines': True,
|
|
|
|
'linewidth': 1,
|
|
|
|
'NonePointMode': 'None',
|
|
|
|
'options': {
|
|
|
|
'alertThreshold': True
|
|
|
|
},
|
|
|
|
'percentage': False,
|
|
|
|
'pluginVersion': '7.5.5',
|
|
|
|
'pointradius': 2,
|
|
|
|
'points': False,
|
|
|
|
'renderer': 'flot',
|
|
|
|
'seriesOverrides': [],
|
|
|
|
'spaceLength': 10,
|
|
|
|
'span': 4,
|
|
|
|
'stack': False,
|
|
|
|
'steppedLine': False,
|
|
|
|
'targets': [
|
|
|
|
{
|
|
|
|
'groupBy': [
|
|
|
|
{'type': 'time', 'params': ['$__interval']},
|
|
|
|
{'type': 'fill', 'params': ['linear']},
|
|
|
|
],
|
|
|
|
'orderByTime': "ASC",
|
|
|
|
'policy': "default",
|
|
|
|
'query': f"""from(bucket: "telegraf")
|
|
|
|
|> range(start: v.timeRangeStart, stop: v.timeRangeStop)
|
|
|
|
|> filter(fn: (r) =>
|
|
|
|
r["_measurement"] == "zfs" and
|
|
|
|
r["_field"] == "arcstats_hits" and
|
|
|
|
r["host"] == "{node.name}"
|
|
|
|
)
|
|
|
|
|> map(fn: (r) => ({{
|
|
|
|
r with
|
|
|
|
_field: "hits"
|
|
|
|
}})
|
|
|
|
)
|
|
|
|
|> aggregateWindow(every: v.windowPeriod, fn: mean, createEmpty: false)
|
|
|
|
|> derivative(unit: 1s, nonNegative: true)
|
|
|
|
|> yield(name: "misses")""",
|
|
|
|
'resultFormat': 'time_series',
|
|
|
|
'select': [[
|
|
|
|
{'type': 'field', 'params': ['value']},
|
|
|
|
{'type': 'mean', 'params': []},
|
|
|
|
]],
|
|
|
|
"tags": []
|
|
|
|
},
|
|
|
|
{
|
|
|
|
'groupBy': [
|
|
|
|
{'type': 'time', 'params': ['$__interval']},
|
|
|
|
{'type': 'fill', 'params': ['linear']},
|
|
|
|
],
|
|
|
|
'orderByTime': "ASC",
|
|
|
|
'policy': "default",
|
|
|
|
'query': f"""from(bucket: "telegraf")
|
|
|
|
|> range(start: v.timeRangeStart, stop: v.timeRangeStop)
|
|
|
|
|> filter(fn: (r) =>
|
|
|
|
r["_measurement"] == "zfs" and
|
|
|
|
r["_field"] == "arcstats_misses" and
|
|
|
|
r["host"] == "{node.name}"
|
|
|
|
)
|
|
|
|
|> map(fn: (r) => ({{
|
|
|
|
r with
|
|
|
|
_field: "misses"
|
|
|
|
}})
|
|
|
|
)
|
|
|
|
|> aggregateWindow(every: v.windowPeriod, fn: mean, createEmpty: false)
|
|
|
|
|> derivative(unit: 1s, nonNegative: true)
|
|
|
|
|> yield(name: "misses")""",
|
|
|
|
'resultFormat': 'time_series',
|
|
|
|
'select': [[
|
|
|
|
{'type': 'field', 'params': ['value']},
|
|
|
|
{'type': 'mean', 'params': []},
|
|
|
|
]],
|
|
|
|
"tags": []
|
|
|
|
},
|
|
|
|
{
|
|
|
|
'groupBy': [
|
|
|
|
{'type': 'time', 'params': ['$__interval']},
|
|
|
|
{'type': 'fill', 'params': ['linear']},
|
|
|
|
],
|
|
|
|
'orderByTime': "ASC",
|
|
|
|
'policy': "default",
|
|
|
|
'query': f"""from(bucket: "telegraf")
|
|
|
|
|> range(start: v.timeRangeStart, stop: v.timeRangeStop)
|
|
|
|
|> filter(fn: (r) =>
|
|
|
|
r["_measurement"] == "zfs" and
|
|
|
|
r["_field"] == "arcstats_l2_hits" and
|
|
|
|
r["host"] == "{node.name}"
|
|
|
|
)
|
|
|
|
|> map(fn: (r) => ({{
|
|
|
|
r with
|
|
|
|
_field: "l2hits"
|
|
|
|
}})
|
|
|
|
)
|
|
|
|
|> aggregateWindow(every: v.windowPeriod, fn: mean, createEmpty: false)
|
|
|
|
|> derivative(unit: 1s, nonNegative: true)
|
|
|
|
|> yield(name: "misses")""",
|
|
|
|
'resultFormat': 'time_series',
|
|
|
|
'select': [[
|
|
|
|
{'type': 'field', 'params': ['value']},
|
|
|
|
{'type': 'mean', 'params': []},
|
|
|
|
]],
|
|
|
|
"tags": []
|
|
|
|
},
|
|
|
|
{
|
|
|
|
'groupBy': [
|
|
|
|
{'type': 'time', 'params': ['$__interval']},
|
|
|
|
{'type': 'fill', 'params': ['linear']},
|
|
|
|
],
|
|
|
|
'orderByTime': "ASC",
|
|
|
|
'policy': "default",
|
|
|
|
'query': f"""from(bucket: "telegraf")
|
|
|
|
|> range(start: v.timeRangeStart, stop: v.timeRangeStop)
|
|
|
|
|> filter(fn: (r) =>
|
|
|
|
r["_measurement"] == "zfs" and
|
|
|
|
r["_field"] == "arcstats_l2_misses" and
|
|
|
|
r["host"] == "{node.name}"
|
|
|
|
)
|
|
|
|
|> map(fn: (r) => ({{
|
|
|
|
r with
|
|
|
|
_field: "l2misses"
|
|
|
|
}})
|
|
|
|
)
|
|
|
|
|> aggregateWindow(every: v.windowPeriod, fn: mean, createEmpty: false)
|
|
|
|
|> derivative(unit: 1s, nonNegative: true)
|
|
|
|
|> yield(name: "misses")""",
|
|
|
|
'resultFormat': 'time_series',
|
|
|
|
'select': [[
|
|
|
|
{'type': 'field', 'params': ['value']},
|
|
|
|
{'type': 'mean', 'params': []},
|
|
|
|
]],
|
|
|
|
"tags": []
|
|
|
|
},
|
|
|
|
],
|
|
|
|
'thresholds': [],
|
|
|
|
'timeRegions': [],
|
|
|
|
'title': 'zfs arc hits/misses',
|
|
|
|
'tooltip': {
|
|
|
|
'shared': True,
|
|
|
|
'sort': 0,
|
|
|
|
'value_type': 'individual'
|
|
|
|
},
|
|
|
|
'type': 'graph',
|
|
|
|
'xaxis': {
|
|
|
|
'buckets': None,
|
|
|
|
'mode': 'time',
|
|
|
|
'name': None,
|
|
|
|
'show': True,
|
|
|
|
'values': []
|
|
|
|
},
|
|
|
|
'yaxes': [
|
|
|
|
{
|
|
|
|
'format': 'short',
|
|
|
|
'label': None,
|
|
|
|
'logBase': 1,
|
|
|
|
'max': None,
|
|
|
|
'min': 0,
|
|
|
|
'show': True,
|
|
|
|
'decimals': 0,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
'format': 'short',
|
|
|
|
'label': None,
|
|
|
|
'logBase': 1,
|
|
|
|
'max': None,
|
|
|
|
'min': None,
|
|
|
|
'show': False,
|
|
|
|
}
|
|
|
|
],
|
|
|
|
'yaxis': {
|
|
|
|
'align': False,
|
|
|
|
'alignLevel': None
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
'aliasColors': {},
|
|
|
|
'bars': False,
|
|
|
|
'dashLength': 10,
|
|
|
|
'dashes': False,
|
|
|
|
'datasource': None,
|
|
|
|
'fieldConfig': {
|
|
|
|
'defaults': {
|
|
|
|
'displayName': '${__field.labels.dataset} ${__field.name}'
|
|
|
|
},
|
|
|
|
'overrides': []
|
|
|
|
},
|
|
|
|
'fill': 1,
|
|
|
|
'fillGradient': 0,
|
|
|
|
'hiddenSeries': False,
|
|
|
|
'id': next(panel_id),
|
|
|
|
'legend': {
|
|
|
|
'alignAsTable': False,
|
|
|
|
'avg': False,
|
|
|
|
'current': False,
|
|
|
|
'max': False,
|
|
|
|
'min': False,
|
|
|
|
'rightSide': False,
|
|
|
|
'show': True,
|
|
|
|
'total': False,
|
|
|
|
'values': False
|
|
|
|
},
|
|
|
|
'lines': True,
|
|
|
|
'linewidth': 1,
|
|
|
|
'NonePointMode': 'None',
|
|
|
|
'options': {
|
|
|
|
'alertThreshold': True
|
|
|
|
},
|
|
|
|
'percentage': False,
|
|
|
|
'pluginVersion': '7.5.5',
|
|
|
|
'pointradius': 2,
|
|
|
|
'points': False,
|
|
|
|
'renderer': 'flot',
|
|
|
|
'seriesOverrides': [],
|
|
|
|
'spaceLength': 10,
|
|
|
|
'span': 6,
|
|
|
|
'stack': True,
|
|
|
|
'steppedLine': False,
|
|
|
|
'targets': [
|
|
|
|
{
|
|
|
|
'groupBy': [
|
|
|
|
{'type': 'time', 'params': ['$__interval']},
|
|
|
|
{'type': 'fill', 'params': ['linear']},
|
|
|
|
],
|
|
|
|
'orderByTime': "ASC",
|
|
|
|
'policy': "default",
|
|
|
|
'query': f"""from(bucket: "telegraf")
|
|
|
|
|> range(start: v.timeRangeStart, stop: v.timeRangeStop)
|
|
|
|
|> filter(fn: (r) =>
|
|
|
|
r["_measurement"] == "zfs_dataset" and
|
|
|
|
r["_field"] == "used" and
|
|
|
|
r["host"] == "{node.name}"
|
|
|
|
)
|
|
|
|
|> aggregateWindow(every: v.windowPeriod, fn: mean, createEmpty: false)
|
|
|
|
|> yield(name: "used")""",
|
|
|
|
'resultFormat': 'time_series',
|
|
|
|
'select': [[
|
|
|
|
{'type': 'field', 'params': ['value']},
|
|
|
|
{'type': 'mean', 'params': []},
|
|
|
|
]],
|
|
|
|
"tags": []
|
|
|
|
},
|
|
|
|
{
|
|
|
|
'groupBy': [
|
|
|
|
{'type': 'time', 'params': ['$__interval']},
|
|
|
|
{'type': 'fill', 'params': ['linear']},
|
|
|
|
],
|
|
|
|
'orderByTime': "ASC",
|
|
|
|
'policy': "default",
|
|
|
|
'query': f"""from(bucket: "telegraf")
|
|
|
|
|> range(start: v.timeRangeStart, stop: v.timeRangeStop)
|
|
|
|
|> filter(fn: (r) =>
|
|
|
|
r["_measurement"] == "zfs_dataset" and
|
|
|
|
r["_field"] == "usedsnap" and
|
|
|
|
r["host"] == "{node.name}"
|
|
|
|
)
|
|
|
|
|> aggregateWindow(every: v.windowPeriod, fn: mean, createEmpty: false)
|
|
|
|
|> yield(name: "out")""",
|
|
|
|
'resultFormat': 'time_series',
|
|
|
|
'select': [[
|
|
|
|
{'type': 'field', 'params': ['value']},
|
|
|
|
{'type': 'mean', 'params': []},
|
|
|
|
]],
|
|
|
|
"tags": []
|
|
|
|
},
|
|
|
|
],
|
|
|
|
'thresholds': [],
|
|
|
|
'timeRegions': [],
|
|
|
|
'title': 'zfs usage per dataset',
|
|
|
|
'tooltip': {
|
|
|
|
'shared': True,
|
|
|
|
'sort': 0,
|
|
|
|
'value_type': 'individual'
|
|
|
|
},
|
|
|
|
'type': 'graph',
|
|
|
|
'xaxis': {
|
|
|
|
'buckets': None,
|
|
|
|
'mode': 'time',
|
|
|
|
'name': None,
|
|
|
|
'show': True,
|
|
|
|
'values': []
|
|
|
|
},
|
|
|
|
'yaxes': [
|
|
|
|
{
|
2021-06-25 18:16:13 +00:00
|
|
|
'format': 'bytes',
|
2021-06-25 18:04:30 +00:00
|
|
|
'label': None,
|
|
|
|
'logBase': 1,
|
|
|
|
'max': None,
|
|
|
|
'min': 0,
|
|
|
|
'show': True,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
'format': 'short',
|
|
|
|
'label': None,
|
|
|
|
'logBase': 1,
|
|
|
|
'max': None,
|
|
|
|
'min': None,
|
|
|
|
'show': False,
|
|
|
|
}
|
|
|
|
],
|
|
|
|
'yaxis': {
|
|
|
|
'align': False,
|
|
|
|
'alignLevel': None
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
'aliasColors': {},
|
|
|
|
'bars': False,
|
|
|
|
'dashLength': 10,
|
|
|
|
'dashes': False,
|
|
|
|
'datasource': None,
|
|
|
|
'fieldConfig': {
|
|
|
|
'defaults': {
|
|
|
|
'displayName': '${__field.labels.pool} ${__field.name}'
|
|
|
|
},
|
|
|
|
'overrides': []
|
|
|
|
},
|
|
|
|
'fill': 1,
|
|
|
|
'fillGradient': 0,
|
|
|
|
'hiddenSeries': False,
|
|
|
|
'id': next(panel_id),
|
|
|
|
'legend': {
|
|
|
|
'alignAsTable': False,
|
|
|
|
'avg': False,
|
|
|
|
'current': False,
|
|
|
|
'max': False,
|
|
|
|
'min': False,
|
|
|
|
'rightSide': False,
|
|
|
|
'show': True,
|
|
|
|
'total': False,
|
|
|
|
'values': False
|
|
|
|
},
|
|
|
|
'lines': True,
|
|
|
|
'linewidth': 1,
|
|
|
|
'NonePointMode': 'None',
|
|
|
|
'options': {
|
|
|
|
'alertThreshold': True
|
|
|
|
},
|
|
|
|
'percentage': False,
|
|
|
|
'pluginVersion': '7.5.5',
|
|
|
|
'pointradius': 2,
|
|
|
|
'points': False,
|
|
|
|
'renderer': 'flot',
|
|
|
|
'seriesOverrides': [],
|
|
|
|
'spaceLength': 10,
|
|
|
|
'span': 6,
|
|
|
|
'stack': False,
|
|
|
|
'steppedLine': False,
|
|
|
|
'targets': [
|
|
|
|
{
|
|
|
|
'groupBy': [
|
|
|
|
{'type': 'time', 'params': ['$__interval']},
|
|
|
|
{'type': 'fill', 'params': ['linear']},
|
|
|
|
],
|
|
|
|
'orderByTime': "ASC",
|
|
|
|
'policy': "default",
|
|
|
|
'query': f"""from(bucket: "telegraf")
|
|
|
|
|> range(start: v.timeRangeStart, stop: v.timeRangeStop)
|
|
|
|
|> filter(fn: (r) =>
|
|
|
|
r["_measurement"] == "zfs_pool" and
|
|
|
|
r["_field"] == "free" and
|
|
|
|
r["host"] == "{node.name}"
|
|
|
|
)
|
|
|
|
|> aggregateWindow(every: v.windowPeriod, fn: mean, createEmpty: false)
|
|
|
|
|> yield(name: "in")""",
|
|
|
|
'resultFormat': 'time_series',
|
|
|
|
'select': [[
|
|
|
|
{'type': 'field', 'params': ['value']},
|
|
|
|
{'type': 'mean', 'params': []},
|
|
|
|
]],
|
|
|
|
"tags": []
|
|
|
|
},
|
|
|
|
{
|
|
|
|
'groupBy': [
|
|
|
|
{'type': 'time', 'params': ['$__interval']},
|
|
|
|
{'type': 'fill', 'params': ['linear']},
|
|
|
|
],
|
|
|
|
'orderByTime': "ASC",
|
|
|
|
'policy': "default",
|
|
|
|
'query': f"""from(bucket: "telegraf")
|
|
|
|
|> range(start: v.timeRangeStart, stop: v.timeRangeStop)
|
|
|
|
|> filter(fn: (r) =>
|
|
|
|
r["_measurement"] == "zfs_pool" and
|
|
|
|
r["_field"] == "size" and
|
|
|
|
r["host"] == "{node.name}"
|
|
|
|
)
|
|
|
|
|> aggregateWindow(every: v.windowPeriod, fn: mean, createEmpty: false)
|
|
|
|
|> yield(name: "out")""",
|
|
|
|
'resultFormat': 'time_series',
|
|
|
|
'select': [[
|
|
|
|
{'type': 'field', 'params': ['value']},
|
|
|
|
{'type': 'mean', 'params': []},
|
|
|
|
]],
|
|
|
|
"tags": []
|
|
|
|
},
|
|
|
|
],
|
|
|
|
'thresholds': [],
|
|
|
|
'timeRegions': [],
|
|
|
|
'title': 'zfs usage per pool',
|
|
|
|
'tooltip': {
|
|
|
|
'shared': True,
|
|
|
|
'sort': 0,
|
|
|
|
'value_type': 'individual'
|
|
|
|
},
|
|
|
|
'type': 'graph',
|
|
|
|
'xaxis': {
|
|
|
|
'buckets': None,
|
|
|
|
'mode': 'time',
|
|
|
|
'name': None,
|
|
|
|
'show': True,
|
|
|
|
'values': []
|
|
|
|
},
|
|
|
|
'yaxes': [
|
|
|
|
{
|
2021-06-25 18:16:13 +00:00
|
|
|
'format': 'bytes',
|
2021-06-25 18:04:30 +00:00
|
|
|
'label': None,
|
|
|
|
'logBase': 1,
|
|
|
|
'max': None,
|
|
|
|
'min': 0,
|
|
|
|
'show': True,
|
|
|
|
'decimals': 0,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
'format': 'short',
|
|
|
|
'label': None,
|
|
|
|
'logBase': 1,
|
|
|
|
'max': None,
|
|
|
|
'min': None,
|
|
|
|
'show': False,
|
|
|
|
}
|
|
|
|
],
|
|
|
|
'yaxis': {
|
|
|
|
'align': False,
|
|
|
|
'alignLevel': None
|
|
|
|
}
|
|
|
|
},
|
|
|
|
],
|
|
|
|
}
|