mirror of
https://github.com/minio/minio.git
synced 2025-01-11 23:13:23 -05:00
listObjects optimized to handle max-keys=1 when prefix is object (#13000)
Some applications albeit poorly written rather than using headObject rely on listObjects to check for existence of object, this unusual request always has prefix=(to actual object) and max-keys=1 handle this situation specially such that we can avoid readdir() on the top level parent to avoid sorting and skipping, ensuring that such type of listObjects() always behaves similar to a headObject() call.
This commit is contained in:
parent
9c65168312
commit
ee028a4693
@ -188,7 +188,9 @@ func verifyServerSystemConfig(ctx context.Context, endpointServerPools EndpointS
|
|||||||
// after 5 retries start logging that servers are not reachable yet
|
// after 5 retries start logging that servers are not reachable yet
|
||||||
if retries >= 5 {
|
if retries >= 5 {
|
||||||
logger.Info(fmt.Sprintf("Waiting for atleast %d remote servers to be online for bootstrap check", len(clnts)/2))
|
logger.Info(fmt.Sprintf("Waiting for atleast %d remote servers to be online for bootstrap check", len(clnts)/2))
|
||||||
|
if len(offlineEndpoints) > 0 {
|
||||||
logger.Info(fmt.Sprintf("Following servers are currently offline or unreachable %s", offlineEndpoints))
|
logger.Info(fmt.Sprintf("Following servers are currently offline or unreachable %s", offlineEndpoints))
|
||||||
|
}
|
||||||
retries = 0 // reset to log again after 5 retries.
|
retries = 0 // reset to log again after 5 retries.
|
||||||
}
|
}
|
||||||
offlineEndpoints = nil
|
offlineEndpoints = nil
|
||||||
|
@ -1060,6 +1060,22 @@ func maxKeysPlusOne(maxKeys int, addOne bool) int {
|
|||||||
|
|
||||||
func (z *erasureServerPools) ListObjects(ctx context.Context, bucket, prefix, marker, delimiter string, maxKeys int) (ListObjectsInfo, error) {
|
func (z *erasureServerPools) ListObjects(ctx context.Context, bucket, prefix, marker, delimiter string, maxKeys int) (ListObjectsInfo, error) {
|
||||||
var loi ListObjectsInfo
|
var loi ListObjectsInfo
|
||||||
|
|
||||||
|
if len(prefix) > 0 && maxKeys == 1 && delimiter == "" && marker == "" {
|
||||||
|
// Optimization for certain applications like
|
||||||
|
// - Cohesity
|
||||||
|
// - Actifio, Splunk etc.
|
||||||
|
// which send ListObjects requests where the actual object
|
||||||
|
// itself is the prefix and max-keys=1 in such scenarios
|
||||||
|
// we can simply verify locally if such an object exists
|
||||||
|
// to avoid the need for ListObjects().
|
||||||
|
objInfo, err := z.GetObjectInfo(ctx, bucket, prefix, ObjectOptions{NoLock: true})
|
||||||
|
if err == nil {
|
||||||
|
loi.Objects = append(loi.Objects, objInfo)
|
||||||
|
return loi, nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
opts := listPathOptions{
|
opts := listPathOptions{
|
||||||
Bucket: bucket,
|
Bucket: bucket,
|
||||||
Prefix: prefix,
|
Prefix: prefix,
|
||||||
|
@ -331,7 +331,7 @@ func (s *storageRESTServer) WalkDirHandler(w http.ResponseWriter, r *http.Reques
|
|||||||
}
|
}
|
||||||
|
|
||||||
var reportNotFound bool
|
var reportNotFound bool
|
||||||
if v := vars[storageRESTReportNotFound]; v != "" {
|
if v := r.Form.Get(storageRESTReportNotFound); v != "" {
|
||||||
reportNotFound, err = strconv.ParseBool(v)
|
reportNotFound, err = strconv.ParseBool(v)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
s.writeErrorResponse(w, err)
|
s.writeErrorResponse(w, err)
|
||||||
|
Loading…
Reference in New Issue
Block a user