จากตัวอย่างของอูบุนตูเราสามารถบอกได้ไหมว่าเคอร์เนลนั้นถูกคอมไพล์เองมากกว่าจะมาพร้อมกับ distro หรือไม่?
จากตัวอย่างของอูบุนตูเราสามารถบอกได้ไหมว่าเคอร์เนลนั้นถูกคอมไพล์เองมากกว่าจะมาพร้อมกับ distro หรือไม่?
คำตอบ:
แน่นอนตรวจสอบว่าdpkg
รู้เกี่ยวกับมันหรือไม่
ก่อนอื่นตรวจสอบรุ่นเคอร์เนลที่คุณใช้งานอยู่
uname -a
Linux orwell 3.2.0-4-amd64 #1 SMP Debian 3.2.65-1+deb7u2 x86_64 GNU/Linux
จากนั้นบอกdpkg
ให้ค้นหาไฟล์อิมเมจเคอร์เนลในdpkg
ฐานข้อมูล
dpkg -S /boot/vmlinuz-3.2.0-4-amd64
linux-image-3.2.0-4-amd64: /boot/vmlinuz-3.2.0-4-amd64
หรือดีกว่าใช้dlocate
จากdlocate
แพ็คเกจ dlocate
ขั้นแรกให้สร้างแคชจากdpkg
ฐานข้อมูลและใช้สิ่งนั้น ดังนั้นจึงรวดเร็ว
dlocate /boot/vmlinuz-3.2.0-4-amd64
linux-image-3.2.0-4-amd64: /boot/vmlinuz-3.2.0-4-amd64
สุดท้ายตรวจสอบว่าคลังเก็บ Debian มีแพ็คเกจนี้
apt-cache policy linux-image-3.2.0-4-amd64
linux-image-3.2.0-4-amd64:
Installed: 3.2.68-1+deb7u1
Candidate: 3.2.68-1+deb7u1
Version table:
*** 3.2.68-1+deb7u1 0
500 http://security.debian.org/ wheezy/updates/main amd64 Packages
100 /var/lib/dpkg/status
3.2.65-1 0
500 http://httpredir.debian.org/debian/ wheezy/main amd64 Packages
ถ้าไม่เช่นนั้นมันเป็นแพ็คเกจที่กำหนดเอง แน่นอนถ้า dpkg ไม่รู้เกี่ยวกับไฟล์รูปภาพเคอร์เนลของคุณไม่ได้เป็นส่วนหนึ่งของแพ็คเกจเลย แต่ถูกคอมไพล์แล้ว
ทราบว่าapt
สามารถบอกความแตกต่างระหว่างแพคเกจในการเก็บถาวร Debian และหนึ่งในชื่อเดียวกันที่รวบรวมภายใน ฉันคิดว่ามันตรวจสอบ md5sum ของแพ็คเกจ แต่ฉันลืมรายละเอียดของวิธีการทำ แพคเกจไบนารีมีข้อมูลเกี่ยวกับแฮชดูด้านล่างของapt-cache show linux-image-3.2.0-4-amd64
ตัวอย่างเช่น เช่น
Package: linux-image-3.2.0-4-amd64
Source: linux
Version: 3.2.68-1+deb7u1
Installed-Size: 105729
[...]
Size: 23483788
MD5sum: f9736f30f8b68ae79b2747d8a710ce28
SHA1: 64bfde903892801dccd04b52b12316901a02cd96
SHA256: 775814b3eff4a964b593c0bdeaac20587a4e3ddb1257a9d2bfcf1e9d3b9bfd15
apt-cache show ...
ทำงาน ฉันเห็นว่าฉันพิมพ์ผิด กำลังแก้ไขทันที
อย่างน้อยที่สุดuname -r
จะให้รุ่น kernal 3.18.6
เช่น แต่เมื่อเคอร์เนลจะรวบรวมสตริงเพิ่มเติมสามารถกำหนดค่าและติดอยู่กับที่และ distros มักจะทำเช่นนี้เพื่อบ่งบอกถึงระดับของตัวเองแพทช์ (หลังเส้นประ) 3.18.6-32-generic
และรสชาติเช่น นั่นเป็นเงื่อนงำหนึ่ง เห็นได้ชัดว่าใช้สตริงของคุณเองเมื่อคุณสร้างเคอร์เนลที่กำหนดเองสามารถเป็นอีกหนึ่ง
uname -v
ให้สตริงซึ่งโดยค่าเริ่มต้นคืออะไรเช่นนี้
#4 SMP PREEMPT Mon Mar 9 13:55:25 EDT 2015
จำนวนนั้นโดยพลการในแง่ที่ว่าจำนวนครั้งที่เคอร์เนลนี้ถูกสร้างขึ้นโดยใช้ทรีซอร์สเฉพาะโดยไม่ต้องรีทรีทรี - ซึ่งอาจเป็นประโยชน์เมื่อคุณกำลังสร้างของคุณเอง SMP
บ่งชี้เคอร์เนลแบบมัลติทาสกิ้ง (เช่นไม่ใช่แบบเรียลไทม์) และ PREEMPT เป็นตัวเลือกการกำหนดค่าอื่นที่เกี่ยวข้องกับ "preemption model" ของ scheduler แต่เงื่อนงำใหญ่ที่นี่น่าจะเป็นเวลาที่มันถูกสร้างขึ้น นี้สามารถนำมาใช้เพื่อให้ตรงกับการประทับเวลาการแก้ไข / touch
การเปลี่ยนแปลงในเคอร์เนลของตัวเองทำให้ทราบว่าสามารถเปลี่ยนแปลงได้เช่นกับ ตัวอย่างเช่นstat
บนเคอร์เนลนั้นมีลักษณะดังนี้:
File: ‘3.19-goldilocksSpecial’
Size: 6858880 Blocks: 13400 IO Block: 4096 regular file
Device: 801h/2049d Inode: 3156605 Links: 1
Access: (0644/-rw-r--r--) Uid: ( 0/ root) Gid: ( 0/ root)
Access: 2015-02-15 15:32:29.000000000 -0500
Modify: 2015-03-03 13:55:21.000000000 -0500
Change: 2015-03-03 14:02:26.767045553 -0500
Birth: -
Mon Mar 9 13:55:25 EDT 2015
ซึ่งเป็นที่สวยมากในแนวเดียวกันกับ
เหมือนกับคนอื่น ๆ
sudo apt-cache policy linux-generic
เป็นรุ่นที่ติดตั้งผ่านตัวจัดการแพคเกจและ
uname -r
เปรียบเทียบรุ่น
สำหรับฉันมัน
linux-generic:
Installed: 3.19.0.15.14
Candidate: 3.19.0.15.14
และ
3.19.0-15-generic
ซึ่งระบุรุ่นเดียวกัน
/boot
ฉันเดาว่าชื่อเดียวกันก็จะถูกเขียนทับใน ประเด็นของฉันคือฉันไม่เห็นว่าทำไมคุณคาดหวังผลลัพธ์ของuname
การเปลี่ยนแปลงหากคุณเพิ่งคอมไพล์ใหม่ในขณะที่เปลี่ยนตัวเลือกบางอย่าง ในกรณีนี้ฉันคาดหวังapt-cache
และuname -r
จะส่งกลับข้อมูลเดิมแม้ว่าคุณจะคอมไพล์ซ้ำในเครื่อง
ฉันจะบอกว่าคำตอบที่แท้จริงโดยทั่วไปคือ "ไม่คุณไม่สามารถ" มีวิธีการต่าง ๆ ที่อาจช่วยได้ในบางกรณีและสิ่งเหล่านี้ได้รับการแนะนำแล้ว แต่สิ่งเหล่านี้ดูเหมือนจะพลาดว่าสถานการณ์นี้เป็นอย่างไร ในความเป็นจริงหากคุณใช้เคอร์เนลที่กำหนดเองเคอร์เนลนั้นสามารถทำอะไรก็ได้รวมถึงการซ่อนการแสดงตนหรือดูเหมือนจะเป็นเคอร์เนลอื่น
ฉันจะกังวลถ้าคุณใช้เคอร์เนลที่กำหนดเองและไม่ทราบสิ่งนี้ วิธีที่เชื่อถือได้เพียงวิธีเดียวในการทราบว่าเคอร์เนลที่ใช้อยู่นั้นคือการติดตามอย่างละเอียดว่าเคอร์เนลใดที่คุณคอมไพล์และติดตั้ง
หากคุณไม่แน่ใจจริงๆว่าเคอร์เนลใดที่ระบบกำลังทำงานอยู่หรือแหล่งที่มาของเคอร์เนลนี้ถูกสร้างขึ้นหรือที่มาจากไหนฉันจะพิจารณาติดตั้งระบบปฏิบัติการอย่างจริงจังจากภาพลักษณ์ที่รู้จักดีและระวังในอนาคตเกี่ยวกับเมล็ดที่คุณลองใช้ จากหรือใช้