Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/geometerio/geometrics
An opinionated library and set of guides for adding application tracing and metrics to a Phoenix application
https://github.com/geometerio/geometrics
elixir observability opentelemetry tracing-applications
Last synced: 3 months ago
JSON representation
An opinionated library and set of guides for adding application tracing and metrics to a Phoenix application
- Host: GitHub
- URL: https://github.com/geometerio/geometrics
- Owner: geometerio
- License: mit
- Created: 2021-02-24T20:04:01.000Z (almost 4 years ago)
- Default Branch: main
- Last Pushed: 2022-11-08T21:38:47.000Z (about 2 years ago)
- Last Synced: 2024-10-01T14:36:56.108Z (3 months ago)
- Topics: elixir, observability, opentelemetry, tracing-applications
- Language: Elixir
- Homepage: https://hexdocs.pm/geometrics
- Size: 1.74 MB
- Stars: 20
- Watchers: 3
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE.md
Awesome Lists containing this project
README
# Geometrics
An opinionated library for adding application tracing and metrics to a Phoenix application. Geometrics includes
dependencies which hook into Phoenix and Ecto [telemetry](https://hexdocs.pm/phoenix/telemetry.html), adding support for
LiveView as well as crash tracking.This repo also contains informative [guides](https://hexdocs.pm/geometrics) to help you wrap your head around
Application tracing concepts which can be notoriously confusing, especially in Elixir and Erlang. It is worth reading
these before diving in.## Basic Usage
Given this simple LiveView module in a Phoenix application:
```elixir
defmodule GeometerTracingDemosWeb.PageLive do
use GeometerTracingDemosWeb, :live_viewalias GeometerTracingDemos.Repo
alias GeometerTracingDemos.SomeModelrequire OpenTelemetry.Tracer
@impl true
def mount(_params, _session, socket) do
...
end@impl true
def handle_event("create", %{"some_model" => form_attrs}, socket) do
# This is an example of adding a custom span to your application. All of the other application traces in the image
# below come by default after installing Geometrics without any other changes to source code.
OpenTelemetry.Tracer.with_span "My custom span" do
%SomeModel{}
|> SomeModel.changeset(form_attrs)
|> Repo.insert()
end{:noreply, socket}
end
end
```You can see an application trace that extends throughout an entire live view session.
![Honeycomb Trace Exmample](guides/assets/honeycomb_trace_example.png)
(Note that the trace shown here is from the [Honeycomb.io](https://www.honeycomb.io/) UI, but should carry over to any
Application tracing service)## Why does this library exists?
1. To distill knowledge gleaned from dissecting the somewhat overwhelming OpenTelemetry/observability ecosystem into an
easily consumed set of [guides](https://hexdocs.pm/geometrics).
2. To provide Phoenix LiveView observability, which has not yet been included into OpenTelemetry the way
that [Phoenix](https://github.com/opentelemetry-beam/opentelemetry_phoenix)
and [Ecto](https://github.com/opentelemetry-beam/opentelemetry_ecto) have.
3. To generally make it easier to get started with observing your Phoenix application## Installation
[Installation guide](https://hexdocs.pm/geometrics/installation.html).
## References
For further reading, see [the guides](https://hexdocs.pm/geometrics).
External references:
- https://opentelemetry.io/docs/concepts/what-is-opentelemetry/
- https://opentelemetry.io/docs/erlang/getting-started/
- https://github.com/open-telemetry/opentelemetry-specification