#prometheus #rtos #ci #push-gateway #github-actions #nuttx

app ingest-nuttx-builds

Ingest Build Logs from Apache NuttX RTOS into Prometheus Pushgateway

1 stable release

1.0.0 Dec 12, 2024

#974 in Command line utilities

Download history 117/week @ 2024-12-06 44/week @ 2024-12-13 1/week @ 2024-12-20

162 downloads per month

Apache-2.0

125KB
798 lines

Ingest Build Logs from Apache NuttX RTOS into Prometheus Pushgateway

Ingest Build Logs from Apache NuttX RTOS into Prometheus Pushgateway

Read the articles...

To ingest NuttX Build Logs into Prometheus Pushgateway: run.sh

## We prefer GitLab Snippets, since GitHub Gists will get blocked for overuse.
## For GitHub Gists: Any GitHub Token with read access will do
## export GITHUB_TOKEN=...
. $HOME/github-token.sh

## Find all defconfig files
cd $HOME ; git clone https://github.com/apache/nuttx
find $HOME/nuttx -name defconfig >/tmp/defconfig.txt

## Ingest logs from lupyuen/nuttx-build-log GitLab Snippets. Remove special characters.
## gitlab-token.sh contains "export GITHUB_TOKEN=...", any GitLab Token with read access will do.
set +x ; . $HOME/gitlab-token.sh ; set -x
cargo run -- \
  --user lupyuen \
  --repo nuttx-build-log \
  --defconfig /tmp/defconfig.txt \
  | tr -d '\033\007'
unset GITLAB_TOKEN

## Ingest logs from nuttxpr GitHub Gist. Remove special characters.
cargo run -- \
  --user nuttxpr \
  --defconfig /tmp/defconfig.txt \
  | tr -d '\033\007'

## Ingest logs from GitHub Actions
./github.sh

## Or: Start GitHub Actions Build, wait to complete then ingest logs
./build-github-and-ingest.sh

## Or: Sync NuttX Mirror Repo, start GitHub Actions Build, wait to complete then ingest logs
## https://github.com/lupyuen/nuttx-release/blob/main/sync-build-ingest.sh
../nuttx-release/sync-build-ingest.sh

(See the Ingest Log for GitHub Gists)

(See the Ingest Log for GitHub Actions)

To install Grafana and Prometheus...

## Install Grafana
brew install grafana
brew services start grafana
## Browse to http://localhost:3000

## Install Prometheus
brew install prometheus
brew services start prometheus
## Browse to http://localhost:9090

## Install Prometheus Pushgateway
brew install go
git clone https://github.com/prometheus/pushgateway
cd pushgateway
go run main.go &
## Browse to http://localhost:9091

Update the Grafana and Prometheus Configuration...

Add the Grafana Dashboard and Panels...

Remember to check for suspicious activity!

tail -f /opt/homebrew/var/log/grafana/grafana.log \
  | grep --line-buffered "logger=context " \
  | grep --line-buffered -v "path=/api/frontend-metrics " \
  | grep --line-buffered -v "path=/api/live/ws " \
  | grep --line-buffered -v "path=/api/plugins/grafana-lokiexplore-app/settings " \
  | grep --line-buffered -v "path=/api/user/auth-tokens/rotate " \
  | grep --line-buffered -v "path=/favicon.ico " \
  | cut -d ' ' -f 9-15

Highlight the HTTP Errors: iTerm > Profile > Advanced > Triggers...

  • Regular Expression: status=[4-9][^ ]+[ ], Action: Highlight Line, Background: Red
  • Regular Expression: path=[^ ]+[ ], Action: Highlight Text, Background: Dark Blue

If we see too many HTTP 404 Errors for Dubious URLs (we're not a WordPress Server!): Turn on Cloudflare > Under Attack Mode. The errors should disappear.

Dependencies

~15–29MB
~443K SLoC