The experimental open-source Elixir agent allows you to monitor your Elixir
applications with New Relic. It helps you track transactions, distributed traces, other parts of your application's behavior, and provides an overview of underlying BEAM activity.
New Relic hosts and moderates an online forum where customers can interact with New Relic employees as well as other customers to get help and share best practices. Like all official New Relic open source projects, there's a related topic in the community forum. You can find this project's topic/threads in the forum.
We encourage your contributions to improve [project name]! Keep in mind when you submit your pull request, you'll need to sign the CLA via the click-through using CLA-Assistant. You only have to sign the CLA one time per project. If you have any questions, or to execute our corporate CLA, required if your contribution is on behalf of a company, please drop us an email at [email protected].
A note about vulnerabilities: As noted in our security policy, New Relic is committed to the privacy and security of our customers and their data. We believe that providing coordinated disclosure by security researchers and engaging with the security community are important means to achieve our security goals.
If you believe you have found a security vulnerability in this project or any of New Relic's products or websites, we welcome and greatly appreciate you reporting it to New Relic through HackerOne.
The open-source Elixir agent is licensed under the Apache 2.0 License.
Install the Hex package
Requirements:
- Erlang/OTP 22
- Elixir 1.9
defp deps do
[
{:new_relic_agent, "~> 1.0"}
]
end
You need to set a few required configuration keys so we can authenticate properly.
config :new_relic_agent,
app_name: "My App",
license_key: "license_key"
You can also configure these attributes via ENV
vars, which helps keep secrets out of source code.
NEW_RELIC_APP_NAME
NEW_RELIC_LICENSE_KEY
httpc
client settings can be overridden if needed. For example, the HTTP connect timeout can be increased which can help alleviate errors related to timeouts connecting to New Relic:
config :new_relic_agent,
app_name: "My App",
license_key: "license_key",
httpc_request_options: [connect_timeout: 5000]
Some common Elixir packages are auto-instrumented via telemetry
Plug
: See NewRelic.Telemetry.Plug for details.Phoenix
: See NewRelic.Telemetry.Phoenix for details.Ecto
: See NewRelic.Telemetry.Ecto for details.Redix
: See NewRelic.Telemetry.Redix for details.Finch
: See NewRelic.Telemetry.Finch for details.Oban
: See NewRelic.Telemetry.Oban for details.Absinthe
: See NewRelic.Telemetry.Absinthe for details.
There are a few agent features that can be enabled via configuration. Please see the documentation for more information.
The Plug
and Phoenix
instrumentation automatically report a Transaction for each request.
These Transactions will follow across any process spawned and linked (ex: Task.async
), but will not follow a process that isn't linked (ex: Task.Supervisor.async_nolink
).
To manually connect a Transaction to an unlinked process, you can use NewRelic.get_transaction
and NewRelic.connect_to_transaction
. See the docs for those functions for further details.
tx = NewRelic.get_transaction()
spawn(fn ->
NewRelic.connect_to_transaction(tx)
# ...
end)
To exclude a process from the Transaction:
Task.async(fn ->
NewRelic.exclude_from_transaction()
Work.wont_be_tracked()
end)
To prevent reporting an individual transaction:
NewRelic.ignore_transaction()
You can configure some paths to be automatically ignored:
config :new_relic_agent,
ignore_paths: [
"/health",
~r/longpoll/
]
If you are using a Task
to spawn work, you can use the pre-instrumented NewRelic.Instrumented.Task
convenience module to make this easier. Just alias
it in your module and all your Tasks will be instrumented. You may also use the functions directly.
alias NewRelic.Instrumented.Task
Task.Supervisor.async_nolink(MyTaskSupervisor, fn ->
# This process will be automatically connected to the current Transaction...
end)
NewRelic.Tracer
enables detailed Function tracing. Annotate a function and it'll show up as a span in Transaction Traces / Distributed Traces, and we'll collect aggregate stats about it. Install it by adding use NewRelic.Tracer
to any module, and annotating any function with an @trace
module attribute
defmodule MyModule do
use NewRelic.Tracer
@trace :work
def work do
# Will report as `MyModule.work/0`
end
end
If you want to trace a sub-set of a function, you can use the NewRelic.span
macro.
defmodule MyModule do
use NewRelic.Tracer
def work do
# Do some stuff..
NewRelic.span "do.some_work", user_id: "abc123" do
# Will report as `do.some_work`
# Will return the result of the block
end
end
end
Requests to other services can be connected with an additional outgoing header.
defmodule MyExternalService do
def request(method, url, headers) do
headers = headers ++ NewRelic.distributed_trace_headers(:http)
HttpClient.request(method, url, headers)
end
end
NewRelic.Instrumented.Mix.Task
To enable the agent and record an Other Transaction during a Mix.Task
, simply use NewRelic.Instrumented.Mix.Task
. This will ensure the agent is properly started, records a Transaction, and is shut down.
defmodule Mix.Tasks.Example do
use Mix.Task
use NewRelic.Instrumented.Mix.Task
def run(args) do
# ...
end
end
You may start an "Other" Transaction for non-HTTP related work. This could used be while consuming from a message queue, for example.
defmodule Worker do
use NewRelic.Tracer
def process_messages do
NewRelic.other_transaction("Worker", "ProcessMessages") do
# ...
end
end
end
There are a few adapters which leverage this agent to provide library / framework specific instrumentation. Note that these will eventually be replaced with telemetry
based instrumentation.
If you want to disable the agent, you can do it in two different ways:
- Application config:
config :new_relic_agent, license_key: nil
- Environment variables:
NEW_RELIC_HARVEST_ENABLED=false