I have run into some issues with zfsbootmenu after reboot. After the UEFI phase zfsbootmenu starts and displays an error “Unable to import pool, retryin in” - and keeps retrying.
I have checked using a rescue disk and the pool is fine.
zreport command show that there are no pools or datasets available.
What might be the issue here and how can i fix it?
Thank you in advance for any help
It sounds at a guess like perhaps you lost the special “bootfs” zfs property on your pool, which tells ZFSBootMenu which dataset to boot from.
root@elden:/# zpool get bootfs
NAME PROPERTY VALUE SOURCE
rpool bootfs rpool/ROOT/ubuntu.2023.01.15 local
You might also want to check for any zfsbootmenu properties at the dataset level. There should be a command line arguments property for your root dataset:
root@elden:/# zfs get all -r rpool | grep zfsbootmenu | grep -v inherited
rpool/ROOT org.zfsbootmenu:commandline spl_hostid=3c479c74 ro local
Which version of Ubuntu? There’s a breaking ZFS-related bug in the Noble beta right now; a patch was created only yesterday (you can see issues with the 6.8 kernel and Ubuntu Noble in the mailing lists) but it hasn’t been applied in the repos yet.
Have you tried importing the pool from the ZBM rescue shell, to see if you get any interesting error messages (or, for that matter, if it just works when done manually)?
The screenshots are from zfsbootmenu shell. Using zfsbootmenu i’m unable to boot the system.
The zpool properties were checked by booting ubuntu live from usb drive and importing my pool.
OK, now check the enabled features on the pool. If you or an upgrade script ran a zpool upgrade recently, and you forgot to create the pool originally with compat=zfs2.1, you may have a bleeding-edge on-disk feature enabled that ZBM doesn’t know how to cope with.
zpool get all | grep feature\@ to list the features on your pool and whether they’re disabled, enabled, or active; I don’t know off the top of my head which features might have popped up recently that aren’t backward-compatible with 2.1, but seems to me that’s pretty much got to be the issue.
The only other thing you might try is creating a portable ZBM boot drive on a handy USB thumbdrive, using the latest version of ZBM, in case it’s just that you’ve got a particularly old version of ZBM on the boot partition on your actual system.
You’re welcome! Glad it was a relatively painless fix. Don’t forget that portable boot trick–I’d advise essentially both always having one handy, and always remembering how to update it (which is just doing the curl command again to fetch a fresh copy of BOOTX64.EFI).
Hmmm. Comming back to the issue. It looks like my bios is unable to use zfsbootmenu as a default entry for booting (but i can boot using boot override):
In result - i can manually boot my system using ZFSBootMenu, but it does not work during automatic boot. It apears that rEfind uses older copy of ZFSbootmenu. How can i upgrade it so the system will be able to reboot without manual boot override?