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 }