From 1ad96ee09f7c23c2207098697a4820327b54a1f4 Mon Sep 17 00:00:00 2001 From: Krishnan Parthasarathi Date: Fri, 10 Feb 2017 10:08:14 +0530 Subject: [PATCH] Handle uptime for single-node instances differnt from distributed setup (#3726) --- cmd/admin-rpc-client.go | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/cmd/admin-rpc-client.go b/cmd/admin-rpc-client.go index 58a83cd0c..a34809560 100644 --- a/cmd/admin-rpc-client.go +++ b/cmd/admin-rpc-client.go @@ -287,6 +287,13 @@ func (ts uptimeSlice) Swap(i, j int) { // getPeerUptimes - returns the uptime since the last time read quorum // was established on success. Otherwise returns errXLReadQuorum. func getPeerUptimes(peers adminPeers) (time.Duration, error) { + // In a single node Erasure or FS backend setup the uptime of + // the setup is the uptime of the single minio server + // instance. + if !globalIsDistXL { + return time.Now().UTC().Sub(globalBootTime), nil + } + uptimes := make(uptimeSlice, len(peers)) // Get up time of all servers. @@ -320,8 +327,9 @@ func getPeerUptimes(peers adminPeers) (time.Duration, error) { } } - // This implies there weren't read quorum number of servers up. - if latestUptime == time.Duration(0) { + // Less than readQuorum "Admin.Uptime" RPC call returned + // successfully, so read-quorum unavailable. + if validCount < readQuorum { return time.Duration(0), InsufficientReadQuorum{} }