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