Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/spandex-project/spandex_phoenix
Phoenix Instrumentation tracer
https://github.com/spandex-project/spandex_phoenix
hacktoberfest
Last synced: 3 months ago
JSON representation
Phoenix Instrumentation tracer
- Host: GitHub
- URL: https://github.com/spandex-project/spandex_phoenix
- Owner: spandex-project
- License: mit
- Created: 2018-09-14T15:20:01.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2023-02-10T18:51:10.000Z (almost 2 years ago)
- Last Synced: 2024-10-03T12:48:28.861Z (4 months ago)
- Topics: hacktoberfest
- Language: Elixir
- Homepage:
- Size: 98.6 KB
- Stars: 82
- Watchers: 5
- Forks: 29
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Funding: .github/FUNDING.yml
- License: LICENSE.md
Awesome Lists containing this project
- awesome-beam-monitoring - Phoenix
README
# SpandexPhoenix
[![Hex Version](https://img.shields.io/hexpm/v/spandex_phoenix.svg)](https://hex.pm/packages/spandex_phoenix)
[![Hex Docs](https://img.shields.io/badge/hex-docs-lightgreen.svg)](https://hexdocs.pm/spandex_phoenix/)
[![Total Downloads](https://img.shields.io/hexpm/dt/spandex_phoenix.svg)](https://hex.pm/packages/spandex_phoenix)
[![License](https://img.shields.io/hexpm/l/spandex_phoenix.svg)](https://github.com/spandex-project/spandex_phoenix/blob/master/LICENSE)Phoenix and Plug integrations for the [Spandex] tracing library.
[Spandex]: https://github.com/spandex-project/spandex
## Usage
Add `:spandex_phoenix` to your dependencies in `mix.exs`:
```elixir
def deps do
[
{:spandex_phoenix, "~> 1.1"}
]
end
```Configure it to use your desired `Spandex.Tracer` module in `config.exs`:
```elixir
config :spandex_phoenix, tracer: MyApp.Tracer
```### Usage: Phx >= 1.5 (Telemetry)
**Upgrade Note**: *If you're updating your SpandexPhoenix code from using it with previous versions of Phoenix,
you must first remove all the code detailed in `Usage: Plug & Phx < 1.5` before following
telemetry installation instructions below.*SpandexPhoenix supports using Phoenix 1.5's Telemetry events to create spans for
`Phoenix.Controller` timing, with the `resource` name set to the controller action.To attach `Spandex.Telemetry`'s event handlers, call `SpandexPhoenix.Telemetry.install/{0,1}`
during your application's startup:```elixir
defmodule MyApp.Application do
def start(_, _) do
# ...
SpandexPhoenix.Telemetry.install()
# ...
end
end
```See `Spandex.Telemetry.install/1` documentation for event handler options.
### Usage: Plug & Phx < 1.5
Add `use SpandexPhoenix` to the appropriate module. This will "wrap" the
module with tracing and error-reporting via Spandex.Phoenix integration:
```elixir
defmodule MyAppWeb.Endpoint do
use Phoenix.Endpoint, otp_app: :my_app
use SpandexPhoenix# ...
end
```If you use Phoenix, you don't need to use the following integration most likely, otherwise, you get the error messages like
```
[error] Tried to start a trace over top of another trace
```Plug integration:
```elixir
defmodule MyApp.Router do
use Plug.Router
use SpandexPhoenix# ...
end
```#### Customizing Traces
Traces can be customized and filtered by passing options to the `use SpandexPhoenix` macro.
See the [documentation for SpandexPhoenix] for more information.#### Integrating with Phoenix Instrumentation
If you are using Phoenix and you configure `SpandexPhoenix.Instrumenter` in
your Phoenix `instrumenters` list, you will automatically get spans created for
`Phoenix.Controller` and `Phoenix.View` timing, with the `resource` set to the
name of the controller action or view name.Note that this should be used in addition to the `use SpandexPhoenix`
macro to start the trace and top-level span, as the instrumenter only creates
child spans, assuming that the trace will already have been created.Configure your Phoenix `Endpoint` to use this library as one of its
`instrumenters`:```elixir
config :my_app, MyAppWeb.Endpoint,
# ... existing config ...
instrumenters: [SpandexPhoenix.Instrumenter]
```More details can also be found in the docs on [Hexdocs].
## Copyright and License
Copyright (c) 2021 Zachary Daniel & Greg Mefford
Released under the MIT License, which can be found in [LICENSE.md](./LICENSE.md).
[Hexdocs]: https://hexdocs.pm/spandex_phoenix
[documentation for SpandexPhoenix]: https://hexdocs.pm/spandex_phoenix/SpandexPhoenix.html