From 8ab5e4497eeec37d6b03ea25b7080cdbbe03a09c Mon Sep 17 00:00:00 2001 From: Matthew Wild Date: Mon, 26 Feb 2018 15:21:27 +0000 Subject: net.connect: Handle case when resolver runs out of targets --- net/connect.lua | 8 ++++++++ 1 file changed, 8 insertions(+) (limited to 'net') diff --git a/net/connect.lua b/net/connect.lua index aa6e622b..2aa6c16c 100644 --- a/net/connect.lua +++ b/net/connect.lua @@ -27,6 +27,14 @@ local function attempt_connection(p) p.conn = nil; end p.target_resolver:next(function (conn_type, ip, port, extra) + if not conn_type then + -- No more targets to try + p:log("debug", "No more connection targets to try"); + if p.listeners.onfail then + p.listeners.onfail(p.data, p.last_error or "unable to connect to service"); + end + return; + end p:log("debug", "Next target to try is %s:%d", ip, port); local conn = assert(server.addclient(ip, port, pending_connection_listeners, p.options.pattern or "*a", p.options.sslctx, conn_type, extra)); p.conn = conn; -- cgit v1.2.3