看起来像是mount -o loop
更改了已安装的映像文件。我下载了 ISO 映像文件并检查了其 SHA-1 校验和。然后我安装了 ISO 文件并且校验和发生了变化。以下是我执行的具体步骤,从我的控制台 CentOS 7 x64 复制粘贴(注意,ISO 文件是只读的):
[mbartnicki@89-78-33-81 Downloads]$ ls -lh
total 3.1G
-r--r--r--. 1 mbartnicki mbartnicki 3.1G Mar 31 18:28 X17-58997.iso
[mbartnicki@89-78-33-81 Downloads]$ sha1sum X17-58997.iso
6c9058389c1e2e5122b7c933275f963edf1c07b9 X17-58997.iso
[mbartnicki@89-78-33-81 Downloads]$ sudo mount -o loop X17-58997.iso /mnt/iso/
mount: /dev/loop0 is write-protected, mounting read-only
[mbartnicki@89-78-33-81 Downloads]$ sha1sum X17-58997.iso
994944df320e9e03c032263d7b9e36157a0a587c X17-58997.iso
我很惊讶,我在另一台机器(Ubuntu 14.04 x64)上重复了上述步骤,只是为了得到相同的结果:文件校验和在mount -o loop
.卸载 ISO 映像不会将其校验和恢复为原始值;文件更改是持久的。此外,下一次安装再次将校验和更改为某个新值。怎么解释呢?
聚苯乙烯
通过添加挂载选项显式只读挂载ro
可防止文件被更改,因此如果我使用:
sudo mount -o ro,loop X17-58997.iso /mnt/iso
然后一切正常,ISO镜像文件挂载后保持不变。仅当未指定选项时才会出现错误行为ro
,即使 ISO 映像文件在文件系统级别上是只读的。我尝试了三种不同的ISO映像:Windows 7安装DVD(官方)、SystemRescueCD(小型救援Linux)和工具创建的手工ISO genisoimage
。
我用实用程序检查了所有 ISO 文件file
,并file
说它们都是ISO 9660 CD-ROM 文件系统数据。 ISO 映像内的文件没有更改 - 我也检查过 - 看起来错误的安装场景添加了一些元数据或只是垃圾。
答案1
Iso 不是只读的同义词,在某些情况下,您可能希望挂载 iso 读/写(创建启动介质时)。
如果您想只读,请使用选项
mount -o ro,iso