RHEL Engineering is moving the tracking of its product development work on RHEL 6 through RHEL 9 to Red Hat Jira (issues.redhat.com). If you're a Red Hat customer, please continue to file support cases via the Red Hat customer portal. If you're not, please head to the "RHEL project" in Red Hat Jira and file new tickets here. Individual Bugzilla bugs in the statuses "NEW", "ASSIGNED", and "POST" are being migrated throughout September 2023. Bugs of Red Hat partners with an assigned Engineering Partner Manager (EPM) are migrated in late September as per pre-agreed dates. Bugs against components "kernel", "kernel-rt", and "kpatch" are only migrated if still in "NEW" or "ASSIGNED". If you cannot log in to RH Jira, please consult article #7032570. That failing, please send an e-mail to the RH Jira admins at rh-issues@redhat.com to troubleshoot your issue as a user management inquiry. The email creates a ServiceNow ticket with Red Hat. Individual Bugzilla bugs that are migrated will be moved to status "CLOSED", resolution "MIGRATED", and set with "MigratedToJIRA" in "Keywords". The link to the successor Jira issue will be found under "Links", have a little "two-footprint" icon next to it, and direct you to the "RHEL project" in Red Hat Jira (issue links are of type "https://issues.redhat.com/browse/RHEL-XXXX", where "X" is a digit). This same link will be available in a blue banner at the top of the page informing you that that bug has been migrated.
Bug 1179576 - virt-v2v prints warning: /files/etc/fstab/8/spec references unknown device "hdb"
Summary: virt-v2v prints warning: /files/etc/fstab/8/spec references unknown device "hdb"
Keywords:
Status: CLOSED NOTABUG
Alias: None
Product: Red Hat Enterprise Linux 7
Classification: Red Hat
Component: libguestfs
Version: 7.1
Hardware: Unspecified
OS: Unspecified
medium
medium
Target Milestone: rc
: ---
Assignee: Richard W.M. Jones
QA Contact: Virtualization Bugs
URL:
Whiteboard: V2V
Depends On:
Blocks:
TreeView+ depends on / blocked
 
Reported: 2015-01-07 06:58 UTC by zhoujunqin
Modified: 2015-09-29 13:49 UTC (History)
7 users (show)

Fixed In Version:
Doc Type: Bug Fix
Doc Text:
Clone Of:
Environment:
Last Closed: 2015-09-29 13:49:59 UTC
Target Upstream Version:
Embargoed:


Attachments (Terms of Use)
kvm-4.9-i386-raw_debug.log (9.46 KB, text/plain)
2015-01-07 06:58 UTC, zhoujunqin
no flags Details
kvm-4.9-i386-raw-modify_debug.log (9.48 KB, text/plain)
2015-01-07 06:58 UTC, zhoujunqin
no flags Details

Description zhoujunqin 2015-01-07 06:58:20 UTC
Created attachment 977113 [details]
kvm-4.9-i386-raw_debug.log

Description of problem:
virt-v2v prints warning: /files/etc/fstab/8/spec references unknown device "hdb" when convert a rhel4.9 guest to rhevm

Version-Release number of selected component (if applicable):
virt-v2v-1.28.1-1.18.el7.x86_64
libguestfs-1.28.1-1.18.el7.x86_64
libvirt-1.2.8-10.el7.x86_64
qemu-kvm-rhev-2.1.2-17.el7.x86_64

How reproducible:
100%

Steps to Reproduce:
1. Install a rhel4.9 guest with virt-install by using ISO file:

# virt-install -n kvm-4.9-i386-raw -r 1024 -f /var/lib/libvirt/images/kvm-4.9-i386-raw.img -s 5 --graphics spice -l RHEL4.9-i386-AS-DVD.iso

2. After installation finished, reboot guest and then login guest check file "/etc/fstab"  then shutdown guest without other operation.

# cat /etc/fstab
# This file is edited by fstab-sync - see 'man fstab-sync' for details
/dev/VolGroup00/LogVol00 /                       ext3    defaults        1 1
LABEL=/boot             /boot                   ext3    defaults        1 2
none                    /dev/pts                devpts  gid=5,mode=620  0 0
none                    /dev/shm                tmpfs   defaults        0 0
none                    /proc                   proc    defaults        0 0
none                    /sys                    sysfs   defaults        0 0
/dev/VolGroup00/LogVol01 swap                    swap    defaults        0 0
/dev/hdb                /media/cdrom            auto    pamconsole,fscontext=system_u:object_r:removable_t,exec,noauto,managed 0 0

# virsh list --all
 Id    Name                           State
----------------------------------------------------
 -     kvm-4.9-i386-raw               shut off

3. Use virt-v2v to convert the guest to rhev.

# virt-v2v  -o rhev -os 10.66.90.115:/vol/v2v_auto/iscsi_export kvm-4.9-i386-raw
[   0.0] Opening the source -i libvirt kvm-4.9-i386-raw
[   0.0] Creating an overlay to protect the source from being modified
[   0.0] Opening the overlay
[   2.0] Initializing the target -o rhev -os 10.66.90.115:/vol/v2v_auto/iscsi_export
virt-v2v: warning: cannot write files to the NFS server as 36:36, even
though we appear to be running as root. This probably means the NFS client
or idmapd is not configured properly.

You will have to chown the files that virt-v2v creates after the run,
otherwise RHEV-M will not be able to import the VM.
[   2.0] Inspecting the overlay
[   7.0] Checking for sufficient free disk space in the guest
[   7.0] Estimating space required on target for each disk
[   7.0] Converting Red Hat Enterprise Linux AS release 4 (Nahant Update 9) to run on KVM
virt-v2v: warning: /files/etc/fstab/8/spec references unknown device "hdb".
 You may have to fix this entry manually after conversion.
virt-v2v: This guest has virtio drivers installed.
[   9.0] Mapping filesystem data to avoid copying unused and blank areas
[   9.0] Closing the overlay
[   9.0] Copying disk 1/1 to /tmp/v2v.bMJtdS/f6d2eaca-b8b0-45ec-ace7-e947a7c0d150/images/650c621a-cf1b-4c50-805a-185f32338be0/7dd4b19f-2de4-4c3f-a227-cdefe2a15b8f (raw)
    (100.00/100%)
[  44.0] Creating output metadata
[  44.0] Finishing off

4. After conversion, import guest and check /etc/fstab:

/dev/hdc                /media/cdrom            auto    pamconsole,fscontext=system_u:object_r:removable_t,exec,noauto,managed 0 0

Actual results:
virt-v2v prints waringing: /files/etc/fstab/8/spec references unknown device "hdb".
 You may have to fix this entry manually after conversion.

Expected results:
No warning message.

Additional info:
1. I will attach detail debug information, called kvm-4.9-i386-raw_debug.log.
2. If i modify /etc/fstab content before conversion:
From
/dev/hdb                /media/cdrom            auto    pamconsole,fscontext=system_u:object_r:removable_t,exec,noauto,managed 0 0
To
/dev/cdrom                /media/cdrom            auto    pamconsole,fscontext=system_u:object_r:removable_t,exec,noauto,managed 0 0

Then converted it to rhevm, there is no warning message.
# virt-v2v  -o rhev -os 10.66.90.115:/vol/v2v_auto/iscsi_export kvm-4.9-i386-raw  -on kvm-4.9-i386-raw-modify
[   0.0] Opening the source -i libvirt kvm-4.9-i386-raw
[   0.0] Creating an overlay to protect the source from being modified
[   0.0] Opening the overlay
[   3.0] Initializing the target -o rhev -os 10.66.90.115:/vol/v2v_auto/iscsi_export
virt-v2v: warning: cannot write files to the NFS server as 36:36, even
though we appear to be running as root. This probably means the NFS client
or idmapd is not configured properly.

