2020-10-12 17:00:50 +00:00
# Pleroma: A lightweight social networking server
2021-01-13 06:49:20 +00:00
# Copyright © 2017-2021 Pleroma Authors <https://pleroma.social/>
2020-10-12 17:00:50 +00:00
# SPDX-License-Identifier: AGPL-3.0-only
2020-07-15 12:26:25 +00:00
defmodule Pleroma.Telemetry.Logger do
@moduledoc " Transforms Pleroma telemetry events to logs "
require Logger
@events [
[ :pleroma , :connection_pool , :reclaim , :start ] ,
[ :pleroma , :connection_pool , :reclaim , :stop ] ,
2020-05-08 15:18:59 +00:00
[ :pleroma , :connection_pool , :provision_failure ] ,
2020-09-11 11:22:54 +00:00
[ :pleroma , :connection_pool , :client , :dead ] ,
2021-12-05 22:46:56 +00:00
[ :pleroma , :connection_pool , :client , :add ] ,
[ :pleroma , :repo , :query ]
2020-07-15 12:26:25 +00:00
]
def attach do
2021-12-05 22:46:56 +00:00
:telemetry . attach_many (
" pleroma-logger " ,
@events ,
& Pleroma.Telemetry.Logger . handle_event / 4 ,
[ ]
)
2020-07-15 12:26:25 +00:00
end
# Passing anonymous functions instead of strings to logger is intentional,
# that way strings won't be concatenated if the message is going to be thrown
# out anyway due to higher log level configured
def handle_event (
[ :pleroma , :connection_pool , :reclaim , :start ] ,
_ ,
%{ max_connections : max_connections , reclaim_max : reclaim_max } ,
_
) do
Logger . debug ( fn ->
" Connection pool is exhausted (reached #{ max_connections } connections). Starting idle connection cleanup to reclaim as much as #{
reclaim_max
} connections "
end )
end
def handle_event (
[ :pleroma , :connection_pool , :reclaim , :stop ] ,
%{ reclaimed_count : 0 } ,
_ ,
_
) do
Logger . error ( fn ->
" Connection pool failed to reclaim any connections due to all of them being in use. It will have to drop requests for opening connections to new hosts "
end )
end
def handle_event (
[ :pleroma , :connection_pool , :reclaim , :stop ] ,
%{ reclaimed_count : reclaimed_count } ,
_ ,
_
) do
Logger . debug ( fn -> " Connection pool cleaned up #{ reclaimed_count } idle connections " end )
end
def handle_event (
[ :pleroma , :connection_pool , :provision_failure ] ,
%{ opts : [ key | _ ] } ,
_ ,
_
) do
Logger . error ( fn ->
" Connection pool had to refuse opening a connection to #{ key } due to connection limit exhaustion "
end )
end
2020-05-08 15:18:59 +00:00
def handle_event (
2020-09-11 11:22:54 +00:00
[ :pleroma , :connection_pool , :client , :dead ] ,
2020-05-08 15:18:59 +00:00
%{ client_pid : client_pid , reason : reason } ,
%{ key : key } ,
_
) do
Logger . warn ( fn ->
" Pool worker for #{ key } : Client #{ inspect ( client_pid ) } died before releasing the connection with #{
inspect ( reason )
} "
end )
end
2020-09-11 11:22:54 +00:00
def handle_event (
[ :pleroma , :connection_pool , :client , :add ] ,
%{ clients : [ _ , _ | _ ] = clients } ,
%{ key : key , protocol : :http } ,
_
) do
Logger . info ( fn ->
" Pool worker for #{ key } : #{ length ( clients ) } clients are using an HTTP1 connection at the same time, head-of-line blocking might occur. "
end )
end
def handle_event ( [ :pleroma , :connection_pool , :client , :add ] , _ , _ , _ ) , do : :ok
2021-12-05 22:46:56 +00:00
def handle_event (
[ :pleroma , :repo , :query ] = _name ,
%{ query_time : query_time } = _measurements ,
%{ source : source , query : query } = _metadata ,
_config
)
when query_time > 500_000 and source not in [ nil , " oban_jobs " ] do
{ :current_stacktrace , stacktrace } = Process . info ( self ( ) , :current_stacktrace )
stacktrace =
Enum . filter ( stacktrace , fn
{ __MODULE__ , _ , _ , _ } ->
false
{ mod , _ , _ , _ } ->
mod
|> to_string ( )
|> String . starts_with? ( " Elixir.Pleroma. " )
end )
Logger . warn ( fn ->
"""
Query took longer than 500 ms!
Total time : #{query_time / 1_000}ms
#{inspect(query)}
#{inspect(stacktrace, pretty: true)}
"""
end )
end
def handle_event ( [ :pleroma , :repo , :query ] , _measurements , _metadata , _config ) , do : :ok
2020-07-15 12:26:25 +00:00
end