From c90d5c5860ad63fa886d7d8748caff7acbed9552 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Mon, 23 Oct 2023 13:10:29 +0200 Subject: [PATCH 01/13] build(deps-dev): bump undici from 5.20.0 to 5.26.3 (#354) Bumps [undici](https://github.com/nodejs/undici) from 5.20.0 to 5.26.3. - [Release notes](https://github.com/nodejs/undici/releases) - [Commits](https://github.com/nodejs/undici/compare/v5.20.0...v5.26.3) --- updated-dependencies: - dependency-name: undici dependency-type: indirect ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Lorenzo Mangani --- package-lock.json | 69 +++++++++++++++++------------------------------ 1 file changed, 24 insertions(+), 45 deletions(-) diff --git a/package-lock.json b/package-lock.json index b3a8b290..f846c24e 100644 --- a/package-lock.json +++ b/package-lock.json @@ -823,6 +823,15 @@ "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==" }, + "node_modules/@fastify/busboy": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/@fastify/busboy/-/busboy-2.0.0.tgz", + "integrity": "sha512-JUFJad5lv7jxj926GPgymrWQxxjPYuJNiNjNMzqT+HiuP6Vl3dk5xzG+8sTX96np0ZAluvaMzPsjhHZ5rNuNQQ==", + "dev": true, + "engines": { + "node": ">=14" + } + }, "node_modules/@fastify/compress": { "version": "6.2.0", "resolved": "https://registry.npmjs.org/@fastify/compress/-/compress-6.2.0.tgz", @@ -3840,18 +3849,6 @@ "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==" }, - "node_modules/busboy": { - "version": "1.6.0", - "resolved": "https://registry.npmjs.org/busboy/-/busboy-1.6.0.tgz", - "integrity": "sha512-8SFQbg/0hQ9xy3UNTB0YEnsNBbWfhf7RtnzpL7TkBiTBRfrQ9Fxcnz7VJsleJpyp6rVLvXiuORqjlHi5q+PYuA==", - "dev": true, - "dependencies": { - "streamsearch": "^1.1.0" - }, - "engines": { - "node": ">=10.16.0" - } - }, "node_modules/cache-base": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/cache-base/-/cache-base-1.0.1.tgz", @@ -12352,15 +12349,6 @@ "resolved": "https://registry.npmjs.org/stream-shift/-/stream-shift-1.0.1.tgz", "integrity": "sha512-AiisoFqQ0vbGcZgQPY1cdP2I76glaVA/RauYR4G4thNFgkTqr90yXTo4LYX60Jl+sIlPNHHdGSwo01AvbKUSVQ==" }, - "node_modules/streamsearch": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/streamsearch/-/streamsearch-1.1.0.tgz", - "integrity": "sha512-Mcc5wHehp9aXz1ax6bZUyY5afg9u2rv5cqQI3mRrYkGC8rW2hM02jWuwjtL++LS5qinSyhj2QfLyNsuc+VsExg==", - "dev": true, - "engines": { - "node": ">=10.0.0" - } - }, "node_modules/string_decoder": { "version": "1.3.0", "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", @@ -13053,15 +13041,15 @@ } }, "node_modules/undici": { - "version": "5.20.0", - "resolved": "https://registry.npmjs.org/undici/-/undici-5.20.0.tgz", - "integrity": "sha512-J3j60dYzuo6Eevbawwp1sdg16k5Tf768bxYK4TUJRH7cBM4kFCbf3mOnM/0E3vQYXvpxITbbWmBafaDbxLDz3g==", + "version": "5.26.3", + "resolved": "https://registry.npmjs.org/undici/-/undici-5.26.3.tgz", + "integrity": "sha512-H7n2zmKEWgOllKkIUkLvFmsJQj062lSm3uA4EYApG8gLuiOM0/go9bIoC3HVaSnfg4xunowDE2i9p8drkXuvDw==", "dev": true, "dependencies": { - "busboy": "^1.6.0" + "@fastify/busboy": "^2.0.0" }, "engines": { - "node": ">=12.18" + "node": ">=14.0" } }, "node_modules/union-value": { @@ -14103,6 +14091,12 @@ } } }, + "@fastify/busboy": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/@fastify/busboy/-/busboy-2.0.0.tgz", + "integrity": "sha512-JUFJad5lv7jxj926GPgymrWQxxjPYuJNiNjNMzqT+HiuP6Vl3dk5xzG+8sTX96np0ZAluvaMzPsjhHZ5rNuNQQ==", + "dev": true + }, "@fastify/compress": { "version": "6.2.0", "resolved": "https://registry.npmjs.org/@fastify/compress/-/compress-6.2.0.tgz", @@ -16411,15 +16405,6 @@ "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==" }, - "busboy": { - "version": "1.6.0", - "resolved": "https://registry.npmjs.org/busboy/-/busboy-1.6.0.tgz", - "integrity": "sha512-8SFQbg/0hQ9xy3UNTB0YEnsNBbWfhf7RtnzpL7TkBiTBRfrQ9Fxcnz7VJsleJpyp6rVLvXiuORqjlHi5q+PYuA==", - "dev": true, - "requires": { - "streamsearch": "^1.1.0" - } - }, "cache-base": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/cache-base/-/cache-base-1.0.1.tgz", @@ -22968,12 +22953,6 @@ "resolved": "https://registry.npmjs.org/stream-shift/-/stream-shift-1.0.1.tgz", "integrity": "sha512-AiisoFqQ0vbGcZgQPY1cdP2I76glaVA/RauYR4G4thNFgkTqr90yXTo4LYX60Jl+sIlPNHHdGSwo01AvbKUSVQ==" }, - "streamsearch": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/streamsearch/-/streamsearch-1.1.0.tgz", - "integrity": "sha512-Mcc5wHehp9aXz1ax6bZUyY5afg9u2rv5cqQI3mRrYkGC8rW2hM02jWuwjtL++LS5qinSyhj2QfLyNsuc+VsExg==", - "dev": true - }, "string_decoder": { "version": "1.3.0", "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", @@ -23504,12 +23483,12 @@ "integrity": "sha1-5z3T17DXxe2G+6xrCufYxqadUPo=" }, "undici": { - "version": "5.20.0", - "resolved": "https://registry.npmjs.org/undici/-/undici-5.20.0.tgz", - "integrity": "sha512-J3j60dYzuo6Eevbawwp1sdg16k5Tf768bxYK4TUJRH7cBM4kFCbf3mOnM/0E3vQYXvpxITbbWmBafaDbxLDz3g==", + "version": "5.26.3", + "resolved": "https://registry.npmjs.org/undici/-/undici-5.26.3.tgz", + "integrity": "sha512-H7n2zmKEWgOllKkIUkLvFmsJQj062lSm3uA4EYApG8gLuiOM0/go9bIoC3HVaSnfg4xunowDE2i9p8drkXuvDw==", "dev": true, "requires": { - "busboy": "^1.6.0" + "@fastify/busboy": "^2.0.0" } }, "union-value": { From 6573c7d427b7f525f0e5ed98d3dae8194b94b641 Mon Sep 17 00:00:00 2001 From: Automated Version Bump Date: Mon, 23 Oct 2023 11:10:52 +0000 Subject: [PATCH 02/13] ci: version bump to v2.4.4 --- package-lock.json | 4 ++-- package.json | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/package-lock.json b/package-lock.json index f846c24e..68960f27 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,12 +1,12 @@ { "name": "qryn", - "version": "2.4.3", + "version": "2.4.4", "lockfileVersion": 2, "requires": true, "packages": { "": { "name": "qryn", - "version": "2.4.3", + "version": "2.4.4", "hasInstallScript": true, "license": "AGPL-3.0", "dependencies": { diff --git a/package.json b/package.json index 8ac48b90..36c565f3 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "qryn", - "version": "2.4.3", + "version": "2.4.4", "description": "Polyglot Observability Stack with ClickHouse storage", "main": "qryn.js", "bin": { From 0fa66cd34eb0591a395037ded6cfba6588490864 Mon Sep 17 00:00:00 2001 From: Lorenzo Mangani Date: Tue, 24 Oct 2023 22:07:53 +0200 Subject: [PATCH 03/13] Update bump_version.yml Signed-off-by: Lorenzo Mangani --- .github/workflows/bump_version.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/bump_version.yml b/.github/workflows/bump_version.yml index fa367728..7fa0222e 100644 --- a/.github/workflows/bump_version.yml +++ b/.github/workflows/bump_version.yml @@ -1,4 +1,4 @@ -name: 'Bump & Publish Multi-Arch' +name: 'Build Multi-Arch' on: push: From 095972e5f8dcb5153e67b4a12f8faf76b9e96d12 Mon Sep 17 00:00:00 2001 From: Lorenzo Mangani Date: Tue, 24 Oct 2023 22:18:33 +0200 Subject: [PATCH 04/13] Update README.md Signed-off-by: Lorenzo Mangani --- README.md | 64 ++++++++++++++++++++++++++++++++----------------------- 1 file changed, 37 insertions(+), 27 deletions(-) diff --git a/README.md b/README.md index c555f51d..16884cc7 100644 --- a/README.md +++ b/README.md @@ -7,50 +7,51 @@ Matrix + + cloud + -# [qryn.dev](https://qryn.dev) :cloud: [qryn.cloud](https://qryn.cloud) :heart: -> ... it's pronounced /ˈkwɪr..ɪŋ/ or just querying +# [qryn](https://qryn.dev) :cloud: [qryn.cloud](https://qryn.cloud) +> ... it's pronounced /ˈkwɪr..ɪŋ/ or just _querying_ ![image](https://user-images.githubusercontent.com/1423657/232089970-c4536f16-5967-4051-85a5-8ad94fcde67c.png) -:rocket: **qryn** is a _drop-in Grafana compatible_ **polyglot observability** framework
-- **Logs, Metrics and Traces** living happily together. Drop-in compatible with multiple vendors formats. -- Native [LogQL/PromQL/TempoQL APIs](https://qryn.cloud) support for [querying](https://github.com/lmangani/qryn/wiki/LogQL-for-Beginners), [processing](https://github.com/lmangani/qryn/wiki/LogQL-Supported-Queries), [tracing](https://github.com/lmangani/qryn/wiki/Tempo-Tracing) and [alerting](https://github.com/lmangani/qryn/wiki/Ruler---Alerts) [^2] in [Grafana](http://docs.grafana.org/features/explore/) [^3] -- Search, filter and extract metrics from _logs, events, spans and traces_ using familiar languages. _SQL Optional_. -- Ingestion [APIs](https://qryn.metrico.in/#/support) transparently compatible with [Opentelemetry, Loki, Prometheus, InfluxDB, Elastic](https://qryn.dev) _and [more](https://github.com/metrico/otel-collector)_ -- Ready to use with popular Agents such as [Promtail, Grafana-Agent, Vector, Logstash, Telegraf](https://qryn.metrico.in/#/ingestion) _and more_ -- Built in [Explore UI](https://github.com/metrico/cloki-view) and [CLI](https://github.com/lmangani/vLogQL) for querying supported datasources -- Designed for edge _(js/bun/wasm)_ and core/backend deployments _(golang/rust)_. -- Total data control. Compatible with [ClickHouse](https://clickhouse.com/) or [InfluxDB IOx](https://influxdata.com) with S3 object storage. - -:rocket: **qryn.cloud** is the _supercharged_ **qryn** version developed in _go_ with additional _functionality, speed and features!_
+:rocket: **qryn** is a _lighweight, multi-standard drop-in compatible_ **polyglot observability** framework for _**Logs, Metrics and Traces**_.
+- **Unified Query Language**: Use native **LogQL, PromQL**, and **TempoQL** languages to query, process and alert _with any data_. +- **Versatile Ingestion**: Ingest any vendor format compatible with **Opentelemetry, Loki, Prometheus, Influx, Datadog, Elastic** _and more_. +- **Built-in Explorer**: Explore data with qryn's built-in **Explore UI** and **CLI**, or use **Grafana** with _100% native_ compatibility. +- **Total Data Control**: Take full control of your data, using **ClickHouse** or **InfluxDB IOx** on top of disposable **S3** object storage. +- **Freedom of Choice**: Unlimited FOSS deployments or **qryn.cloud** service with advanced features and additional performance. +- **Cost Effective**: Do more with less, achieving the same results as the competition for a fractions of the cost and complexity.
- - - - -
## 🚀 [Get Started](https://qryn.metrico.in/#/installation) -:octocat: Get qryn OSS up and running on-prem in no time using the [Documentation](https://qryn.metrico.in/#/installation) or join our [Matrix Room](https://matrix.to/#/#qryn:matrix.org) +* Deploy qryn OSS using the [documentation](https://qryn.metrico.in/#/installation) or get help in our [Matrix room](https://matrix.to/#/#qryn:matrix.org) :octocat: +* Create a free account on [qryn.cloud](https://qryn.cloud) and get polyglot without moving a finger ☁️ -☁️ Create a free account on [qryn.cloud](https://qryn.cloud) and go straight to production at any scale with **polyglot confidence**. + + + +

-## Supported Features +## Features ### 📚 OpenTelemetry -qryn fully supports opentelemetry and comes with a powerful [otel-collector](https://github.com/metrico/otel-collector) distribution supporting _any log, trace or metric format_ and writing directly to ClickHouse _qryn tables_ ready to be consumed through any query API. +qryn is officially integrated with [opentelemetry](https://github.com/metrico/otel-collector) supports _any log, trace or metric format_ ### 📚 LogQL -qryn implements a complete [LogQL API](https://github.com/lmangani/qryn/wiki/LogQL-Supported-Queries) to provide transparent compatibility with Loki clients
+ +> Any Loki compatible client or application can be used with qryn out of the box + +qryn implements a full [LogQL API](https://github.com/lmangani/qryn/wiki/LogQL-Supported-Queries) to provide transparent compatibility with Loki
The Grafana Loki datasource can be used to natively browse and query _logs_ and display extracted _timeseries_
@@ -59,11 +60,15 @@ The Grafana Loki datasource can be used to natively browse and query _logs_ and :tada: _No plugins needed_ +
### 📈 Prometheus -qryn implements a complete [Prometheus API](https://github.com/lmangani/qryn/wiki/LogQL-Supported-Queries) to provide transparent compatibility with Prometheus clients
-The Grafana Prometheus datasource can be used to natively browse and query _metrics_ and display extracted _timeseries_
+ +> Any Prometheus compatible client or application can be used with qryn out of the box + +qryn is the first platform to deliver full [Prometheus API](https://prometheus.io/docs/prometheus/latest/querying/api/) compatibility using WASM 🏆
+The Grafana Prometheus datasource can be used to natively to query _metrics_ and display _timeseries_
@@ -71,11 +76,16 @@ The Grafana Prometheus datasource can be used to natively browse and query _metr :tada: _No plugins needed_ +
### 🕛 Tempo + qryn implements the [Tempo API](https://github.com/lmangani/qryn/wiki/LogQL-Supported-Queries) to provide transparent compatibility with Tempo/OTLP clients.
-The Tempo datasource can be used to natively query _traces_ including _beta search_ and _service graphs_
+ +> Any Tempo/Opentelemetry compatible client or application can be used with qryn out of the box + +The Tempo datasource can be used to natively query _traces_ including _**TraceQL**_ and supporting _service graphs_
@@ -86,7 +96,7 @@ The Tempo datasource can be used to natively query _traces_ including _beta sear
### ↔️ Correlation -Data correlation made simple with dynamic **links** between _logs, metrics and traces_ +Data correlation is simple using qryn's drop-in compatibility with **Grafana** native datasources.
From 8559c5aa6588229e553ee87cae4d898411cb0dce Mon Sep 17 00:00:00 2001 From: Lorenzo Mangani Date: Tue, 24 Oct 2023 22:39:19 +0200 Subject: [PATCH 05/13] Update Release Action - Releases synced with Tags - Only publish upon new release Signed-off-by: Lorenzo Mangani --- .github/workflows/bump_version.yml | 48 +++++++++++------------------- 1 file changed, 17 insertions(+), 31 deletions(-) diff --git a/.github/workflows/bump_version.yml b/.github/workflows/bump_version.yml index fa367728..c05f2a1b 100644 --- a/.github/workflows/bump_version.yml +++ b/.github/workflows/bump_version.yml @@ -1,39 +1,25 @@ -name: 'Bump & Publish Multi-Arch' +name: 'Build Multi-Arch' on: - push: - branches: - - 'master' - paths-ignore: - - '**.md' - - '**.yml' - - '**.yaml' + release: + types: [created] jobs: - bump-version: - name: 'Bump Version on master & Publish' + build: + name: 'Build & Publish' runs-on: ubuntu-latest steps: - name: 'Checkout source code' - uses: 'actions/checkout@v2' + uses: 'actions/checkout@v3' with: ref: ${{ github.ref }} - - name: 'cat package.json' - run: cat ./package.json - - name: 'Automated Version Bump' - id: version-bump - uses: 'phips28/gh-action-bump-version@master' - with: - tag-prefix: 'v' - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - - name: 'cat package.json' - run: cat ./package.json - - name: 'Output Step' - env: - NEW_TAG: ${{ steps.version-bump.outputs.newTag }} - run: echo "new tag $NEW_TAG" + - uses: MYXOMOPX/modify-pkg-json@master + id: setcmnver + with: + target: ./package.json + action: "set_version" + argument: "${{ github.ref_name }}" - name: Check NPM secret presence id: checksecrets shell: bash @@ -45,10 +31,10 @@ jobs: fi env: SECRET: ${{ secrets.NPM_TOKEN }} - - uses: actions/setup-node@v1 + - uses: actions/setup-node@v4.0.0 if: ${{ steps.checksecrets.outputs.secretspresent }} with: - node-version: 14 + node-version: 18 - name: Publish to NPM if: ${{ steps.checksecrets.outputs.secretspresent }} run: | @@ -93,9 +79,9 @@ jobs: push: true tags: | qxip/qryn:latest - qxip/qryn:${{ steps.version-bump.outputs.newTag }} + qxip/qryn:${{ github.ref_name }} qxip/cloki:latest - qxip/cloki:${{ steps.version-bump.outputs.newTag }} + qxip/cloki:${{ github.ref_name }} - name: Log in to the GHCR registry uses: docker/login-action@v2.0.0 @@ -111,4 +97,4 @@ jobs: push: true tags: | ghcr.io/metrico/qryn:latest - ghcr.io/metrico/qryn:${{ steps.version-bump.outputs.newTag }} + ghcr.io/metrico/qryn:${{ github.ref_name }} From 4336b4ed840d6c50e0f8ca41be8556a919350025 Mon Sep 17 00:00:00 2001 From: Lorenzo Mangani Date: Tue, 24 Oct 2023 22:39:52 +0200 Subject: [PATCH 06/13] Delete .github/workflows/bump_version_beta.yml Signed-off-by: Lorenzo Mangani --- .github/workflows/bump_version_beta.yml | 95 ------------------------- 1 file changed, 95 deletions(-) delete mode 100644 .github/workflows/bump_version_beta.yml diff --git a/.github/workflows/bump_version_beta.yml b/.github/workflows/bump_version_beta.yml deleted file mode 100644 index 96cab544..00000000 --- a/.github/workflows/bump_version_beta.yml +++ /dev/null @@ -1,95 +0,0 @@ -name: 'Bump & Publish' - -on: - push: - branches: - - 'beta' - paths-ignore: - - '**.md' - - '**.yml' - - '**.yaml' - -jobs: - bump-version: - name: 'Bump Version on master & Publish' - runs-on: ubuntu-latest - - steps: - - name: 'Checkout source code' - uses: 'actions/checkout@v2' - with: - ref: ${{ github.ref }} - - name: 'cat package.json' - run: cat ./package.json - - name: 'Automated Version Bump' - id: version-bump - uses: 'phips28/gh-action-bump-version@master' - with: - tag-prefix: 'v' - tag-suffix: '-beta' - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - - name: 'cat package.json' - run: cat ./package.json - - name: 'Output Step' - env: - NEW_TAG: ${{ steps.version-bump.outputs.newTag }} - run: echo "new tag $NEW_TAG" - - name: Check NPM secret presence - id: checksecrets - shell: bash - run: | - if [ "$SECRET" == "" ]; then - echo ::set-output name=secretspresent::false - else - echo ::set-output name=secretspresent::true - fi - env: - SECRET: ${{ secrets.NPM_TOKEN }} - - uses: actions/setup-node@v1 - if: ${{ steps.checksecrets.outputs.secretspresent }} - with: - node-version: 14 - - name: Publish to NPM - if: ${{ steps.checksecrets.outputs.secretspresent }} - run: | - npm config set //registry.npmjs.org/:_authToken ${NPM_TOKEN} - npm install - npm publish --access public - env: - NPM_TOKEN: ${{ secrets.NPM_TOKEN }} - - - name: Check Docker secret presence - id: checkdocker - shell: bash - run: | - if [ "$SECRET" == "" ]; then - echo ::set-output name=secretspresent::false - else - echo ::set-output name=secretspresent::true - fi - env: - SECRET: ${{ secrets.DOCKERHUB_TOKEN }} - - name: Set up Docker QEMU - if: ${{ steps.checkdocker.outputs.secretspresent }} - uses: docker/setup-qemu-action@v1 - - name: Set up Docker Buildx - if: ${{ steps.checkdocker.outputs.secretspresent }} - uses: docker/setup-buildx-action@v1 - - name: Login to DockerHub - if: ${{ steps.checkdocker.outputs.secretspresent }} - uses: docker/login-action@v1 - with: - username: ${{ secrets.DOCKERHUB_USERNAME }} - password: ${{ secrets.DOCKERHUB_TOKEN }} - - name: Build and push - if: ${{ steps.checkdocker.outputs.secretspresent }} - id: docker_build - uses: docker/build-push-action@v2 - with: - push: true - tags: | - qxip/qryn:latest - qxip/qryn:${{ steps.version-bump.outputs.newTag }} - qxip/cloki:latest - qxip/cloki:${{ steps.version-bump.outputs.newTag }} From 80357f134703bad34a89912c7c9212c67bd43ead Mon Sep 17 00:00:00 2001 From: Lorenzo Mangani Date: Tue, 24 Oct 2023 22:48:45 +0200 Subject: [PATCH 07/13] Update README.md Signed-off-by: Lorenzo Mangani --- README.md | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/README.md b/README.md index 16884cc7..68a8ffe3 100644 --- a/README.md +++ b/README.md @@ -20,12 +20,12 @@ :rocket: **qryn** is a _lighweight, multi-standard drop-in compatible_ **polyglot observability** framework for _**Logs, Metrics and Traces**_.
-- **Unified Query Language**: Use native **LogQL, PromQL**, and **TempoQL** languages to query, process and alert _with any data_. -- **Versatile Ingestion**: Ingest any vendor format compatible with **Opentelemetry, Loki, Prometheus, Influx, Datadog, Elastic** _and more_. -- **Built-in Explorer**: Explore data with qryn's built-in **Explore UI** and **CLI**, or use **Grafana** with _100% native_ compatibility. -- **Total Data Control**: Take full control of your data, using **ClickHouse** or **InfluxDB IOx** on top of disposable **S3** object storage. -- **Freedom of Choice**: Unlimited FOSS deployments or **qryn.cloud** service with advanced features and additional performance. -- **Cost Effective**: Do more with less, achieving the same results as the competition for a fractions of the cost and complexity. +- **Polyglot**: Use **LogQL, PromQL**, and **TempoQL** languages to query, process and alert _any data_. +- **Voracious**: Ingest anything compatible with **Opentelemetry, Loki, Prometheus, Influx, Datadog, Elastic** _& more_. +- **Versatile**: Explore data with qryn's built-in **Explore UI** and **CLI** or _native_ **Grafana** compatibility. +- **Secure**: Keep control of your data, using **ClickHouse** or **InfluxDB IOx** on top of disposable **S3** storage. +- **Unmetered**: Unlimited FOSS deployments or **qryn.cloud** service with advanced features and pro performance. +- **Effective**: Do more with less, replace lock-in competitors for a fractions of the cost and complexity.
From d7b32da587b1574d026337148df75cf649f7bae2 Mon Sep 17 00:00:00 2001 From: Lorenzo Mangani Date: Tue, 24 Oct 2023 22:49:27 +0200 Subject: [PATCH 08/13] Update README.md Signed-off-by: Lorenzo Mangani --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 68a8ffe3..6f27d06c 100644 --- a/README.md +++ b/README.md @@ -18,7 +18,7 @@ ![image](https://user-images.githubusercontent.com/1423657/232089970-c4536f16-5967-4051-85a5-8ad94fcde67c.png) -:rocket: **qryn** is a _lighweight, multi-standard drop-in compatible_ **polyglot observability** framework for _**Logs, Metrics and Traces**_.
+:rocket: _lighweight, multi-standard drop-in compatible_ **polyglot observability** framework for _**Logs, Metrics and Traces**_.
- **Polyglot**: Use **LogQL, PromQL**, and **TempoQL** languages to query, process and alert _any data_. - **Voracious**: Ingest anything compatible with **Opentelemetry, Loki, Prometheus, Influx, Datadog, Elastic** _& more_. From a073f192aa4e31c93c0188f6d71bc9bb205f10e5 Mon Sep 17 00:00:00 2001 From: Lorenzo Mangani Date: Tue, 24 Oct 2023 22:55:21 +0200 Subject: [PATCH 09/13] Update README.md Signed-off-by: Lorenzo Mangani --- README.md | 13 +++++++++---- 1 file changed, 9 insertions(+), 4 deletions(-) diff --git a/README.md b/README.md index 6f27d06c..d9db2483 100644 --- a/README.md +++ b/README.md @@ -45,13 +45,17 @@ ## Features ### 📚 OpenTelemetry -qryn is officially integrated with [opentelemetry](https://github.com/metrico/otel-collector) supports _any log, trace or metric format_ + +⚡ **qryn** is officially integrated with [opentelemetry](https://github.com/metrico/otel-collector) supports _any log, trace or metric format_ + +
### 📚 LogQL > Any Loki compatible client or application can be used with qryn out of the box -qryn implements a full [LogQL API](https://github.com/lmangani/qryn/wiki/LogQL-Supported-Queries) to provide transparent compatibility with Loki
+⚡ **qryn** implements the [LogQL API](https://github.com/lmangani/qryn/wiki/LogQL-Supported-Queries) for transparent compatibility with **Loki** clients
+ The Grafana Loki datasource can be used to natively browse and query _logs_ and display extracted _timeseries_
@@ -67,7 +71,8 @@ The Grafana Loki datasource can be used to natively browse and query _logs_ and > Any Prometheus compatible client or application can be used with qryn out of the box -qryn is the first platform to deliver full [Prometheus API](https://prometheus.io/docs/prometheus/latest/querying/api/) compatibility using WASM 🏆
+⚡ **qryn** implements the [Prometheus API](https://prometheus.io/docs/prometheus/latest/querying/api/) for transparent **PromQL** compatibility using WASM 🏆
+ The Grafana Prometheus datasource can be used to natively to query _metrics_ and display _timeseries_
@@ -81,7 +86,7 @@ The Grafana Prometheus datasource can be used to natively to query _metrics_ and ### 🕛 Tempo -qryn implements the [Tempo API](https://github.com/lmangani/qryn/wiki/LogQL-Supported-Queries) to provide transparent compatibility with Tempo/OTLP clients.
+⚡ **qryn** implements the [Tempo API](https://github.com/lmangani/qryn/wiki/LogQL-Supported-Queries) for transparent compatibility with **Tempo/OTLP** clients.
> Any Tempo/Opentelemetry compatible client or application can be used with qryn out of the box From eb1c52c83c6489b2d80802878ea54694a84a6345 Mon Sep 17 00:00:00 2001 From: Lorenzo Mangani Date: Tue, 24 Oct 2023 23:01:45 +0200 Subject: [PATCH 10/13] Update README.md Signed-off-by: Lorenzo Mangani --- README.md | 17 +++++++++++------ 1 file changed, 11 insertions(+), 6 deletions(-) diff --git a/README.md b/README.md index d9db2483..cc5919c8 100644 --- a/README.md +++ b/README.md @@ -50,7 +50,7 @@
-### 📚 LogQL +### 📚 Loki + LogQL > Any Loki compatible client or application can be used with qryn out of the box @@ -67,7 +67,7 @@ The Grafana Loki datasource can be used to natively browse and query _logs_ and
-### 📈 Prometheus +### 📈 Prometheus + PromQL > Any Prometheus compatible client or application can be used with qryn out of the box @@ -84,7 +84,7 @@ The Grafana Prometheus datasource can be used to natively to query _metrics_ and
-### 🕛 Tempo +### 🕛 Tempo + TempoQL ⚡ **qryn** implements the [Tempo API](https://github.com/lmangani/qryn/wiki/LogQL-Supported-Queries) for transparent compatibility with **Tempo/OTLP** clients.
@@ -100,8 +100,11 @@ The Tempo datasource can be used to natively query _traces_ including _**TraceQL
-### ↔️ Correlation -Data correlation is simple using qryn's drop-in compatibility with **Grafana** native datasources. +With **qryn** and **grafana** everything _just works_ right out of the box: + +- Native datasource support without any plugin or extension +- Advanced Correlation between Logs, Metrics and Traces +- Service Graphs and Service Status Panels, and all the cool features
@@ -109,7 +112,9 @@ Data correlation is simple using qryn's drop-in compatibility with **Grafana** n
-### :eye: View +
+ +### :eye: Explore View No Grafana? No Problem. **qryn** ships with **view** - it's own lightweight data exploration tool From 3ce6360b884572c9f8a00374d26caad355ea6754 Mon Sep 17 00:00:00 2001 From: Lorenzo Mangani Date: Thu, 26 Oct 2023 21:36:11 +0200 Subject: [PATCH 11/13] Update README.md Signed-off-by: Lorenzo Mangani --- README.md | 24 +++++++++++++++++++----- 1 file changed, 19 insertions(+), 5 deletions(-) diff --git a/README.md b/README.md index cc5919c8..b7b7a5b1 100644 --- a/README.md +++ b/README.md @@ -12,7 +12,7 @@
-# [qryn](https://qryn.dev) :cloud: [qryn.cloud](https://qryn.cloud) +# [qryn 3.x](https://qryn.dev) :cloud: [qryn.cloud](https://qryn.cloud) > ... it's pronounced /ˈkwɪr..ɪŋ/ or just _querying_ ![image](https://user-images.githubusercontent.com/1423657/232089970-c4536f16-5967-4051-85a5-8ad94fcde67c.png) @@ -29,6 +29,7 @@
+ ## 🚀 [Get Started](https://qryn.metrico.in/#/installation) * Deploy qryn OSS using the [documentation](https://qryn.metrico.in/#/installation) or get help in our [Matrix room](https://matrix.to/#/#qryn:matrix.org) :octocat: @@ -44,17 +45,23 @@ ## Features +💡 _**qryn** independently implements popular observability standards, protocols and query languages:_ + +
+ ### 📚 OpenTelemetry ⚡ **qryn** is officially integrated with [opentelemetry](https://github.com/metrico/otel-collector) supports _any log, trace or metric format_ +Ingested data can be queried using any of the avialable qryn APIs _(LogQL, PromQL, TraceQL)_ +
### 📚 Loki + LogQL > Any Loki compatible client or application can be used with qryn out of the box -⚡ **qryn** implements the [LogQL API](https://github.com/lmangani/qryn/wiki/LogQL-Supported-Queries) for transparent compatibility with **Loki** clients
+⚡ **qryn** implements the [Loki API](https://github.com/lmangani/qryn/wiki/LogQL-Supported-Queries) for transparent compatibility with **[LogQL](https://grafana.com/docs/loki/latest/query/)** clients
The Grafana Loki datasource can be used to natively browse and query _logs_ and display extracted _timeseries_
@@ -71,7 +78,7 @@ The Grafana Loki datasource can be used to natively browse and query _logs_ and > Any Prometheus compatible client or application can be used with qryn out of the box -⚡ **qryn** implements the [Prometheus API](https://prometheus.io/docs/prometheus/latest/querying/api/) for transparent **PromQL** compatibility using WASM 🏆
+⚡ **qryn** implements the [Prometheus API](https://prometheus.io/docs/prometheus/latest/querying/api/) for transparent **[PromQL](https://prometheus.io/docs/prometheus/latest/querying/basics/)** compatibility using WASM 🏆
The Grafana Prometheus datasource can be used to natively to query _metrics_ and display _timeseries_
@@ -84,9 +91,9 @@ The Grafana Prometheus datasource can be used to natively to query _metrics_ and
-### 🕛 Tempo + TempoQL +### 🕛 Tempo + TraceQL -⚡ **qryn** implements the [Tempo API](https://github.com/lmangani/qryn/wiki/LogQL-Supported-Queries) for transparent compatibility with **Tempo/OTLP** clients.
+⚡ **qryn** implements the [Tempo API](https://github.com/lmangani/qryn/wiki/LogQL-Supported-Queries) for transparent compatibility with **[TraceQL](https://grafana.com/docs/tempo/latest/traceql/)** clients.
> Any Tempo/Opentelemetry compatible client or application can be used with qryn out of the box @@ -98,6 +105,13 @@ The Tempo datasource can be used to natively query _traces_ including _**TraceQL :tada: _No plugins needed_ +
+ +### 📚 Other Vendors + +**qryn** can ingest data using the [InfluxDB, DataDog, Elastic](https://qryn.metrico.in/#/support) and other vendors. + +
With **qryn** and **grafana** everything _just works_ right out of the box: From abedcbe3d386ff74f78b1f2cfd5d9e432edecfec Mon Sep 17 00:00:00 2001 From: Lorenzo Mangani Date: Fri, 27 Oct 2023 09:52:41 +0200 Subject: [PATCH 12/13] Update README.md Signed-off-by: Lorenzo Mangani --- README.md | 10 ++++------ 1 file changed, 4 insertions(+), 6 deletions(-) diff --git a/README.md b/README.md index b7b7a5b1..e8adc74c 100644 --- a/README.md +++ b/README.md @@ -4,12 +4,10 @@ [![Build Status](https://github.com/metrico/qryn/actions/workflows/bump_version.yml/badge.svg)](https://github.com/metrico/qryn/actions/workflows/bump_version.yml) ![CodeQL](https://github.com/lmangani/cLoki/workflows/CodeQL/badge.svg) - - Matrix - - cloud + cloud +[![Stand With Ukraine](https://raw.githubusercontent.com/vshymanskyy/StandWithUkraine/main/badges/StandWithUkraine.svg)](https://stand-with-ukraine.pp.ua) # [qryn 3.x](https://qryn.dev) :cloud: [qryn.cloud](https://qryn.cloud) @@ -155,9 +153,9 @@ Whether it's code, documentation or grammar, we ❤️ all contributions. Not su     [![Contributors for @metrico/qryn](https://contributors-img.web.app/image?repo=lmangani/cloki)](https://github.com/metrico/qryn/graphs/contributors) -[![Stargazers repo roster for @metrico/qryn](https://reporoster.com/stars/metrico/qryn)](https://github.com/metrico/qryn/stargazers) +[![Stargazers repo roster for @metrico/qryn](https://bytecrank.com/nastyox/reporoster/php/stargazersSVG.php?user=metrico&repo=qryn)](https://github.com/metrico/qryn/stargazers) -[![Forkers repo roster for @metrico/qryn](https://reporoster.com/forks/metrico/qryn)](https://github.com/metrico/qryn/network/members) +[![Forkers repo roster for @metrico/qryn](https://bytecrank.com/nastyox/reporoster/php/forkersSVG.php?user=metrico&repo=qryn)](https://github.com/metrico/qryn/network/members) #### License From addc20d42da41b1c8513534864cbb5c15184bb71 Mon Sep 17 00:00:00 2001 From: Lorenzo Mangani Date: Fri, 27 Oct 2023 11:02:00 +0200 Subject: [PATCH 13/13] Update README.md Signed-off-by: Lorenzo Mangani --- README.md | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/README.md b/README.md index e8adc74c..1e62aeee 100644 --- a/README.md +++ b/README.md @@ -4,9 +4,6 @@ [![Build Status](https://github.com/metrico/qryn/actions/workflows/bump_version.yml/badge.svg)](https://github.com/metrico/qryn/actions/workflows/bump_version.yml) ![CodeQL](https://github.com/lmangani/cLoki/workflows/CodeQL/badge.svg) - - cloud - [![Stand With Ukraine](https://raw.githubusercontent.com/vshymanskyy/StandWithUkraine/main/badges/StandWithUkraine.svg)](https://stand-with-ukraine.pp.ua) @@ -22,7 +19,7 @@ - **Voracious**: Ingest anything compatible with **Opentelemetry, Loki, Prometheus, Influx, Datadog, Elastic** _& more_. - **Versatile**: Explore data with qryn's built-in **Explore UI** and **CLI** or _native_ **Grafana** compatibility. - **Secure**: Keep control of your data, using **ClickHouse** or **InfluxDB IOx** on top of disposable **S3** storage. -- **Unmetered**: Unlimited FOSS deployments or **qryn.cloud** service with advanced features and pro performance. +- **Unmetered**: Unlimited FOSS deployments or **qryn.cloud** option with advanced features and high performance. - **Effective**: Do more with less, replace lock-in competitors for a fractions of the cost and complexity.
@@ -118,6 +115,8 @@ With **qryn** and **grafana** everything _just works_ right out of the box: - Advanced Correlation between Logs, Metrics and Traces - Service Graphs and Service Status Panels, and all the cool features +
+