You will have to chown the files that virt-v2v creates after the run,
otherwise RHEV-M will not be able to import the VM.
[   4.0] Inspecting the overlay
[   7.0] Checking for sufficient free disk space in the guest
[   7.0] Estimating space required on target for each disk
[   7.0] Converting Red Hat Enterprise Linux AS release 4 (Nahant Update 9) to run on KVM
virt-v2v: This guest has virtio drivers installed.
[  10.0] Mapping filesystem data to avoid copying unused and blank areas
[  10.0] Closing the overlay
[  10.0] Copying disk 1/1 to /tmp/v2v.Vg2YZd/f6d2eaca-b8b0-45ec-ace7-e947a7c0d150/images/dcd7a302-e105-414d-9446-c36384639628/0ec98e1b-3173-462c-a9a2-60f309323f40 (raw)
    (100.00/100%)
[  43.0] Creating output metadata
[  43.0] Finishing off

And i will also attach debug log, called: kvm-4.9-i386-raw-modify_debug.log

Comment 1 zhoujunqin 2015-01-07 06:58:59 UTC
Created attachment 977114 [details]
kvm-4.9-i386-raw-modify_debug.log

Comment 2 Richard W.M. Jones 2015-01-19 10:48:27 UTC
We should probably ignore any mountpoint that looks like /media/cdrom.

Does it really change /dev/hdb to /dev/hdc or was that a mistake
in the bug report?  That's pretty unexpected if it is happening.

Comment 3 zhoujunqin 2015-01-20 02:39:16 UTC
(In reply to Richard W.M. Jones from comment #2)
> We should probably ignore any mountpoint that looks like /media/cdrom.
> 
> Does it really change /dev/hdb to /dev/hdc or was that a mistake
> in the bug report?  That's pretty unexpected if it is happening.

Hi rjones,
Yes, it really change /dev/hdb to /dev/hdc after conversion as bug described, not by mistake, thanks.

Comment 4 Richard W.M. Jones 2015-09-23 14:53:19 UTC
-> 7.3.  Quite a serious bug that needs more investigation.

Comment 5 Richard W.M. Jones 2015-09-25 15:01:45 UTC
I was unable to find RHEL4.9-i386-AS-DVD.iso.

I tried to reproduce the bug using the instructions below, but
it was not reproducible in either 1.28.1-1.55.el7, nor in upstream.

Junqin: Do you have the file RHEL4.9-i386-AS-DVD.iso or a link to it?

---------

$ virt-builder rhel-4.9
$ guestfish  -a rhel-4.9.img -i 
><fs> emacs /etc/fstab

Append the following single line to guest /etc/fstab:

/dev/hdb /media/cdrom auto pamconsole,fscontext=system_u:object_r:removable_t,exec,noauto,managed 0 0

Convert the guest (append -v -x options to capture more debug info):

$ virt-v2v -i disk rhel-4.9.img -o local -os /var/tmp

Examine the converted guest's /etc/fstab file:

$ virt-cat -a /var/tmp/rhel-4.9-sda /etc/fstab

Comment 8 Richard W.M. Jones 2015-09-28 16:02:57 UTC
I couldn't reproduce this precisely, but I'm fairly sure the problem
is fixed upstream.  I ran the virt-install command given in the
description, and installed RHEL 4.9, but the /etc/fstab did not
contain the /dev/hdb device.  However I added that manually.

I then did the conversion.  The (correct) warning was printed:

virt-v2v: warning: /files/etc/fstab/8/spec references unknown device "hdb". 
 You may have to fix this entry manually after conversion.

After examining the converted guest, I found that /etc/fstab still
contained the /dev/hdb device which I added manually.  It was not
renumbered to /dev/hdc (which would have been a bug, if it had happened).

So as far as I can tell the bug has fixed itself upstream (most likely
because of https://github.com/libguestfs/libguestfs/commit/ce83f2751bea272b96107482aeb37af2358214dc ).

Junqin/Tingting: Do you want to try to see if you can reproduce the
bug again, or shall I close it?

Comment 9 mxie@redhat.com 2015-09-29 10:20:11 UTC
Junqin is on vacation,so I help to verify this bug

I can reproduce the bug with builds:
virt-v2v-1.28.1-1.55.el7.x86_64
libguestfs-1.28.1-1.55.el7.x86_64
libvirt-1.2.17-11.el7.x86_64
qemu-kvm-rhev-2.3.0-26.el7.x86_64

How reproducible:
100%

Steps to Reproduce:
1. Install a rhel4.9 guest with virt-install by using ISO file:

# virt-install -n kvm-4.9-x86 -r 1024 -f kvm-4.9-x86-raw.img -s 5 --graphics spice -l /root/Desktop/RHEL4.9-i386-AS-DVD.iso 

2. After installation finished, reboot guest and then login guest check file "/etc/fstab"  then shutdown guest without other operation.

# cat /etc/fstab
# This file is edited by fstab-sync - see 'man fstab-sync' for details
/dev/VolGroup00/LogVol00 /                       ext3    defaults        1 1
LABEL=/boot             /boot                   ext3    defaults        1 2
none                    /dev/pts                devpts  gid=5,mode=620  0 0
none                    /dev/shm                tmpfs   defaults        0 0
none                    /proc                   proc    defaults        0 0
none                    /sys                    sysfs   defaults        0 0
/dev/VolGroup00/LogVol01 swap                    swap    defaults        0 0
/dev/hdb                /media/cdrom            auto     pamconsole,fscontext=system_u:object_r:removable_t,exec,noauto,managed 0 0

3. Use virt-v2v to convert the guest to rhev.

# virt-v2v -o rhev -os 10.66.90.115:/vol/v2v_auto/auto_export kvm-4.9-x86
[   0.0] Opening the source -i libvirt kvm-4.9-x86
[   0.0] Creating an overlay to protect the source from being modified
[   1.0] Opening the overlay
[   4.0] Initializing the target -o rhev -os 10.66.90.115:/vol/v2v_auto/auto_export
virt-v2v: warning: cannot write files to the NFS server as 36:36, even 
though we appear to be running as root. This probably means the NFS client 
or idmapd is not configured properly.

You will have to chown the files that virt-v2v creates after the run, 
otherwise RHEV-M will not be able to import the VM.
[   4.0] Inspecting the overlay
[  11.0] Checking for sufficient free disk space in the guest
[  11.0] Estimating space required on target for each disk
[  11.0] Converting Red Hat Enterprise Linux AS release 4 (Nahant Update 9) to run on KVM
virt-v2v: warning: /files/etc/fstab/8/spec references unknown device "hdb". 
 You may have to fix this entry manually after conversion.
virt-v2v: This guest has virtio drivers installed.
[  15.0] Mapping filesystem data to avoid copying unused and blank areas
[  15.0] Closing the overlay
[  15.0] Checking if the guest needs BIOS or UEFI to boot
[  15.0] Copying disk 1/1 to /tmp/v2v.Zdqi4Q/f2ab9c04-e53f-4465-b2f0-8b28fb5905cc/images/2a2f9931-ec1d-43c0-9e50-9fd61210537c/63a3451a-89be-4019-9e12-0ba71bd80bff (raw)
    (100.00/100%)
[  48.0] Creating output metadata
[  48.0] Finishing off

4. After conversion, import guest and check /etc/fstab:

/dev/hdc                /media/cdrom            auto    pamconsole,fscontext=system_u:object_r:removable_t,exec,noauto,managed 0 0

Actual results:
1.virt-v2v prints waringing: /files/etc/fstab/8/spec references unknown device "hdb".
You may have to fix this entry manually after conversion.
2.Gues /etc/fstab change /dev/hdb to /dev/hdc after conversion
Expected results:
No warning message and /etc/fstab will not change after conversion

Comment 10 Richard W.M. Jones 2015-09-29 13:49:59 UTC
I managed to reproduce it.

The two steps I was missing were:

(1) Rebooting the guest after the initial install, and going through
the guest initial setup.  After doing that, /etc/fstab does contain
/dev/hdb as described in the bug report.

(2) Importing the guest into RHEV and booting it up.  /etc/fstab is
modified *by the guest itself*, so the CDROM entry is changed to point
to wherever the CD is placed.

Immediately after conversion, /etc/fstab is correct.  It's only when
the guest is booted that the guest itself changes /etc/fstab.

Therefore: it's not a bug.  But it was definitely good to go through
this process so we understand the problem, so thanks everyone.

(The warning message printed out by virt-v2v is correct.)


Note You need to log in before you can comment on or make changes to this bug.