AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 437931
Accepted
Madoc Comadrin
Madoc Comadrin
Asked: 2018-04-16 10:03:18 +0800 CST2018-04-16 10:03:18 +0800 CST 2018-04-16 10:03:18 +0800 CST

由 Systemd 运行时,无人值守升级不会使用 mailx

  • 772

我unattended-upgrades在运行 Raspbian ( Raspbian GNU/Linux 9.4 (stretch)) 的服务器上进行了设置。无人值守升级版本:0.93.1+nmu1

更新有效,但我在电子邮件报告方面遇到问题。我想mailx用于发送报告。如果我使用命令运行更新,unattended-upgrade -v -d则会发送报告并使用我在/root/.mailrc.

但是,当unattended upgrades由 Systemd 计时器 ( apt-daily-upgrade.timer) 运行时,它不会使用mailx.

如果sendmail存在,则用于发送邮件。在这种情况下,邮件被发送,但发件人是root@hostname并且邮件被标记为垃圾邮件。

如果没有,sendmail我会在以下日志中看到此错误apt-daily-upgrade:

Cannot start "/usr/sbin/sendmail": executable not found (adjust *sendmail* variable)

我不明白为什么根据任务的启动方式使用不同的邮件程序。

我试图编辑unattended-upgradesPython 程序以强制它使用mailx:

if os.path.exists(SENDMAIL_BINARY):
        ret = _send_mail_using_sendmail(from_email, to_email, subject, body)
    elif os.path.exists(MAIL_BINARY):
        ret = _send_mail_using_mailx(from_email, to_email, subject, body

我将变量更改SENDMAIL_BINARY为指向不存在的路径,因此它将强制使用mailx. 这在unattended-upgrades手动调用时也有效,但在 Systemd 运行时失败。(并且上面关于尝试使用的错误sendmail仍然被记录下来。)

即使由 systemd 自动运行,我如何强制unattended upgrades使用以及导致使用的邮件程序不同的原因是什么?mailx

编辑:

运行无人值守升级的系统单元文件:

[Unit]
Description=Daily apt upgrade and clean activities
Documentation=man:apt(8)
ConditionACPower=true
After=apt-daily.service

[Service]
Type=oneshot
ExecStart=/usr/lib/apt/apt.systemd.daily install
KillMode=process
TimeoutStopSec=900
systemd sendmail
  • 2 2 个回答
  • 1686 Views

2 个回答

  • Voted
  1. Best Answer
    Mark Stosberg
    2018-04-16T13:09:28+08:002018-04-16T13:09:28+08:00

    您的问题是常见问题解答的变体。为什么在 systemd 下事情会有所不同?.

    好处之一systemd是它提供了一致的执行环境。为了在安全性和简单性方面出错,环境变量集是最小的。

    systemd执行环境的相关文档详细说明了设置的内容。

    您提到您的配置位于root主目录中。man mailx确认它正在寻找~/.mailrc,而不是固定路径/root/.mailrc。

    systemd文档阐明该变量$HOME仅在使用User=指令时设置。您没有共享您的systemd服务文件,但我认为由于您以 root 身份运行任务,因此您没有使用该User=指令。所以这可以解释你的部分问题。

    似乎您想要的路径$PATH在运行时可能不是由您的环境变量设置的systemd。您可以通过将ExecStart=服务中的行替换为:

     ExecStart=/bin/echo "My path is $PATH"
    

    如果mailx路径未列出,您可以使用Environment=指令显式设置。

    如果这个明确的提示不能解决您的问题,请务必查看上面链接的常见问题解答以获得更多可能性。

    • 3
  2. Sicco
    2020-04-23T05:48:33+08:002020-04-23T05:48:33+08:00

    我在 Ubuntu 18.04 上使用msmtpandbsd-mailx允许unattended-upgrades通过电子邮件向我发送更新。我想我遇到了和你一样的问题。我进行了配置,并且可以使用命令行msmtp发送电子邮件。如果我自己从命令行运行它,也会给我发送一封电子邮件,但如果会自动运行,那么我将不会收到任何电子邮件。查看我看到的日志:mailxunattended-upgradesunattended-upgrades/var/log/msmtp/msmtp.log

    <DATE> host=<MY_SMTP_HOST> tls=on auth=on user=<MY_STMP_USERNAME> from=<MY_EMAIL_ADDRESS> recipients=<MY_EMAIL_ADDRESS> smtpstatus=550 smtpmsg='550 5.2.0 Mail format error: No domain in From header [1633]' errormsg='the server did not accept the mail' exitcode=EX_UNAVAILABLE
    

    所以设置有问题From header。深入研究这一点,默认from使用的电子邮件地址似乎是,但您可以通过添加来自己定义。这为我修好了。unattended-upgradesroot/etc/apt/apt.conf.d/50unattended-upgradesUnattended-Upgrade::Sender "<EMAIL_ADDRESS>";

    • 2

相关问题

  • journalctl 中的区分级别

  • 将默认编辑器更改为 vim for _ sudo systemctl edit [unit-file] _

  • systemd:如何在服务启动时运行脚本,而不编辑服务定义

  • 使用 systemd 看门狗支持重新启动应用程序

  • 使用键盘快捷键启动/停止 systemd 服务 [关闭]

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    ssh 无法协商:“找不到匹配的密码”,正在拒绝 cbc

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    如何卸载内核模块“nvidia-drm”?

    • 13 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Wong Jia Hau ssh-add 返回:“连接代理时出错:没有这样的文件或目录” 2018-08-24 23:28:13 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST
  • Martin Hope
    Bagas Sanjaya 为什么 Linux 使用 LF 作为换行符? 2017-12-20 05:48:21 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve