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
    • 最新
    • 标签
主页 / ubuntu / 问题 / 1128433
Accepted
Sqerstet
Sqerstet
Asked: 2019-03-25 21:15:44 +0800 CST2019-03-25 21:15:44 +0800 CST 2019-03-25 21:15:44 +0800 CST

如何确保在断断续续的互联网连接上定期运行安全升级?

  • 772

对于未永久连接到互联网的计算机,Ubuntu 似乎有一个持久的安全升级盲点。这些天肯定有很多,主要是笔记本电脑。

理论上解决方案是unattended-upgrades。在 Ubuntu 上,它默认使用每日systemd计时器或 cron 作业运行。使用 cron,anacron默认情况下也作为保护运行,并执行cron因计算机关闭而错过的任何作业。到目前为止如此明智。

但!

  1. 默认unattended-upgrades配置(/etc/apt/apt.conf.d/50unattended-upgrades或类似配置)需要设置以下内容,否则在漫游笔记本电脑上可能会跳过升级:

    Unattended-Upgrade::OnlyOnACPower "false";
    Unattended-Upgrade::Skip-Updates-On-Metered-Connections "false";
    
  2. 更糟糕的是,anacron无论cron是否有 Internet 连接,都可以运行作业!这显然是非服务器 Ubuntu 的一个主要设计错误,因为个人计算机并不总是永久连接。

TLDR:使用默认配置,在漫游的笔记本电脑上,unattended-upgrades大部分时间都不会工作。

(也许需要有一个单独的cron作业类或systemd计时器类,它等待网络连接直到执行。或者失败的cron.daily作业可以切换到cron.hourly它们成功执行。也许已经有一个。)

一种实用的解决方案是在网络上线后作为用户脚本systemd执行的单元文件。unattended-upgrades但每次启动它只会运行一次。

最佳解决方案是什么?有谁知道是否有计划通过新软件包或配置改进来解决这个问题?

security apt unattended-upgrades 18.04 anacron
  • 1 1 个回答
  • 1001 Views

1 个回答

  • Voted
  1. Best Answer
    Sqerstet
    2019-03-25T21:15:44+08:002019-03-25T21:15:44+08:00

    如果使用 Ubuntu 上的当前默认值连接到互联网network-manager,则创建一个调度程序脚本以在连接到网络后启动unattended-upgrade(是一个符号链接,也可以):unattended-upgrades

    sudo touch /etc/NetworkManager/dispatcher.d/20-myconnectionscript
    sudo chmod +x /etc/NetworkManager/dispatcher.d/20-myconnectionscript
    

    在20-myconnectionscript:

    #!/bin/sh
    
    if [ "$2" = "up" ];
      # only proceed if unattended-upgrades was last run more than a day ago
      ELAPSEDSINCEUU=$(($(date +%s) - $(date +%s -r /var/lib/apt/periodic/unattended-upgrades-stamp)))
      if [ $ELAPSEDSINCEUU -gt 86400 ]; then
        apt update --yes # replace, see below
        /usr/bin/unattended-upgrade # replace, see below
      fi
    fi
    

    编辑。结果unattended-upgrades不会触发更新包列表。因此,如果unattended-upgrades一直失败,那么很有可能apt update也失败了,在这种情况下,升级将继续不会发生!因此添加了对脚本的手动更新。令人失望的是,确保安全升级必须如此复杂。

    编辑 2。如果您想绝对确定您的笔记本电脑是最新的,这就是您在非交互式脚本中所需要的。可以确认它工作可靠。用它替换上面的 2 行。

    DEBIAN_FRONTEND=noninteractive apt-get --yes update
    DEBIAN_FRONTEND=noninteractive apt-get --yes --allow-downgrades --allow-remove-essential --allow-change-held-packages -- option Dpkg::Options::=--force-confold --option Dpkg::Options::=--force-confdef dist-upgrade
    

    它是完整的dist-upgrade,而不仅仅是安全升级。如果有人对仅安全版本有建议,该版本在非交互式运行时始终有效,并且不会涉及过多的 repo 配置,请提出建议。

    再一次:unattended-upgrades 不能指望在间歇性连接的计算机上工作。Ubuntu 安全团队确实需要解决这种情况。

    • 3

相关问题

  • 使用 apt-get upgrade 时如何强制安装内核更新?

  • 如何从命令行仅安装安全更新?关于如何管理更新的一些提示

  • iptables 的图形用户界面?

  • 如何启用自动更新?

  • 如何与无头服务器进行图形交互?

Sidebar

Stats

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

    如何运行 .sh 脚本?

    • 16 个回答
  • Marko Smith

    如何安装 .tar.gz(或 .tar.bz2)文件?

    • 14 个回答
  • Marko Smith

    如何列出所有已安装的软件包

    • 24 个回答
  • Marko Smith

    无法锁定管理目录 (/var/lib/dpkg/) 是另一个进程在使用它吗?

    • 25 个回答
  • Martin Hope
    Flimm 如何在没有 sudo 的情况下使用 docker? 2014-06-07 00:17:43 +0800 CST
  • Martin Hope
    Ivan 如何列出所有已安装的软件包 2010-12-17 18:08:49 +0800 CST
  • Martin Hope
    La Ode Adam Saputra 无法锁定管理目录 (/var/lib/dpkg/) 是另一个进程在使用它吗? 2010-11-30 18:12:48 +0800 CST
  • Martin Hope
    David Barry 如何从命令行确定目录(文件夹)的总大小? 2010-08-06 10:20:23 +0800 CST
  • Martin Hope
    jfoucher “以下软件包已被保留:”为什么以及如何解决? 2010-08-01 13:59:22 +0800 CST
  • Martin Hope
    David Ashford 如何删除 PPA? 2010-07-30 01:09:42 +0800 CST

热门标签

10.10 10.04 gnome networking server command-line package-management software-recommendation sound xorg

Explore

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

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve