명령 행을 통해 apt-get 패키지 관리 내역을 표시하려면 어떻게합니까?


답변:


131

apt (apt-get) 인 모든 작업이 기록됩니다. 이 파일들은 / var / log / apt /에 있습니다. 가장 최근의 이력 로그를 보려면 다음을 실행하십시오.

less /var/log/apt/history.log

이 로그는 회전합니다 (매달 추측합니다). 오래된 파일에는 접미사가 붙어 압축됩니다. 다음 히스토리 로그를 보려면 다음을 사용하십시오.

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

사용 가능한 로그를 보려면

ls -la /var/log/apt/

4
이것은 우수하다. 유일하게 누락 된 것은 명령을 실행 한 사람입니다.
한정된 속죄

3
@LimitedAtonement /var/log/auth.log를 살펴보면 설치를 실행중인 사용자 포함될 있습니다. (이것은 루트로 실행되는 쉘 / 프로그램을 통해 설치가 호출 된 경우 도움이되지 않습니다)
Lekensteyn

3
또한 유용 : zgrep, zcat
ishmael

이 파일은 원래 apt-get의 결과로 설치된 종속성 패키지도 기록합니까?
Mahesha999

2
@LimitedAtonement 최신 버전의 APT는 로그의 "요청한 사람 :"부분을 제공하여 명령을 호출 한 사람과 "명령 줄 : packagekit role = 'update-packages"또는 "명령 줄 : apt 업그레이드 "
Michael Tunnell

21

재미있는 내용을 표시하는 간단한 명령을 만들 수도 있습니다.

  • 이 사용자 정의 함수를 다음에 추가하십시오 ~/.bashrc.

    ### pars for fun: install | remove | rollback
    function apt-history(){
    
          case "$1" in
            install)
                  grep 'install ' /var/log/dpkg.log
                  ;;
            upgrade|remove)
                  grep $1 /var/log/dpkg.log
                  ;;
            rollback)
                  grep upgrade /var/log/dpkg.log | \
                      grep "$2" -A10000000 | \
                      grep "$3" -B10000000 | \
                      awk '{print $4"="$5}'
                  ;;
            *)
                  cat /var/log/dpkg.log
                  ;;
          esac
    }
  • 그리고 다음과 같이 터미널에서 호출하십시오.

    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
    

여기 에서 찍은


zgrep ... /var/log/dpkg.log*-아카이브에서도 항목을 출력합니다.
Ctrl-C


2

설치되어 이후에 제거 되지 않은 패키지를 원하면 다음을 시도하십시오.

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) 

일치하는 제거를 제외한 설치입니다.

참고 문헌 :


+1 : 좋은 한 줄짜리지만 마지막 로그 교체 기간에만 유효합니다. 대신 또한 sort, 사용 sort -u등과 같은 패키지로 표시하는 중복 라인을 피하기 위해 두 경우 모두에서 oracle-java8-installer그리고 많은 다른 사람.
Cbhihe

1

package 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

dpkg.log를 사용하면 apt-get이 볼 수없는 작업이 캡처됩니다.

산출:

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
…

1
여기에 트리플 배틱은 생각한대로 작동하지 않습니다.
edwinksl

1

apt를 통해 설치 / 업데이트되었다고 가정 할 때 특정 패키지의 업데이트 기록을 얻으려면 oneliner (bash 및 zgrep)가 있습니다 (예 : 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)

이것은 날짜를 얻기 위해 이전 세 줄을 포함하여 skypeforlinux에 대한 apt의 기록 로그 파일을 그립니다. 그런 다음 결과를 반복하고 관련 날짜와 버전을 에코합니다.

바꾸기 패키지 도 여러 패키지 작동, 패키지 이름을 가진 변수 값은 동일한 문자열로 시작 제공.

출력 예 :

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)
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.