module RedisClient::ConnectionMixin
def call(command, timeout)
def call(command, timeout) @pending_reads += 1 write(command) result = read(connection_timeout(timeout)) @pending_reads -= 1 if result.is_a?(Error) result._set_command(command) result._set_config(config) raise result else result end end
def call_pipelined(commands, timeouts, exception: true)
def call_pipelined(commands, timeouts, exception: true) first_exception = nil size = commands.size results = Array.new(commands.size) @pending_reads += size write_multi(commands) size.times do |index| timeout = timeouts && timeouts[index] result = read(connection_timeout(timeout)) @pending_reads -= 1 # A multi/exec command can return an array of results. # An error from a multi/exec command is handled in Multi#_coerce!. if result.is_a?(Array) result.each do |res| res._set_config(config) if res.is_a?(Error) end elsif result.is_a?(Error) result._set_command(commands[index]) result._set_config(config) first_exception ||= result end results[index] = result end if first_exception && exception raise first_exception else results end end
def close
def close @pending_reads = 0 nil end
def connection_timeout(timeout)
def connection_timeout(timeout) return timeout unless timeout && timeout > 0 # Can't use the command timeout argument as the connection timeout # otherwise it would be very racy. So we add the regular read_timeout on top # to account for the network delay. timeout + config.read_timeout end
def initialize
def initialize @pending_reads = 0 end
def reconnect
def reconnect close connect end
def revalidate
def revalidate if @pending_reads > 0 close false else connected? end end