Rya*_*yan 4 unix linux bash shell linux-disk-free
df做一个很好的概述.但是如果我想在shell脚本中将变量设置为磁盘上可用的字节数呢?
例:
$ df
Filesystem 1K-blocks Used Available Use% Mounted on
/dev/sda 1111111111 2222222 33333333 10% /
tmpfs 44444444 555 66666666 1% /dev/shm
Run Code Online (Sandbox Code Playgroud)
但我只想返回33333333(可用的字节数/),而不是整个df输出.
小智 14
您可以使用 df 获得确切的字节数:
df -B1 /
Filesystem 1B-blocks Used Available Use% Mounted on
/dev/mapper/cl-root 32893632512 13080072192 18119061504 42% /
便携:
df -P /dev/sda1 | awk 'NR==2 {print $4}'
Run Code Online (Sandbox Code Playgroud)
该-P选项可确保df以预期格式打印输出,并且特别是即使设备名称很长也不会断开设备名称后面的行。将设备名称作为参数传递以df消除解析过程中的任何危险,例如获取/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}'
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
5039 次 |
| 最近记录: |