github.com/zuoyebang/bitalosdb@v1.1.1-0.20240516111551-79a8c4d8ce20/internal/vfs/disk_usage_linux.go (about)

     1  // Copyright 2021 The Bitalosdb author(hustxrb@163.com) and other contributors.
     2  //
     3  // Licensed under the Apache License, Version 2.0 (the "License");
     4  // you may not use this file except in compliance with the License.
     5  // You may obtain a copy of the License at
     6  //
     7  //     http://www.apache.org/licenses/LICENSE-2.0
     8  //
     9  // Unless required by applicable law or agreed to in writing, software
    10  // distributed under the License is distributed on an "AS IS" BASIS,
    11  // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    12  // See the License for the specific language governing permissions and
    13  // limitations under the License.
    14  
    15  //go:build linux
    16  
    17  package vfs
    18  
    19  import "golang.org/x/sys/unix"
    20  
    21  func (defaultFS) GetDiskUsage(path string) (DiskUsage, error) {
    22  	stat := unix.Statfs_t{}
    23  	if err := unix.Statfs(path, &stat); err != nil {
    24  		return DiskUsage{}, err
    25  	}
    26  
    27  	// We use stat.Frsize here rather than stat.Bsize because on
    28  	// Linux Bavail and Bfree are in Frsize units.
    29  	//
    30  	// On most filesystems Frsize and Bsize will be set to the
    31  	// same value, but on some filesystems bsize returns the
    32  	// "optimal transfer block size"[1] which may be different
    33  	// (typically larger) than the actual block size.
    34  	//
    35  	// This confusion is cleared up in the statvfs[2] libc function,
    36  	// but the statfs system call used above varies across
    37  	// platforms.
    38  	//
    39  	// Frsize is used by GNU coreutils and other libraries, so
    40  	// this also helps ensure that we get the same results as one
    41  	// would get if they ran `df` on the given path.
    42  	//
    43  	// [1] https://man7.org/linux/man-pages/man2/statfs.2.html
    44  	// [2] https://man7.org/linux/man-pages/man3/statvfs.3.html
    45  	freeBytes := uint64(stat.Frsize) * uint64(stat.Bfree)
    46  	availBytes := uint64(stat.Frsize) * uint64(stat.Bavail)
    47  	totalBytes := uint64(stat.Bsize) * uint64(stat.Blocks)
    48  	return DiskUsage{
    49  		AvailBytes: availBytes,
    50  		TotalBytes: totalBytes,
    51  		UsedBytes:  totalBytes - freeBytes,
    52  	}, nil
    53  }