Я написал небольшой сценарий оболочки (на CentOS) для загрузки статистики с нашего устройства APC UPS. Он отлично работает, но каждый день cron отправляет электронное письмо с таким сообщением:
WARNING! 1 bare linefeeds received in ASCII mode File may not have transferred correctly.
Я также получаю это сообщение, когда получаю файл вручную в оболочке. FTP-часть моего скрипта выглядит так:
ftp -in $ftpip <<END_FTP_DOWNLOAD
user $ftpuser $ftppassword
get data.txt
bye
END_FTP_DOWNLOAD
Как мне избавиться от этого предупреждающего сообщения, которое может беспокоить моих коллег?
Ручное FTP-соединение выглядит так. На этот раз я попытался ввести "ascii":
220 AP9617 Network Management Card AOS v2.6.4 FTP server ready.
Name (192.168.0.50:myusername): username
331 User name okay, need password.
Password:
230 User logged in, proceed.
ftp> ascii
200 TYPE Command okay.
ftp> get data.txt
local: data.txt remote: data.txt
227 Entering Passive Mode (192,168,0,50,161,31).
125 Data connection already open; transfer starting.
WARNING! 1 bare linefeeds received in ASCII mode
File may not have transferred correctly.
226 Closing data connection.
131468 bytes received in 19,3 secs (6,6 Kbytes/sec)
ftp> bye
221 Thank you for using APC products!
Файл data.txt содержит от 500 до 800 строк, а последняя строка всегда пуста.
Попробуйте использовать двоичный режим вместо режима ASCII. Это должно быть примерно так:
ftp -in $ftpip << END_FTP_DOWNLOAD
user $ftpuser $ftppassword
bin
get $filename
bye
END_FTP_DOWNLOAD
Теперь я нашел (грязное) решение:
Я загружаю текстовый файл в ДВОИЧНОМ режиме, а затем заменяю символ ^ M, который вставляется в файл, так как похоже, что APC UPS основан на DOS ...
tr -d '\015' < data.txt > data-$today.txt
Если кто-то предложит лучшее решение, это будет здорово, но это тоже работает.