diff options
author | Fredrik Gustafsson <[email protected]> | 2013-03-15 11:26:12 +0100 |
---|---|---|
committer | Fredrik Gustafsson <[email protected]> | 2013-03-15 11:26:12 +0100 |
commit | 1990318baa032d1e65f3b39f420d9fbddb1bf830 (patch) | |
tree | c128124b6967e71ededd3f5e5e5a063ac40d1267 /lib | |
parent | f26dab68e9b3d40e59b015bb5b0cbfaf6995a66b (diff) | |
parent | 9e6214fb792adbe566bc0155c7050a07a531a825 (diff) | |
download | otp-1990318baa032d1e65f3b39f420d9fbddb1bf830.tar.gz otp-1990318baa032d1e65f3b39f420d9fbddb1bf830.tar.bz2 otp-1990318baa032d1e65f3b39f420d9fbddb1bf830.zip |
Merge branch 'maint'
Diffstat (limited to 'lib')
-rw-r--r-- | lib/os_mon/src/disksup.erl | 24 |
1 files changed, 22 insertions, 2 deletions
diff --git a/lib/os_mon/src/disksup.erl b/lib/os_mon/src/disksup.erl index f5f76f1488..f906f33d32 100644 --- a/lib/os_mon/src/disksup.erl +++ b/lib/os_mon/src/disksup.erl @@ -275,8 +275,8 @@ check_disk_space({unix, sunos4}, Port, Threshold) -> Result = my_cmd("df", Port), check_disks_solaris(skip_to_eol(Result), Threshold); check_disk_space({unix, darwin}, Port, Threshold) -> - Result = my_cmd("/bin/df -k -t ufs,hfs", Port), - check_disks_solaris(skip_to_eol(Result), Threshold). + Result = my_cmd("/bin/df -i -k -t ufs,hfs", Port), + check_disks_susv3(skip_to_eol(Result), Threshold). % This code works for Linux and FreeBSD as well check_disks_solaris("", _Threshold) -> @@ -298,6 +298,26 @@ check_disks_solaris(Str, Threshold) -> check_disks_solaris(skip_to_eol(Str),Threshold) end. +% Parse per SUSv3 specification, notably recent OS X +check_disks_susv3("", _Threshold) -> + []; +check_disks_susv3("\n", _Threshold) -> + []; +check_disks_susv3(Str, Threshold) -> + case io_lib:fread("~s~d~d~d~d%~d~d~d%~s", Str) of + {ok, [_FS, KB, _Used, _Avail, Cap, _IUsed, _IFree, _ICap, MntOn], RestStr} -> + if + Cap >= Threshold -> + set_alarm({disk_almost_full, MntOn}, []); + true -> + clear_alarm({disk_almost_full, MntOn}) + end, + [{MntOn, KB, Cap} | + check_disks_susv3(RestStr, Threshold)]; + _Other -> + check_disks_susv3(skip_to_eol(Str),Threshold) + end. + %% Irix: like Linux with an extra FS type column and no '%'. check_disks_irix("", _Threshold) -> []; check_disks_irix("\n", _Threshold) -> []; |