K6 Loki qxip/qryn #10
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: K6 Loki qxip/qryn | |
on: | |
workflow_dispatch: | |
inputs: | |
qryn_tag: | |
description: 'Build/Tag for qryn (latest)' | |
required: false | |
clickhouse_tag: | |
description: 'BuildTag for ClickHouse (latest)' | |
required: false | |
jobs: | |
build: | |
name: Run k6 on qryn:latest | |
runs-on: ubuntu-latest | |
env: | |
CLICKHOUSE_VERSION: "ghcr.io/chdb-io/chdb-server:${{ github.event.inputs.qryn_tag || 'latest' }}" | |
QRYN_VERSION: "qxip/qryn:${{ github.event.inputs.clickhouse_tag || 'latest' }}" | |
services: | |
clickhouse: | |
image: "ghcr.io/chdb-io/chdb-server:${{ github.event.inputs.clickhouse_tag || 'latest' }}" | |
ports: | |
- 8123:8123 | |
env: | |
PORT: 8123 | |
qryn: | |
image: "ghcr.io/metrico/qryn:${{ github.event.inputs.qryn_tag || 'latest' }}" | |
ports: | |
- 3100:3100 | |
env: | |
CLICKHOUSE_SERVER: clickhouse | |
CLICKHOUSE_AUTH: "qryn:qryn" | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
with: | |
repository: metrico/qryn-bench | |
path: . | |
- uses: actions/setup-go@v4 | |
with: | |
go-version: '1.20' | |
- name: Download k6 for Prometheus | |
run: | | |
wget https://github.com/metrico/qryn-bench/releases/download/latest/k6 | |
chmod +x k6 | |
- name: Download k6 for Prometheus | |
run: | | |
wget https://github.com/metrico/qryn-bench/releases/download/latest/k6-tracing -O k6-tracing | |
chmod +x k6-tracing | |
- name: Wait for API | |
uses: mydea/action-wait-for-api@v1 | |
with: | |
url: "http://localhost:3100/loki/api/v1/label" | |
expected-response-field: "status" | |
expected-response-field-value: "success" | |
timeout: 30 | |
- name: Run k6 loki test | |
run: ./k6 run --out csv=results.csv loki/qryn-loki-loadtest.js | |
env: | |
K6_VUS: 1 | |
K6_ITERACTIONS: 10 | |
- run: mv summary.txt loki_summary.txt | |
- name: Run k6 local test | |
run: ./k6 run --out csv=results.csv prometheus/qryn-loadtest.js | |
env: | |
K6_WRITE_HOSTNAME: "localhost:3100" | |
K6_READ_HOSTNAME: "localhost:3100" | |
K6_WRITE_REQUEST_RATE: 1 | |
K6_WRITE_SERIES_PER_REQUEST: 1 | |
K6_READ_REQUEST_RATE: 1 | |
K6_DURATION_MIN: 1 | |
K6_SCRAPE_INTERVAL_SECONDS: 30 | |
RAMP_UP_MIN: 0 | |
- run: mv summary.txt prom_summary.txt | |
- name: Run k6 tempo test | |
run: ./k6-tracing run --out csv=results.csv tempo/qryn-tempo-template.js | |
env: | |
K6_TEMPO_ENDPOINT: "http://localhost:3100" | |
K6_VUS: 1 | |
K6_DURATION_MINUTES: 1 | |
K6_ITERATIONS: 10 | |
- run: mv summary.txt tempo_summary.txt | |
- name: Strip Text report | |
run: | | |
sed -i 's/[^[:print:]]/*/' *_summary.txt | |
sed -i 's/[\d128-\d255]//g' *_summary.txt | |
- uses: actions/upload-artifact@v3 | |
with: | |
name: results | |
path: | | |
loki_summary.txt | |
prom_summary.txt | |
tempo_summary.txt | |
- name: Summary Report | |
run: | | |
echo "### qryn image" >> $GITHUB_STEP_SUMMARY | |
echo "qxip/qryn:${{ github.event.inputs.qryn_tag || 'latest' }}" >> $GITHUB_STEP_SUMMARY | |
echo "" >> $GITHUB_STEP_SUMMARY | |
echo "### chdb image" >> $GITHUB_STEP_SUMMARY | |
echo "ghcr.io/chdb-io/chdb-server:${{ github.event.inputs.clickhouse_tag || 'latest' }}" >> $GITHUB_STEP_SUMMARY | |
echo "" >> $GITHUB_STEP_SUMMARY | |
echo "### Loki Test" >> $GITHUB_STEP_SUMMARY | |
cat loki_summary.txt >> $GITHUB_STEP_SUMMARY | |
echo "" >> $GITHUB_STEP_SUMMARY | |
echo "### Prometheus Test" >> $GITHUB_STEP_SUMMARY | |
cat prom_summary.txt >> $GITHUB_STEP_SUMMARY | |
echo "" >> $GITHUB_STEP_SUMMARY | |
echo "### Tempo Test" >> $GITHUB_STEP_SUMMARY | |
cat tempo_summary.txt >> $GITHUB_STEP_SUMMARY | |
- name: Pull Docker logs | |
run: | | |
docker logs "${{ job.services.clickhouse.id }}" | |
docker logs "${{ job.services.qryn.id }}" |