Bug 1797879

Summary: Modify the error message when failed to create an iscsi-direct pool
Product: Red Hat Enterprise Linux Advanced Virtualization Reporter: gaojianan <jgao>
Component: libvirtAssignee: Michal Privoznik <mprivozn>
Status: CLOSED ERRATA QA Contact: Meina Li <meili>
Severity: low Docs Contact:
Priority: low    
Version: 8.2CC: jdenemar, jsuchane, lcheng, lmen, meili, mprivozn, xuzhang
Target Milestone: rcKeywords: Triaged, Upstream
Target Release: 8.0Flags: pm-rhel: mirror+
Hardware: x86_64   
OS: Linux   
Whiteboard:
Fixed In Version: libvirt-7.5.0-1.el8 Doc Type: If docs needed, set a value
Doc Text:
Story Points: ---
Clone Of:
: 1982609 (view as bug list) Environment:
Last Closed: 2021-11-16 07:49:56 UTC Type: Bug
Regression: --- Mount Type: ---
Documentation: --- CRM:
Verified Versions: Category: ---
oVirt Team: --- RHEL 7.3 requirements from Atomic Host:
Cloudforms Team: --- Target Upstream Version: 7.5.0
Embargoed:
Bug Depends On: 1982609    
Bug Blocks:    

Description gaojianan 2020-02-04 06:20:00 UTC
Description of problem:
Get error about logout failed rather than login fail when try to create a new iscsi-direct pool with wrong device-path.

Version-Release number of selected component (if applicable):
libvirt-6.0.0-2.virtcov.el8.x86_64
qemu-kvm-4.2.0-8.module+el8.2.0+5607+dc756904.x86_64
libiscsi-1.18.0-8.module+el8.2.0+4793+b09dd2fb.x86_64

How reproducible:
100%

Steps to Reproduce:
1.Prepare a iscsi-direct pool xml:
# cat iscsi-direct.xml
<pool type="iscsi-direct">
  <name>virtimages</name>
  <source>
    <host name="10.66.85.243"/>
    <device path="iqn.2020-01.com.virttest:blockdev-pool.target61"/>   ---this device path is unexist
            <initiator>
      <iqn name="iqn.2013-06.com.example:iscsi-initiator"/>
    </initiator>
  </source>
</pool>

But the correct device path is "iqn.2020-01.com.virttest:blockdev-pool.target6"

2.Try to create the pool from xml
# virsh pool-create iscsi-direct.xml 
error: Failed to create pool from iscsi-direct.xml
error: internal error: Failed to logout: Failed to start logout() Trying to logout while not logged in.

3.

Actual results:
As step 2

Expected results:
Need clear message such as "Failed to login `device-path`" rather than "failed to logout"

Additional info:
libvirt log:
2020-02-04 06:16:20.887+0000: 2464: debug : virStorageFileProbeFormatFromBuf:854 : format=1
2020-02-04 06:16:20.890+0000: 2464: debug : virStorageFileGetMetadataInternal:972 : path=RHEL-8.1-x86_64-latest.qcow2, buf=0x7faf2c1dde60, len=33280, meta->format=-1
2020-02-04 06:16:20.890+0000: 2464: debug : virStorageFileProbeFormatFromBuf:820 : path=RHEL-8.1-x86_64-latest.qcow2, buf=0x7faf2c1dde60, buflen=33280
2020-02-04 06:16:20.890+0000: 2464: debug : virStorageFileMatchesVersion:770 : Compare detected version 3 vs one of the expected versions 1
2020-02-04 06:16:20.890+0000: 2464: debug : virStorageFileMatchesVersion:770 : Compare detected version 3 vs one of the expected versions 2
2020-02-04 06:16:20.890+0000: 2464: debug : virStorageFileMatchesVersion:770 : Compare detected version 3 vs one of the expected versions 3
2020-02-04 06:16:20.890+0000: 2464: debug : virStorageFileProbeFormatFromBuf:854 : format=14
2020-02-04 06:16:20.894+0000: 2464: debug : virStorageFileGetMetadataInternal:972 : path=blockdev.img, buf=0x7faf2c1dde60, len=33280, meta->format=-1
2020-02-04 06:16:20.894+0000: 2464: debug : virStorageFileProbeFormatFromBuf:820 : path=blockdev.img, buf=0x7faf2c1dde60, buflen=33280
2020-02-04 06:16:20.894+0000: 2464: debug : virStorageFileProbeFormatFromBuf:854 : format=1
2020-02-04 06:16:25.125+0000: 2453: debug : virStoragePoolCreateXML:564 : conn=0x7faf6c000c20, xmlDesc=<pool type="iscsi-direct">
  <name>virtimages</name>
  <source>
    <host name="10.66.85.243"/>
    <device path="iqn.2020-01.com.virttest:blockdev-pool.target61"/>
            <initiator>
      <iqn name="iqn.2013-06.com.example:iscsi-initiator"/>
    </initiator>
  </source>
