AppSignal uses Ecto’s Telemetry instrumentation to gain information about queries ran in your app by attaching a handler that gets called whenever a query is executed.
To get this to work, you attach the handler manually when starting your app’s supervisor. In most applications, this is done in your application’s
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 def start(_type, _args) do children = [ AppsignalPhoenixExample.Repo, AppsignalPhoenixExampleWeb.Endpoint ] :telemetry.attach( "appsignal-ecto", [:appsignal_phoenix_example, :repo, :query], &Appsignal.Ecto.handle_event/4, nil ) opts = [strategy: :one_for_one, name: AppsignalPhoenixExample.Supervisor] Supervisor.start_link(children, opts) end
In this example, we’ve attached the Telemetry handler to our Phoenix application by calling
:telemetry.attach/4 with the following arguments:
"appsignal-ecto"is the name of the handler. This should be unique. If you have multiple repos you’d like to have instrumentation for, give each a unique name (like
[:appsignal_phoenix_example, :repo, :query]is the name of the event to watch. It’s made up of the repo module’s name (
AppsignalPhoenixExample.Repo), and the event name (
&Appsignal.Ecto.handle_event/4is the function the event will be sent to in the AppSignal integration.
- We’ll omit the handler configuration by passing
nilas the fourth argument.
For versions of Telemetry < 0.3.0, you'll need to call it slightly differently:
1 2 3 4 5 6 7 Telemetry.attach( "appsignal-ecto", [:appsignal_phoenix_example, :repo, :query], Appsignal.Ecto, :handle_event, nil )
On Ecto 2, add the
Appsignal.Ecto module to your Repo's logger configuration instead. The
Ecto.LogEntry logger is the default logger for Ecto and needs to be set as well to keep the original Ecto logger behavior intact.
1 2 config :my_app, MyApp.Repo, loggers: [Appsignal.Ecto, Ecto.LogEntry]