Как запустить gpg из скрипта, запущенного cron?

У меня есть сценарий, который выглядит так:

for file in `ls *.tar.gz`; do
  echo encrypting $file
  gpg --passphrase-file /home/$USER/.gnupg/backup-passphrase \
    --simple-sk-checksum -c  $file
done

По какой-то причине, если я запускаю этот скрипт вручную, он работает отлично, и все файлы зашифрованы. Если я запустил это как задание cron, echo $file будет работать нормально (я вижу «encrypting <file>» в журнале), но файл не зашифровывается, и gpg silent не работает без вывода stdout / stderr.

Какие-нибудь подсказки?

Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
26
0
23 850
7
Перейти к ответу Данный вопрос помечен как решенный

Ответы 7

убедитесь, что у пользователя, выполняющего задание cron, есть разрешения, необходимые для шифрования файла.

Однажды я столкнулся с этой проблемой.

Я не могу сказать вам, почему, но я не думаю, что cron выполняется с той же переменной среды, что и пользователь.

На самом деле мне пришлось экспортировать хороший путь, чтобы мои программы хорошо выполнялись. Gpg хотя бы пытается выполнить?

Или файлы, которые вы пытаетесь зашифровать, действительно находятся в текущем каталоге при выполнении cron?

Возможно, попробуйте выполнить echo whereis gpg и echo $PATH в своем сценарии, чтобы увидеть, включены ли они ... Сработало для меня.

Вы должны убедиться, что GPG находится на вашем пути, когда cronjob запущен. Лучше всего получить полный путь к GPG (выполнив which gpg) и запустить его, используя полный путь (например, /usr/bin/gpp...).

Некоторые другие советы по отладке:

  • выведите значение $? после запуска GPG (например: echo "$?"). Это дает вам код выхода, который должен быть 0, если это удалось.
  • перенаправить STDERR в STDOUT для GPG, а затем перенаправить STDOUT в файл, чтобы проверить любые сообщения об ошибках, которые могут быть напечатаны (вы можете сделать это из командной строки: /usr/bin/gpg ... 2>&1 >> gpg.log)
Ответ принят как подходящий

Оказывается, ответ оказался проще, чем я ожидал. Отсутствует параметр --batch, gpg пытается читать из / dev / tty, которого нет для заданий cron. Для отладки я использовал параметр --exit-on-status-write-error. Но чтобы использовать это, меня вдохновил статус выхода 2, о котором сообщалось, повторяя $?, как предлагал Cd-Man.

Спасибо за это, у нас была точно такая же проблема!

latortuga 24.02.2010 02:58

Большое спасибо, такая же проблема здесь. Они должны включать параметр --batch в gpg --help ... по крайней мере, в моей версии (1.4.10) он отсутствует.

tbk 02.04.2012 17:15

@skinp Задания Cron выполняются sh, тогда как большинство современных Unix используют bash или ksh для интерактивного входа в систему. Самая большая проблема (по моему опыту) в том, что sh не понимает таких вещей, как:

export PS1='\u@\h:\w> '

который необходимо изменить на:

PS1='\u@\h:\w> '
export PS1

Таким образом, если cron запускает сценарий оболочки, который определяет переменную среды с использованием первого синтаксиса, перед запуском какой-либо другой команды другая команда никогда не будет выполнена, потому что sh вылетает, пытаясь определить переменную.

В моем случае gpg не может найти домашний каталог для использования ключей:

gpg: no default secret key: No secret key

gpg: 0003608.cmd: sign+encrypt failed: No secret key

Поэтому я добавил --homedir /root/.gnupg. Последняя команда может выглядеть так:

echo 'password' | gpg -vvv --homedir /root/.gnupg --batch --passphrase-fd 0 --output /usr/share/file.gpg --encrypt --sign /usr/share/file.tar.bz2

В моем случае: «gpg: дешифрование не удалось: неверный ключ сеанса».

Пытался добавить / usr / bin / gpg, проверить версию, установить --batch, установить --home (с /root/.gnupg и /home/user/.gnupg), и все не сработало.

/usr/bin/gpg -d --batch --homedir /home/ec2-user/.gnupg --no-mdc-warning -quiet --passphrase "$GPG_PP" "$file"

Оказалось, что для cron в экземпляре beanstalk AWS требуется переменная среды, которая используется для установки --passphrase $ GPG_PP. Cron сейчас:

0 15 * * * $(source /opt/elasticbeanstalk/support/envvars && /home/ec2-user/bin/script.sh >> /home/ec2-user/logs/cron_out.log 2>&1)

Другие вопросы по теме