Linux у команды висит?

У меня проблема с командой Linux 'at', и Google довольно сложно работать с 'at'. Проблема в том, что, что бы я ни запускал, оно никогда не останавливалось.

например, вот простой скрипт, который я сделал (я заменил свое имя пользователя на USER):

#!/bin/bash
echo "Testing" > /local/USER/tmp.txt

Я поместил вышеупомянутые строки в файл /local/USER/tmp.sh и сделал файл исполняемым. Запуск с

/local/rarandje/tmp.sh

работает как положено и создает соответствующий файл.

Теперь, если я попробую с командой 'at':

at -f /local/USER/tmp.sh now + 1 min

он начинает выполняться в нужное время, но просто зависает, это вывод команды -l:

10      Wed Jan 21 15:06:00 2015 = USER
10      Wed Jan 21 15:06:00 2015 a USER

Выходной файл tmp.txt не создается, в списке процессов нет команды 'echo' или 'tmp.sh', поэтому я не совсем понимаю, в чем проблема и как ее отладить.

Стоит отметить одну вещь, которая может иметь значение, хотя она также может быть совершенно неактуальной и отвлекать вас: у пользователя root нет прав на мою домашнюю папку (я работаю в компании, которая хранит домашние папки в сети и монтируется через NAS таким образом, локальный пользователь root на моей машине фактически не имеет прав даже на чтение смонтированной папки ~, поскольку локальный корень не совпадает с удаленным корнем). Однако root определенно имеет доступ на чтение / запись к / local / USER /, поскольку это всего лишь локальный диск. Не уверен, имеет ли это какое-либо отношение, например, может быть, есть что-то в начале команды 'at', которая выполняется root и должна прочитать мой профиль bash или что-то еще, но это все равно не имеет смысла, я бы сказал, меньше всего ожидайте, что работа провалится и не будет постоянно "работать".

Я на Ubuntu 12.04.4 и имею (локальный) доступ с правами root. Заранее спасибо.

РЕДАКТИРОВАТЬ: я только что попробовал то же самое, что и root, то есть просто запустил ту же команду "at", что и пользователь root, и все работает нормально, выходной файл создан, и задание завершается.

2 ответа

Решение

После того, как @maiki разместил этот комментарий, и я посмотрел на /var/log/syslog и увидел эту ошибку (я анонимизировал ее с помощью HOSTNAME и USERID):

Jan 21 17:53:32 HOSTNAME atd[27285]: Userid USERID not found - aborting job       14 (a0000e016998f5)

Немного погуглив, я обнаружил этот пост, в котором в основном говорится, что atd должен запускаться после ypbinding при запуске компьютера, если есть нелокальные пользователи (я не эксперт в настройке компьютера, у меня есть сеть имя пользователя, которое я использую для подключения к своему компьютеру, и каждый из моей компании может подключиться таким же образом к моему компьютеру). Я просто перезапустил atd с sudo service atd restart и мои "на" рабочие места теперь работают нормально. Не уверен, как это исправить навсегда, чтобы мне не приходилось перезапускать atd каждый раз, когда я перезагружал компьютер, но я постараюсь выяснить это (и отредактировать этот ответ)

Добавьте свое имя пользователя в /etc/at.allow (создайте его, если он не существует)

Согласно справочной странице:

  • если /etc/at.allow существует, упомянутые пользователи имеют доступ к at
  • иначе если /etc/at.deny существует, все пользователи имеют доступ к at кроме упомянутых в файле.
  • иначе только root имеет доступ к at
Другие вопросы по тегам