¿Cómo muestro el historial de administración del paquete apt-get a través de la línea de comando?

110

¿Hay alguna manera de mostrar el historial de los paquetes que fueron modificados por apt-get a través de la línea de comandos?

    
pregunta NES 15.01.2011 - 14:04

6 respuestas

120

Todas las acciones con apt (apt-get) se registran. Estos archivos están disponibles en / var / log / apt /. Para ver el registro de historial más reciente, ejecute:

less /var/log/apt/history.log

Estos registros se rotan (todos los meses, supongo), los archivos antiguos tienen el sufijo de un número y se comprimen. Para ver el siguiente registro de historial, use:

zless /var/log/apt/history.log.1.gz

Para ver los registros disponibles:

ls -la /var/log/apt/
    
respondido por el Lekensteyn 15.01.2011 - 14:10
19

También puede hacer un pequeño comando para mostrar el contenido interesante.

  • Agregue esta función personalizada a su ~/.bashrc :

    ### pars for fun: install | remove | rollback
    function apt-history(){
    
          case "" in
            install)
                  grep 'install ' /var/log/dpkg.log
                  ;;
            upgrade|remove)
                  grep  /var/log/dpkg.log
                  ;;
            rollback)
                  grep upgrade /var/log/dpkg.log | \
                      grep "" -A10000000 | \
                      grep "" -B10000000 | \
                      awk '{print "="}'
                  ;;
            *)
                  cat /var/log/dpkg.log
                  ;;
          esac
    }
    
  • Y llámalo en un terminal como este:

    kreso@h17:~$ apt-history install
    2013-08-06 14:42:36 install gir1.2-nautilus-3.0:amd64 <none> 1:3.8.2-0ubuntu1~ubuntu13.04.1
    2013-08-06 14:42:36 install python-nautilus:amd64 <none> 1.1-3ubuntu1
    2013-08-06 14:42:37 install insync-nautilus:all <none> 1.0.20
    2013-08-07 14:41:37 install powertop:amd64 <none> 2.1-0ubuntu1
    2013-08-07 18:44:10 install libdiscid0:amd64 <none> 0.2.2-3build1
    2013-08-07 18:44:11 install sound-juicer:amd64 <none> 3.5.0-0ubuntu1
    

Tomado de aquí

    
respondido por el Kresimir Pendic 25.08.2013 - 12:12
5

También puede usar el siguiente comando para listar los paquetes recientemente instalados

grep "\ install\ " /var/log/dpkg.log
    
respondido por el Desta Haileselassie Hagos 14.02.2014 - 00:28
2

Si quiere que los paquetes que se instalaron y no se desinstalen posteriormente, intente esto:

comm -23 <(grep "apt-get install" /var/log/apt/history.log | sed 's/.* //' | sort) \ 
<(grep "apt-get remove" /var/log/apt/history.log | sed 's/.* //' | sort) 

Estas son las instalaciones menos las eliminaciones coincidentes.

Referencias:

respondido por el hoffmanc 30.07.2015 - 05:26
1

Así es como se hace, digamos paquete mutter:

_P=mutter &&
(cat /var/log/dpkg.log{,.1};zcat /var/log/dpkg.log.*.gz) |
egrep --text "^[^ ]* [^ ]* (configure|install|remove|status [^ ]*|trigproc|upgrade) $_P[: ]" |
sort --reverse | less

El uso de dpkg.log captura operaciones que apt-get no ve.

Salida:

2016-12-20 09:47:35 status unpacked mutter:amd64 3.22.2-2ubuntu1~ubuntu16.10.1
2016-12-20 09:47:35 status installed mutter:amd64 3.22.2-2ubuntu1~ubuntu16.10.1
…
    
respondido por el Harald Rudell 20.12.2016 - 23:58
0

Para obtener el historial de actualización de un paquete específico, suponiendo que se instaló / actualizó a través de apt aquí hay un oneliner (bash y zgrep), el ejemplo es para el paquete skypeforlinux:

package='skypeforlinux'; pregex="(${package}[^\)]+\))"; while read -r line; do [[ "$line" =~ ^Start-Date:[[:space:]]([[:digit:]].+) ]] && curdate="${BASH_REMATCH[1]} "; [[ "$line" =~ $pregex ]] && echo "$curdate ${BASH_REMATCH[1]}"; done < <(for i in 'ls -tr /var/log/apt/history*'; do zgrep -B3 "$package" $i; done)

Esto greps los archivos de registro de historial de apt para skypeforlinux, incluidas las tres líneas anteriores para obtener la fecha. Luego itera sobre el resultado y repite las fechas y versiones relevantes.

Reemplace el valor de la variable paquete con el nombre de su paquete, incluso funciona para varios paquetes siempre que comiencen con la misma cadena.

Ejemplo con salida:

package='apache'; pregex="(${package}[^\)]+\))"; while read -r line; do [[ "$line" =~ ^Start-Date:[[:space:]]([[:digit:]].+) ]] && curdate="${BASH_REMATCH[1]} "; [[ "$line" =~ $pregex ]] && echo "$curdate ${BASH_REMATCH[1]}"; done < <(for i in 'ls -tr /var/log/apt/history*'; do zgrep -B3 "$package" $i; done)
2017-10-19  15:00:09  apache2-utils:amd64 (2.4.18-2ubuntu3.5)
2017-11-24  14:24:45  apache-pom-java:amd64 (10-2build1, automatic)
2018-02-22  16:42:02  apache2-data:amd64 (2.4.18-2ubuntu3.5, automatic)
2018-02-26  15:34:34  apache2:amd64 (2.4.18-2ubuntu3.5)
2018-02-26  15:36:32  apache2-data:amd64 (2.4.18-2ubuntu3.5)
2018-02-26  15:40:50  apache2-data:amd64 (2.4.18-2ubuntu3.5, automatic)
2018-02-26  15:42:07  apache2:amd64 (2.4.18-2ubuntu3.5)
2018-02-26  15:42:39  apache2:amd64 (2.4.18-2ubuntu3.5)
2018-03-15  10:08:50  apache-pom-java:amd64 (10-2build1)
2018-04-20  08:55:07  apache2-data:amd64 (2.4.18-2ubuntu3.5, 2.4.18-2ubuntu3.8)
2018-07-06  08:55:11  apache2-data:amd64 (2.4.18-2ubuntu3.8, 2.4.18-2ubuntu3.9)
    
respondido por el kilgor 19.07.2018 - 11:54

Lea otras preguntas en las etiquetas