답변:
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/
재미있는 내용을 표시하는 간단한 명령을 만들 수도 있습니다.
이 사용자 정의 함수를 다음에 추가하십시오 ~/.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*
-아카이브에서도 항목을 출력합니다.
다음 명령을 사용하여 최근에 설치된 패키지를 나열 할 수도 있습니다.
grep "\ install\ " /var/log/dpkg.log
grep "\ install\ " /var/log/apt/history.log
리스트를 복사하여 apt-get에 붙여
설치되어 이후에 제거 되지 않은 패키지를 원하면 다음을 시도하십시오.
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)
일치하는 제거를 제외한 설치입니다.
참고 문헌 :
sort
, 사용 sort -u
등과 같은 패키지로 표시하는 중복 라인을 피하기 위해 두 경우 모두에서 oracle-java8-installer
그리고 많은 다른 사람.
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
…
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)