Crontab с командами ed by в потоке, приводит к "без изменений".

0

Вопрос

Я пытаюсь добавить строку в свой файл crontab. Я знаю, что есть другие способы обойти эту проблему, но все равно хочу знать, что ее вызвало. Команда выполняется на raspberry pi 3 B+, установлен raspbian lite, с GNU ed 1.15, cron 3.0pl1-134+deb10u1.

Команда, на которой я застрял, такова:

$ echo -e 'a\n#asdf\n.\nwQ' | EDITOR=ed crontab -e
902
909
No modification made

Я ожидаю, что он добавит строку #asdf в конце моего файла crontab, но это не так.

Установка EDITOR='tee -a' как и предлагалось https://stackoverflow.com/a/30123606/8842387 это не решает проблему. Так что, я думаю, это проблема с кроном.

Как ни странно, когда я даю Эду команды непосредственно с клавиатуры, а не транслирую их, это просто работает. Может быть, проблема возникла из-за создания недр?

Здесь я прикрепляю несколько последних строк из strace Результат.

$ echo -e 'a\n#asdf\n.\nwQ' | EDITOR=ed strace crontab -e
execve("/usr/bin/crontab", ["crontab", "-e"], 0x7ee54c14 /* 29 vars */) = 0
access("/etc/suid-debug", F_OK)         = -1 ENOENT (No such file or directory)
...
read(3, "TZif2\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\7\0\0\0\7\0\0\0\0"..., 4096) = 659
_llseek(3, -393, [266], SEEK_CUR)       = 0
read(3, "TZif2\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\7\0\0\0\7\0\0\0\0"..., 4096) = 393
close(3)                                = 0
getpid()                                = 18579
socket(AF_UNIX, SOCK_DGRAM|SOCK_CLOEXEC, 0) = 3
connect(3, {sa_family=AF_UNIX, sun_path="/dev/log"}, 110) = 0
send(3, "<78>Nov 20 15:31:25 crontab[1857"..., 56, MSG_NOSIGNAL) = 56
openat(AT_FDCWD, "crontabs/pi", O_RDONLY) = -1 EACCES (Permission denied)
openat(AT_FDCWD, "/usr/share/locale/locale.alias", O_RDONLY|O_CLOEXEC) = 4
fstat64(4, {st_mode=S_IFREG|0644, st_size=2995, ...}) = 0
read(4, "# Locale name alias data base.\n#"..., 4096) = 2995
read(4, "", 4096)                       = 0
close(4)                                = 0
openat(AT_FDCWD, "/usr/share/locale/en_GB.UTF-8/LC_MESSAGES/libc.mo", O_RDONLY) = -1 ENOENT (No such file or directory)
openat(AT_FDCWD, "/usr/share/locale/en_GB.utf8/LC_MESSAGES/libc.mo", O_RDONLY) = -1 ENOENT (No such file or directory)
openat(AT_FDCWD, "/usr/share/locale/en_GB/LC_MESSAGES/libc.mo", O_RDONLY) = 4
fstat64(4, {st_mode=S_IFREG|0644, st_size=1433, ...}) = 0
mmap2(NULL, 1433, PROT_READ, MAP_PRIVATE, 4, 0) = 0x76f50000
close(4)                                = 0
openat(AT_FDCWD, "/usr/share/locale/en.UTF-8/LC_MESSAGES/libc.mo", O_RDONLY) = -1 ENOENT (No such file or directory)
openat(AT_FDCWD, "/usr/share/locale/en.utf8/LC_MESSAGES/libc.mo", O_RDONLY) = -1 ENOENT (No such file or directory)
openat(AT_FDCWD, "/usr/share/locale/en/LC_MESSAGES/libc.mo", O_RDONLY) = -1 ENOENT (No such file or directory)
write(2, "crontabs/pi/: fdopen: Permission"..., 39crontabs/pi/: fdopen: Permission denied) = 39
exit_group(1)                           = ?
+++ exited with 1 +++

openat(AT_FDCWD, "crontabs/pi", O_RDONLY) = -1 EACCES (Permission denied) выглядит немного подозрительно, но не уверен, почему он открывает файл только для чтения.

Редактировать: Как и предлагал @tink, я побежал EDITOR=ed strace crontab -e чтобы увидеть, что strace проводит интерактивную сессию. Результат был почти одинаковым (только различался по числам pid и fd).

Я заметил, что бег echo "..." | EDITOR=ed crontab -e выхожу с сообщением No modification made но с strace процесс останавливается без каких-либо сообщений. (EDITOR=ed strace crontab -e 2>&1 | grep "No mod" ничего не печатает). Предположим, что расслоение вызывает различные ошибки.

bash cron ed linux
2021-11-20 06:41:51
1

Лучший ответ

0

Следуя моему ВИЗУАЛЬНОМУ комментарию, это сработало для меня:

( unset VISUAL; printf '%s\n' a '#abcd' . wq | EDITOR=ed crontab -e )
printf '%s\n' a '#abcd' . wq | VISUAL=ed crontab -e

В моей среде и ВИЗУАЛЬНЫЙ, и РЕДАКТОР настроены на "vim".

Или, более окольным путем, но не нужно обезьянничать с завистью. Это также позволяет вам делать это бесшумно:

crontab <(printf '%s\n' a '#asdf' . '%p' | ed -s <(crontab -l))

Я делал все вышесказанное на Mac. В Linux я могу воспроизвести ваши наблюдения, но не могу их объяснить.

Небольшая настройка последней команды работает:

printf '%s\n' a '#asdf' . '%p' Q | ed -s <(crontab -l) | crontab -
2021-11-21 20:34:51

Спасибо за ответ! Я боюсь сказать, что ни одна из двух вышеперечисленных строк не сработала для меня, и последняя дает /dev/fd/63: Not a regular file. Может быть, какая-то конфигурация системы будет другой?
bivoje

На других языках

Эта страница на других языках

Italiano
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................