Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(logs): add alloy + loki #451

Merged
merged 9 commits into from
Jan 6, 2025
Merged
Show file tree
Hide file tree
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
/kcov-output
/results
/validator
/logs
dnut marked this conversation as resolved.
Show resolved Hide resolved

# desktop app config
.DS_Store
Expand Down
70 changes: 30 additions & 40 deletions metrics/README.md
Original file line number Diff line number Diff line change
@@ -1,67 +1,52 @@
original src: https://github.com/docker/awesome-compose/tree/master/prometheus-grafana

## Setup
## Setup

requirements:
- `docker compose`
- [https://docs.docker.com/engine/install/ubuntu/](https://docs.docker.com/engine/install/ubuntu/)
- either mac or linux supported

modify `/etc/hosts` to include the following line:
```
127.0.0.1 prometheus
```
requirements:

- `docker compose`
- [https://docs.docker.com/engine/install/ubuntu/](https://docs.docker.com/engine/install/ubuntu/)
- macos or linux (windows untested/unsupported)

## Running
## Running

mac: `docker compose -f compose_mac.yaml up -d`
linux: `docker compose -f compose_linux.yaml up -d`
mac: `docker compose up -d`
linux: `docker compose up -d`

- grafana will be accessable on `localhost:3000`
- note: `username: admin password: grafana`
- prometheus will be accessable on `localhost:9090`
- sig metrics will be published to localhost:12345 (if you change this on the sig cli, you will
need to also modify the prometheus `target` to point to the different port).
- sig metrics will be published to localhost:12345 (if you change this on the sig cli, you will
need to also modify the prometheus `target` to point to the different port).
- sig gossip metrics are published to localhost:12355
dnut marked this conversation as resolved.
Show resolved Hide resolved

## Shutting down

mac: `docker compose -f compose_mac.yaml down`
linux: `docker compose -f compose_linux.yaml down`
mac: `docker compose down`
linux: `docker compose down`

## Compose sample

### Prometheus & Grafana

Project structure:

```
.
├── compose_linux.yaml
├── compose_mac.yaml
├── docker-compose.yml
├── alloy -- this scrapes logs/ and pushes to loki
├── loki -- log database
├── grafana
│   └── dashboards/ -- this is where the sig dashboard lives (will need to copy .json export of dashboard from running container and push through git for any dashboard changes)
│   └── datasources/ -- this points to prometheus docker
├── prometheus
│   └── prometheus.yml
│   └── prometheus.yml
└── README.md
```

[_compose.yaml_](compose.yaml)
```
services:
prometheus:
image: prom/prometheus
...
ports:
- 9090:9090
grafana:
image: grafana/grafana
...
ports:
- 3000:3000
```
The compose file defines a stack with two services `prometheus` and `grafana`.
When deploying the stack, docker compose maps port the default ports for each service to the equivalent ports on the host in order to inspect easier the web interface of each service.
Make sure the ports 9090 and 3000 on the host are not already in use.
## Run with logs

`./zig-out/bin/sig gossip -n testnet 2>&1 | tee -a logs/sig.log`

## Deploy with docker compose

Expand All @@ -79,11 +64,15 @@ Attaching to prometheus, grafana
## Expected result

Listing containers must show two containers running and the port mapping as below:

```
$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
dbdec637814f prom/prometheus "/bin/prometheus --c…" 8 minutes ago Up 8 minutes 0.0.0.0:9090->9090/tcp prometheus
79f667cb7dc2 grafana/grafana "/run.sh" 8 minutes ago Up 8 minutes 0.0.0.0:3000->3000/tcp grafana
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
948f31ee975a prom/prometheus "/bin/prometheus --c…" 32 seconds ago Up 3 seconds 0.0.0.0:9090->9090/tcp, :::9090->9090/tcp prometheus
adc6fb731842 grafana/grafana "/run.sh" 32 seconds ago Up 3 seconds 0.0.0.0:3000->3000/tcp, :::3000->3000/tcp grafana
e698bc98a061 grafana/alloy:v1.3.1 "/bin/alloy run --se…" 32 seconds ago Up 3 seconds 0.0.0.0:3200->3200/tcp, :::3200->3200/tcp alloy
f774e615e5b1 grafana/loki:3.0.0 "/usr/bin/loki --con…" 32 seconds ago Up 3 seconds 0.0.0.0:3100->3100/tcp, :::3100->3100/tcp loki
27ee173b0491 prom/node-exporter "/bin/node_exporter" 32 seconds ago Up 3 seconds 0.0.0.0:9100->9100/tcp, :::9100->9100/tcp node-exporter
```

Navigate to `http://localhost:3000` in your web browser and use the login credentials specified in the compose file to access Grafana. It is already configured with prometheus as the default datasource.
Expand All @@ -93,6 +82,7 @@ Navigate to `http://localhost:3000` in your web browser and use the login creden
Navigate to `http://localhost:9090` in your web browser to access directly the web interface of prometheus.

Stop and remove the containers. Use `-v` to remove the volumes if looking to erase all data.

```
$ docker compose down -v
```
16 changes: 16 additions & 0 deletions metrics/alloy/config.alloy
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
local.file_match "local_files" {
path_targets = [{"__path__" = "/var/log/alloy/*.log"}]
sync_period = "1s"
}

loki.source.file "log_scrape" {
targets = local.file_match.local_files.targets
forward_to = [loki.write.grafana_loki.receiver]
tail_from_end = true
}

loki.write "grafana_loki" {
endpoint {
url = "http://loki:3100/loki/api/v1/push"
}
}
33 changes: 0 additions & 33 deletions metrics/compose_mac.yaml

This file was deleted.

42 changes: 37 additions & 5 deletions metrics/compose_linux.yaml → metrics/docker-compose.yml
Original file line number Diff line number Diff line change
@@ -1,18 +1,48 @@
services:
prometheus:
network_mode: "host" # -- only linux
image: prom/prometheus
container_name: prometheus
command:
- "--config.file=/etc/prometheus/prometheus.yml"
restart: unless-stopped
ports:
- 9090:9090
restart: unless-stopped
volumes:
- ./prometheus:/etc/prometheus
- prom_data:/prometheus
command:
- "--config.file=/etc/prometheus/prometheus.yml"
# "--log.level=debug" # Not receiving metrics? Consider uncommenting

# Prometheus needs to be able to connect to the host network as "sig" isn't
# containerised. No other service should talk to the host.
extra_hosts:
- "host.docker.internal:host-gateway"

loki:
image: grafana/loki:3.0.0
container_name: loki
ports:
- "3100:3100"
0xNineteen marked this conversation as resolved.
Show resolved Hide resolved
volumes:
- ./loki:/etc/loki
dnut marked this conversation as resolved.
Show resolved Hide resolved
command:
- "--config.file=/etc/loki/loki.yml"

alloy:
image: grafana/alloy:v1.3.1
container_name: alloy
ports:
- "3200:3200"
volumes:
- "./alloy/config.alloy:/etc/alloy/config.alloy"
- "../logs:/var/log/alloy"
dnut marked this conversation as resolved.
Show resolved Hide resolved
command:
[
"run",
"--server.http.listen-addr=0.0.0.0:3200",
"/etc/alloy/config.alloy",
]

grafana:
network_mode: "host" # -- only linux
image: grafana/grafana
container_name: grafana
ports:
Expand All @@ -25,11 +55,13 @@ services:
- ./grafana/datasources:/etc/grafana/provisioning/datasources
- ./grafana/dashboards:/etc/grafana/provisioning/dashboards
- ./grafana/dashboards:/var/lib/grafana/dashboards

node-exporter:
image: prom/node-exporter
container_name: node-exporter
ports:
- 9100:9100
restart: unless-stopped

volumes:
prom_data:
Loading
Loading