https://github.com/Full-Monitoring/oluas_proxmox
Consumindo a API do Proxmox com HTTP Agent
https://github.com/Full-Monitoring/oluas_proxmox
api http-agent proxmox storage token
Last synced: 4 months ago
JSON representation
Consumindo a API do Proxmox com HTTP Agent
- Host: GitHub
- URL: https://github.com/Full-Monitoring/oluas_proxmox
- Owner: Full-Monitoring
- Created: 2021-07-09T23:05:01.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2022-06-13T20:01:30.000Z (over 2 years ago)
- Last Synced: 2024-07-09T20:19:38.260Z (8 months ago)
- Topics: api, http-agent, proxmox, storage, token
- Homepage: https://full-monitoring.github.io/oluas_proxmox/
- Size: 4.06 MB
- Stars: 16
- Watchers: 2
- Forks: 7
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# PROXMOX 6.3-2 + ZABBIX 5.0.14 + GRAFANA 8.1.1
## Usando item HTTP AGENT
## [Saulo Costa - Telegram](https://t.me/saulos2costa/ "telegram")
data:image/s3,"s3://crabby-images/3df45/3df456048ecbc93005fcee42bcddeb8231e53cb2" alt="image"
data:image/s3,"s3://crabby-images/4a839/4a839335e2bdfb61c365cf806183d8745bc2f721" alt="image"
data:image/s3,"s3://crabby-images/a7d83/a7d835b8dfd746c32310aef85ef1e3c89e014444" alt="print"
data:image/s3,"s3://crabby-images/d454c/d454c79ca14d8c2489f927821de4b919345a4fb3" alt="print"
data:image/s3,"s3://crabby-images/e2f82/e2f826a7a893a75f4a04f6f146b7fc5b39e012a8" alt="print"
[Criar Token API](https://youtu.be/Iuyd2TXe8SA)
- [Dashborad Grafana](/contents/dash_grafana.json "Dashborad Grafana")
## Sobre o Template Zabbix
> Adicione suas macros no host
data:image/s3,"s3://crabby-images/ccfb7/ccfb76fd74a609b035c89c4791b2dc399de0fde4" alt="image"
> Macros LLD
```js
{#NAME} -> $.name
{#TYPE} -> $.type
{#VMID} -> $.vmid
{#STORAGE} -> $.storage
{#NODE} -> $.node
```> Contador de vms, storages e nodes (total)
```js
$.body.data[?(@.type == 'qemu')].length()
$.body.data[?(@.type == 'storage')].length()
$.body.data[?(@.type == 'node')].length()
```> Contador de vms (ligadas)
```js
$.[?(@.status == 'running')].length()
```> Contador de vms (deligadas)
```js
$.[?(@.status == 'stopped')].length()
```> Filtros de contagem dos protótipos de itens tipo vm
```js
$.[?(@.name == '{#NAME}')].status.first()
$.[?(@.name == '{#NAME}')].uptime.first()
$.[?(@.name == '{#NAME}')].cpu.first()
$.[?(@.name == '{#NAME}')].maxcpu.first()
$.[?(@.name == '{#NAME}')].mem.first()
$.[?(@.name == '{#NAME}')].maxmem.first()
$.[?(@.name == '{#NAME}')].netin.first()
$.[?(@.name == '{#NAME}')].netout.first()
```> Item de calculo de porcentagem de memória ram da vm
```js
100*last("vm.mem[{#NAME}]")/last("vm.maxmem[{#NAME}]")
```> Alterando valores de retorno de status da vm de running ou stopped para 1 ou 0
```js
if (value == 'running'){
return 1;
} else {
return 0;
}
```> filtros de contagem dos protótipos de itens tipo storage
```js
$.[?(@.storage == '{#STORAGE}')].disk.first()
$.[?(@.storage == '{#STORAGE}')].maxdisk.first()
$.[?(@.storage == '{#STORAGE}')].status.first()
```> filtros de contagem dos protótipos de itens tipo storage
```js
$.[?(@.storage == '{#STORAGE}')].disk.first()
$.[?(@.storage == '{#STORAGE}')].maxdisk.first()
$.[?(@.storage == '{#STORAGE}')].status.first()
```> Alterando valores de retorno de status do node de available para 1
```js
if (value == 'available'){
return 1;
} else {
return 0;
}
```> Item de calculo de porcentagem de armazenamento do storage
```js
100*last("storage.disk[{#STORAGE}]")/last("storage.maxdisk[{#STORAGE}]")
```> Contador de storages disponíveis ou inidiponíveis
```js
$.[?(@.status == 'available')].length()
$.[?(@.status == 'unavailable')].length()
```> filtros de contagem dos protótipos de itens tipo node
```js
$.[?(@.node == '{#NODE}')].disk.first()
$.[?(@.node == '{#NODE}')].maxdisk.first()
$.[?(@.node == '{#NODE}')].uptime.first()
$.[?(@.node == '{#NODE}')].mem.first()
$.[?(@.node == '{#NODE}')].maxmem.first()
$.[?(@.node == '{#NODE}')].maxcpu.first()
$.[?(@.node == '{#NODE}')].status.first()
$.[?(@.node == '{#NODE}')].cpu.first()
```> Item de calculo de porcentagem de memoria ram e disco do node
```js
100*last("node.mem[{#NODE}]")/last("node.maxmem[{#NODE}]")
100*last("node.disk[{#NODE}]")/last("node.maxdisk[{#NODE}]")
```> Alterando valores de retorno de status do node de online e offiline para 1 ou 0
```js
if (value == 'online'){
return 1;
} else {
return 0;
}
```