26
1
mirror of https://github.com/processone/ejabberd.git synced 2025-01-03 18:02:28 +01:00

Fix SQL connections leakage

This commit is contained in:
Evgeny Khramtsov 2019-07-30 14:26:11 +03:00
parent 81996b153a
commit 209f5d32e1

View File

@ -343,7 +343,8 @@ connecting(connect, #state{host = Host} = State) ->
end, end,
case ConnectRes of case ConnectRes of
{ok, Ref} -> {ok, Ref} ->
erlang:monitor(process, Ref), try link(Ref) of
_ ->
lists:foreach( lists:foreach(
fun({{?PREPARE_KEY, _} = Key, _}) -> fun({{?PREPARE_KEY, _} = Key, _}) ->
erase(Key); erase(Key);
@ -359,15 +360,12 @@ connecting(connect, #state{host = Host} = State) ->
State1 = State#state{db_ref = Ref, State1 = State#state{db_ref = Ref,
pending_requests = PendingRequests}, pending_requests = PendingRequests},
State2 = get_db_version(State1), State2 = get_db_version(State1),
{next_state, session_established, State2}; {next_state, session_established, State2}
catch _:Reason ->
handle_reconnect(Reason, State)
end;
{error, Reason} -> {error, Reason} ->
StartInterval = ejabberd_option:sql_start_interval(Host), handle_reconnect(Reason, State)
?WARNING_MSG("~p connection failed:~n** Reason: ~p~n** "
"Retry after: ~B seconds",
[State#state.db_type, Reason,
StartInterval div 1000]),
p1_fsm:send_event_after(StartInterval, connect),
{next_state, connecting, State}
end; end;
connecting(Event, State) -> connecting(Event, State) ->
?WARNING_MSG("Unexpected event in 'connecting': ~p", ?WARNING_MSG("Unexpected event in 'connecting': ~p",
@ -431,12 +429,8 @@ handle_sync_event(_Event, _From, StateName, State) ->
code_change(_OldVsn, StateName, State, _Extra) -> code_change(_OldVsn, StateName, State, _Extra) ->
{ok, StateName, State}. {ok, StateName, State}.
%% We receive the down signal when we loose the MySQL connection (we are handle_info({'EXIT', _Pid, Reason}, _StateName, State) ->
%% monitoring the connection) handle_reconnect(Reason, State);
handle_info({'DOWN', _MonitorRef, process, _Pid, _Info},
_StateName, State) ->
p1_fsm:send_event(self(), connect),
{next_state, connecting, State};
handle_info(Info, StateName, State) -> handle_info(Info, StateName, State) ->
?WARNING_MSG("Unexpected info in ~p: ~p", ?WARNING_MSG("Unexpected info in ~p: ~p",
[StateName, Info]), [StateName, Info]),
@ -460,6 +454,15 @@ print_state(State) -> State.
%%%---------------------------------------------------------------------- %%%----------------------------------------------------------------------
%%% Internal functions %%% Internal functions
%%%---------------------------------------------------------------------- %%%----------------------------------------------------------------------
handle_reconnect(Reason, #state{host = Host} = State) ->
StartInterval = ejabberd_option:sql_start_interval(Host),
?WARNING_MSG("~p connection failed:~n"
"** Reason: ~p~n"
"** Retry after: ~B seconds",
[State#state.db_type, Reason,
StartInterval div 1000]),
p1_fsm:send_event_after(StartInterval, connect),
{next_state, connecting, State}.
run_sql_cmd(Command, From, State, Timestamp) -> run_sql_cmd(Command, From, State, Timestamp) ->
QueryTimeout = query_timeout(State#state.host), QueryTimeout = query_timeout(State#state.host),