it-swarm.cn

列出可用更新,但不安装它们

我希望我的cron运行报告脚本能够在程序包有更新的情况下通知我。是否可以让apt-get给我可用的更新列表,但不执行其他操作?

231
Morris

易于

对于apt的现代版本,为此有一个特定的开关:

apt list --upgradeable

apt-get

对于旧的apt-get命令-u开关显示可升级的软件包列表:

# apt-get -u upgrade --assume-no

来自 - apt-get手册页

-u
-显示升级
 显示升级的软件包;打印出所有要升级的软件包的列表。配置项:APT :: Get :: Show-Upgradeed。
-假设没有 所有提示自动“否”。 <==为了防止它开始安装
255
jasonwryan
apt-get --just-print upgrade

不那么容易读,下面是Perl的一个衬里来解析apt-get的输出:

apt-get --just-print upgrade 2>&1 | Perl -ne 'if (/Inst\s([\w,\-,\d,\.,~,:,\+]+)\s\[([\w,\-,\d,\.,~,:,\+]+)\]\s\(([\w,\-,\d,\.,~,:,\+]+)\)? /i) {print "PROGRAM: $1 INSTALLED: $2 AVAILABLE: $3\n"}'

这应该输出类似:

PROGRAM: grub-pc INSTALLED: 1.99-21ubuntu3.1 AVAILABLE: 1.99-21ubuntu3.9

希望它会帮助别人,

67
Tom

受enzotib启发的另一种选择:

aptitude search '~U' | wc -l

此命令将使用aptitude输出新的软件包,然后使用wc只是计算行数。

在一个旁注中,我发现没有~U周围的单引号的enzotib解决方案对我不起作用。 (Wheezy,ZSH,能力0.6.8.2)

更新:

使用新的apt,您可以执行以下操作:

apt list --upgradeable

34
cete3

最简单的是:

apt list --upgradeable

27
AJM

你可以跑

aptitude -F%p --disable-columns search ~U

或无证件

/usr/lib/update-notifier/apt-check -p; echo

另一种使用apt-get模拟:

apt-get -s dist-upgrade | awk '/^Inst/ { print $2 }'
19
enzotib

看一看“ apticron”软件包:

apticron-用于邮寄有关待处理软件包更新的简单工具

Apticron是一个简单的脚本,它每天发送有关待处理的软件包更新(例如安全更新)的电子邮件,并通过dselect和aptitude正确处理保留的软件包。

https://packages.debian.org/buster/apticron

11
f4m8
apt-get update && apt-get -s upgrade

将列出可用更新,而无需实际安装。

在完成模拟(因此-s)升级之前,第一个命令将更新软件包索引文件。 “ -s”将进行模拟升级,显示将要安装但实际上不会安装任何包的数据包。

相反,确认后实际上将安装“ -u”而不是“ -s”。

10
ajaaskel

我需要有关可能升级的完整版本信息,因此我对jasonwryan的答案进行了修改:

apt-get -V -u upgrade

这很简单,而且IMO的格式合理。

9
Ben Brian

只需过滤输出

apt-get update && apt-get -s -V -u upgrade

在日志中仅包含首选信息。

最有可能的是,您需要在生产线之后添加漂亮的部分

...

以下软件包将被升级:

...

开头没有空格。

3
freealx

喷射另一架飞机,灵感来自 此答案

function a { read input;dpkg -l ${input} | grep " ${input} " | awk '{$1=$2=$3=$4="";print $0}' | sed 's/^ *//';unset input;};{ apt-get --just-print upgrade 2>&1 | Perl -ne 'if (/Inst\s([\w,\-,\d,\.,~,:,\+]+)\s\[([\w,\-,\d,\.,~,:,\+]+)\]\s\(([\w,\-,\d,\.,~,:,\+]+)\)? /i) {print "$1 (\e[1;34m$2\e[0m -> \e[1;32m$3\e[0m)\n"}';} | while read -r line; do echo -en "$line $(echo $line | awk '{print $1}' | a )\n"; done;

输出看起来像这样(彩色):

