I was trying to plot the results of various iostat results. For that I want to use https://clusterbuffer.wordpress.com/file-system-tools/iostat_plot/iostat-plotter-v3/.
Anyhow - for some inexplicable reason, that script has the time format it expects hardcoded and its expecting a 12hr AM/PM time format which I dont think is part of ANY linux locale setting. Im looking for a way to tell iostat -t to output in an AM/PM format and am failing at that. Supposedly its using the env var S_TIME_FORMAT which is unknown to me and seems to be iostat specific AND undocumented. The systems/user LC_TIME is set to 'C' as per usual. Any idea how to coax iostat into using the am/pm format? Since iostat is a binary I cannot modify the way it calls strftime/localtime. Thanks in advance!
# locale
LANG=en_US.UTF-8
LC_CTYPE="C"
LC_NUMERIC="C"
LC_TIME="C"
LC_COLLATE="C"
LC_MONETARY="C"
LC_MESSAGES="C"
LC_PAPER="C"
LC_NAME="C"
LC_ADDRESS="C"
LC_TELEPHONE="C"
LC_MEASUREMENT="C"
LC_IDENTIFICATION="C"
LC_ALL=C
Требуемый языковой стандарт - en_US:
[xxx]# export LANG=C
[xxx]# iostat -t
Linux 4.14.8-300.fc27.x86_64 (osvetlik.unicorn) 01/10/18 _x86_64_ (4 CPU)
01/10/18 18:36:47
avg-cpu: %user %nice %system %iowait %steal %idle
26.26 0.09 5.56 0.09 0.00 68.00
[xxx]# export LANG="en_US.UTF-8"
[xxx]# locale
LANG=en_US.UTF-8
LC_CTYPE="en_US.UTF-8"
LC_NUMERIC="en_US.UTF-8"
LC_TIME="en_US.UTF-8"
LC_COLLATE="en_US.UTF-8"
LC_MONETARY="en_US.UTF-8"
LC_MESSAGES="en_US.UTF-8"
LC_PAPER="en_US.UTF-8"
LC_NAME="en_US.UTF-8"
LC_ADDRESS="en_US.UTF-8"
LC_TELEPHONE="en_US.UTF-8"
LC_MEASUREMENT="en_US.UTF-8"
LC_IDENTIFICATION="en_US.UTF-8"
LC_ALL=
[xxx]# iostat -t
Linux 4.14.8-300.fc27.x86_64 (osvetlik.unicorn) 01/10/2018 _x86_64_ (4 CPU)
01/10/2018 06:37:41 PM
avg-cpu: %user %nice %system %iowait %steal %idle
26.25 0.09 5.56 0.09 0.00 68.01
Важная переменная локали здесь - LC_TIME
(но вы должны изменить LC_ALL
в случае у вас он установлен, так как он предотвращает различные установки других LC_
переменных). Вы должны установить для этой переменной значение en_US
, чтобы время было в правильном формате. Установка только LANG
на en_US
не помогает. Просто используйте команду locale
, чтобы убедиться, что LC_TIME
установлено правильно.
Вывод без набора LC_ALL
:
[xxx]# export LC_ALL=
[xxx]# export LC_TIME="en_US.UTF-8"
[xxx]# locale
LANG=C
LC_CTYPE="C"
LC_NUMERIC="C"
LC_TIME=en_US.UTF-8
LC_COLLATE="C"
LC_MONETARY="C"
LC_MESSAGES="C"
LC_PAPER="C"
LC_NAME="C"
LC_ADDRESS="C"
LC_TELEPHONE="C"
LC_MEASUREMENT="C"
LC_IDENTIFICATION="C"
LC_ALL=
[xxx]# iostat -t
Linux 4.14.8-300.fc27.x86_64 (osvetlik.unicorn) 01/12/2018 _x86_64_ (4 CPU)
01/12/2018 09:48:05 AM
И с LC_ALL
:
[xxx]# export LC_ALL="en_US.UTF-8"
[xxx]# locale
LANG=C
LC_CTYPE="en_US.UTF-8"
LC_NUMERIC="en_US.UTF-8"
LC_TIME="en_US.UTF-8"
LC_COLLATE="en_US.UTF-8"
LC_MONETARY="en_US.UTF-8"
LC_MESSAGES="en_US.UTF-8"
LC_PAPER="en_US.UTF-8"
LC_NAME="en_US.UTF-8"
LC_ADDRESS="en_US.UTF-8"
LC_TELEPHONE="en_US.UTF-8"
LC_MEASUREMENT="en_US.UTF-8"
LC_IDENTIFICATION="en_US.UTF-8"
LC_ALL=en_US.UTF-8
[xxx]# iostat -t
Linux 4.14.8-300.fc27.x86_64 (osvetlik.unicorn) 01/12/2018 _x86_64_ (4 CPU)
01/12/2018 09:49:38 AM
Краткое решение:
LC_ALL="en_US.UTF-8" iostat -t
не может использовать форматирование в комментариях, поэтому вставьте блок кода сюда:
система уже имеет этот языковой стандарт, даже определенный в /etc/locale.conf. К сожалению, это не так:
[root@xxx]# echo $LANG
en_US.UTF-8
[root@xxx]# iostat -t
Linux 3.10.0-514.6.1.el7.x86_64 (xxx) 01/11/18 _x86_64_ (48 CPU)
01/11/18 08:43:46
avg-cpu: %user %nice %system %iowait %steal %idle
[...]