</pool>
, flags=0x0
2020-02-04 06:16:25.137+0000: 2453: error : virISCSIDirectReportLuns:350 : internal error: Failed to reportluns: Failed to send ReportLuns command
2020-02-04 06:16:25.137+0000: 2453: error : virISCSIDirectDisconnect:392 : internal error: Failed to logout: Failed to start logout() Trying to logout while not logged in.

Comment 3 Michal Privoznik 2021-06-02 08:46:45 UTC
Patch proposed upstream:

https://listman.redhat.com/archives/libvir-list/2021-June/msg00050.html

Comment 4 Michal Privoznik 2021-06-09 06:08:56 UTC
Merged upstream as:

Author:     Michal Prívozník <mprivozn>
AuthorDate: Wed Jun 2 10:34:46 2021 +0200
Commit:     Michal Prívozník <mprivozn>
CommitDate: Wed Jun 9 08:07:07 2021 +0200

    storage: Don't overwrite error in virISCSIDirectDisconnect()
    
    The iscsi-direct storage pool backend works merely like this: a
    connection is established to the target (usually done via
    virStorageBackendISCSIDirectSetConnection()), intended action is
    executed (e.g. reporting LUNs, volume wiping), and at the end the
    connection is closed via virISCSIDirectDisconnect().
    
    The problem is that virISCSIDirectDisconnect() reports its own
    errors which may overwrite error that occurred during LUN
    reporting, or volume wiping or whatever.
    
    To fix this, use virErrorPreserveLast() + virErrorRestore()
    combo, which either preserves previously reported error message,
    or is NOP if there's no error reported.
    
    Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=1797879
    Signed-off-by: Michal Privoznik <mprivozn>
    Reviewed-by: Ján Tomko <jtomko>

v7.4.0-72-ga190906977

Comment 5 Meina Li 2021-06-30 07:29:22 UTC
Verified:tested version:
libvirt-7.0.0-4.fc34.x86_64
qemu-kvm-5.2.0-8.fc34.x86_64

Get the expected result:
# virsh pool-create pool.xml 
error: Failed to create pool from pool.xml
error: internal error: Failed to login: Failed to log in to target. Status: Service unavailable(769)

Comment 8 Meina Li 2021-07-14 06:18:45 UTC
Hi, Michal:

I can't get the expected result in libvirt-7.5.0-1.module+el8.5.0+11664+59f87560.x86_64 for this bug:
# iscsiadm -m discovery -t st -p 10.66.87.196
10.66.87.196:3260,1 iqn.2021-04.com.virttest:emulated-iscsi.target
# cat iscsi-direct.pool 
<pool type="iscsi-direct">
  <name>iscsi-direct</name>
  <source>
    <host name="10.66.87.196"/>
    <device path="iqn.2021-04.com.virttest:emulated-iscsi.target1"/>
    <initiator>
      <iqn name="iqn.2021-07.com.example:iscsi-initiator"/>
    </initiator>
  </source>
</pool>
# virsh pool-create iscsi-direct.pool
error: Failed to create pool from iscsi-direct.pool
error: internal error: Failed to reportluns: Failed to send ReportLuns command

But the error message in upstream is expected:
# virsh pool-create pool.xml 
error: Failed to create pool from pool.xml
error: internal error: Failed to login: Failed to log in to target. Status: Service unavailable(769)

Would you like to check this difference? Thanks.

Comment 9 Michal Privoznik 2021-07-14 08:52:57 UTC
(In reply to Meina Li from comment #8)
> 
> Would you like to check this difference? Thanks.

So the difference is that comment 5 tested libvirt on Fedora 34 and comment 8 on RHEL. I suspect there's a different version of libiscsi in RHEL and Fedora. In fact, RHEL has 1.18.0 which was released ~5 years ago. Therefore, it's very likely that libiscsi was fixed meanwhile to report error during login rather than when trying to list LUNs. I think it's okay, because this bug is originally about something slightly different: we were overwriting error when creating the pool and thus reported misleading error message. This is no longer the case. While I agree that error message is still weird a bit it is definitely better than it was.

BTW I think the following libiscsi commit fixed the libiscsi behaviour:

https://github.com/sahlberg/libiscsi/commit/e9c1f102588447255c75f0d57bbdc8341fc4ec96

Comment 10 Michal Privoznik 2021-07-14 10:08:22 UTC
Actually, I ran bisect and found that the following libiscsi commit fixes the problem:

https://github.com/sahlberg/libiscsi/commit/b5210a1e31afb9f0adf369cde11c612f3365432e

It's contained in 1.19.0 but not in 1.18.0 release. Hence the difference.

Comment 11 Meina Li 2021-07-15 01:17:31 UTC
So according to comment 9, move this bug to be verified.

Comment 13 errata-xmlrpc 2021-11-16 07:49:56 UTC
Since the problem described in this bug report should be
resolved in a recent advisory, it has been closed with a
resolution of ERRATA.

For information on the advisory (virt:av bug fix and enhancement update), and where to find the updated
files, follow the link below.

If the solution does not work for you, open a new bug report.

https://access.redhat.com/errata/RHBA-2021:4684