df在概述方面做得很好。但是,如果我想在Shell脚本中将变量设置为磁盘上可用的字节数,该怎么办?
df
例:
$ df Filesystem 1K-blocks Used Available Use% Mounted on /dev/sda 1111111111 2222222 33333333 10% / tmpfs 44444444 555 66666666 1% /dev/shm
但是我只想返回33333333(字节可用/),而不是整个df输出。
33333333
/
便携性:
df -P /dev/sda1 | awk 'NR==2 {print $4}'
该-P选项可确保df以期望的格式打印输出,并且即使设备名称很长,也不会特别打断行名。将设备名称作为参数传递给df可以消除解析过程中的任何危险,例如获取有关/dev/sda10查询时的信息/dev/sda1。df -P只打印两行,标题行(您忽略)和一条数据行,在其中打印所需的列。
-P
/dev/sda10
/dev/sda1
df -P
可能df会显示包含空格的设备名称,例如,如果卷是通过名称挂载的,并且名称包含空格,或者是其远程挂载点包含空格的NFS卷,则存在风险。在这种情况下,没有完全可移植的方法来解析输出df。如果您确定df会显示传递给它的确切设备名称(并非总是如此),则可以删除它:
df -P -- "$device" | awk -vn=${#device} 'NR==2 {$0 = substr($0, n+1); print $3}'