ฉันจะแสดงประวัติการจัดการแพกเกจ apt-get ผ่านบรรทัดรับคำสั่งได้อย่างไร


116

มีวิธีแสดงประวัติของแพ็กเกจที่เปลี่ยนแปลงโดย apt-get ผ่าน command line หรือไม่?


คำตอบ:


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 อาจมีผู้ใช้ที่กำลังติดตั้ง (นี้จะไม่ช่วยถ้าการติดตั้งที่ถูกเรียกใช้ผ่านเปลือก / โปรแกรมทำงานเป็น root)
Lekensteyn

3
มีประโยชน์เช่นกัน: zgrep, zcat
ishmael

ไฟล์นี้ยังบันทึกการติดตั้งแพ็กเกจอ้างอิงเนื่องจาก apt-get ดั้งเดิมหรือไม่?
Mahesha999

2
@LimitedAtonement APT รุ่นล่าสุดเสนอส่วน "คำขอโดย:" เพื่อแสดงว่าใครเป็นผู้เรียกใช้คำสั่งและคำสั่งที่เรียกเช่น "Commandline: packagekit role = 'update-packages'" หรือ "Commandline: 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

6

คุณยังสามารถใช้คำสั่งต่อไปนี้เพื่อแสดงรายการแพ็คเกจที่เพิ่งติดตั้ง

grep "\ install\ " /var/log/dpkg.log

1
ดียิ่งขึ้น: grep "\ install\ " /var/log/apt/history.logในกรณีที่คุณต้องการคัดลอกและวางรายการลงใน apt-get
mchid

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

นี่คือวิธีที่คุณทำจริงพูดแพคเกจ 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
โปรดทราบว่า backticks สามตัวที่นี่ไม่ทำงานอย่างที่คุณคิด
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)

ไฟล์บันทึกประวัติของ grept apt สำหรับ skypeforlinux รวมถึงสามบรรทัดก่อนหน้าเพื่อรับวันที่ จากนั้นวนซ้ำผลลัพธ์และสะท้อนวันที่และรุ่นที่เกี่ยวข้อง

แทนที่ค่าตัวแปรแพ็กเกจด้วยชื่อแพ็กเกจของคุณแม้ทำงานได้กับหลายแพ็กเกจหากพวกเขาเริ่มต้นด้วยสตริงเดียวกัน

ตัวอย่างที่มีเอาท์พุท:

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.