locales (2.13-38+deb7u7 -> 2.13-38+deb7u8) Embedded GNU C Library: National Language (locale) data [support]
linux-headers-3.2.0-4-AMD64 (3.2.65-1+deb7u1 -> 3.2.65-1+deb7u2) Header files for Linux 3.2.0-4-AMD64
linux-headers-3.2.0-4-common (3.2.65-1+deb7u1 -> 3.2.65-1+deb7u2) Common header files for Linux 3.2.0-4
Sudo (1.8.5p2-1+nmu1 -> 1.8.5p2-1+nmu2) Provide limited super user privileges to specific users

如果您不希望简短说明,请使用以下内容:

{ apt-get --just-print upgrade 2>&1 | Perl -ne 'if (/Inst\s([\w,\-,\d,\.,~,:,\+]+)\s\[([\w,\-,\d,\.,~,:,\+]+)\]\s\(([\w,\-,\d,\.,~,:,\+]+)\)? /i) {print "$1 (\e[1;34m$2\e[0m -> \e[1;32m$3\e[0m)\n"}';} | while read -r line; do echo -en "$line\n"; done;

输出:

locales (2.13-38+deb7u7 -> 2.13-38+deb7u8)
linux-headers-3.2.0-4-AMD64 (3.2.65-1+deb7u1 -> 3.2.65-1+deb7u2)
linux-headers-3.2.0-4-common (3.2.65-1+deb7u1 -> 3.2.65-1+deb7u2)
Sudo (1.8.5p2-1+nmu1 -> 1.8.5p2-1+nmu2)
2
Compilenix
apt-get update > /dev/null && apt-get --just-print upgrade | grep "Inst "

对Cron电子邮件来说是最简单的;没有用户迭代,并且如果没有更新,则没有输出。

2
user1133275

apt-check可能是最有效的脚本编制方法。

/usr/lib/update-notifier/apt-check 2>&1 | cut -d ';' -f 1

很小的修改仅显示安全更新。

/usr/lib/update-notifier/apt-check 2>&1 | cut -d ';' -f 2
1
flickerfly

在对@jasonwryan的答案写警告之后,我想提供自己的解决方案:

apt-get dist-upgrade --assume-no

不幸的是,这与debian wheezy不兼容,我不得不检查一些仍未升级的lxc容器。此表格将始终有效:

apt-get dist-upgrade </dev/null

最后,我还想重新格式化输出。我选择再次更改通话(使用--dry-run,但忽略所有其他输出),因为这样感觉更安全:

apt-get --dry-run dist-upgrade | awk '
BEGIN{p=0}
/^The/{p=1;t=$0}
/no longer required/{p=0}
#optional: /been kept back/{p=0}
p && t{print t;t=""}
/^  / && p{print $0}
'

返回值:

The following packages have been kept back:
  iproute
The following packages will be upgraded:
  unzip
1
Daniel Alder

作为变体,我使用以下内容:

apt-get -V -s dist-upgrade \
    |grep -E "^   .*=>.*" \
    |awk 'BEGIN {
        ul=sprintf("%*s",40,""); gsub(/ /,"-",ul);
        printf "%-30s %-30s %-30s\n", "Package", "Installed", "Available";
        printf "%-30.30s %-30.30s %-30.30s\n", ul, ul, ul;
     }
     {
        printf "%-30s %-30s %-30s\n",
               $1,
               substr($2,2),
               substr($4,1,length($4)-1)
     }'

将其粘贴到名为apt-updates的脚本中,然后可以调用apt-updates以获得所有更新的列表,无论用户是谁。

您仍然需要通过特权访问apt-get update

0
Brett Ryan

apt-show-versions 工具。要显示可用更新,请运行:

apt-show-versions -u
0
agc

我喜欢用这个:

apt-get -qq update && apt-get -qq -s upgrade

您会得到如下输出:

Inst linux-base [3.5] (4.5~deb8u1 Debian-Security:8/oldstable [all])
Conf linux-base (4.5~deb8u1 Debian-Security:8/oldstable [all])

如果有可用的更新,则没有更新。这样,您可以简单地将其与监视解决方案结合在一起。

0
user3310438